I have a problem getting this to work. Server only recieves half of the data being sent. Whats wrong

Dependencies:   mbed

Committer:
tax
Date:
Tue Mar 29 13:20:15 2011 +0000
Revision:
0:66300c77c6e9

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
tax 0:66300c77c6e9 1
tax 0:66300c77c6e9 2 /*
tax 0:66300c77c6e9 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
tax 0:66300c77c6e9 4
tax 0:66300c77c6e9 5 Permission is hereby granted, free of charge, to any person obtaining a copy
tax 0:66300c77c6e9 6 of this software and associated documentation files (the "Software"), to deal
tax 0:66300c77c6e9 7 in the Software without restriction, including without limitation the rights
tax 0:66300c77c6e9 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
tax 0:66300c77c6e9 9 copies of the Software, and to permit persons to whom the Software is
tax 0:66300c77c6e9 10 furnished to do so, subject to the following conditions:
tax 0:66300c77c6e9 11
tax 0:66300c77c6e9 12 The above copyright notice and this permission notice shall be included in
tax 0:66300c77c6e9 13 all copies or substantial portions of the Software.
tax 0:66300c77c6e9 14
tax 0:66300c77c6e9 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
tax 0:66300c77c6e9 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
tax 0:66300c77c6e9 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
tax 0:66300c77c6e9 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
tax 0:66300c77c6e9 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
tax 0:66300c77c6e9 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
tax 0:66300c77c6e9 21 THE SOFTWARE.
tax 0:66300c77c6e9 22 */
tax 0:66300c77c6e9 23
tax 0:66300c77c6e9 24 #include "netCfg.h"
tax 0:66300c77c6e9 25 #if NET_GPRS_MODULE
tax 0:66300c77c6e9 26
tax 0:66300c77c6e9 27 #include "GPRSModuleNetIf.h"
tax 0:66300c77c6e9 28
tax 0:66300c77c6e9 29 #define __DEBUG
tax 0:66300c77c6e9 30 #include "dbg/dbg.h"
tax 0:66300c77c6e9 31
tax 0:66300c77c6e9 32 GPRSModuleNetIf::GPRSModuleNetIf(PinName tx, PinName rx, int baud /*= 115200*/) : PPPNetIf(NULL), m_serial(tx, rx)
tax 0:66300c77c6e9 33 {
tax 0:66300c77c6e9 34 PPPNetIf::m_pIf = new GPRSModem();
tax 0:66300c77c6e9 35 m_serial.baud(baud);
tax 0:66300c77c6e9 36 }
tax 0:66300c77c6e9 37
tax 0:66300c77c6e9 38 GPRSModuleNetIf::~GPRSModuleNetIf()
tax 0:66300c77c6e9 39 {
tax 0:66300c77c6e9 40 delete PPPNetIf::m_pIf;
tax 0:66300c77c6e9 41 }
tax 0:66300c77c6e9 42
tax 0:66300c77c6e9 43 PPPErr GPRSModuleNetIf::connect(const char* apn /*= NULL*/, const char* userId /*= NULL*/, const char* password /*= NULL*/) //Connect using GPRS
tax 0:66300c77c6e9 44 {
tax 0:66300c77c6e9 45
tax 0:66300c77c6e9 46 DBG("Powering on module.\n")
tax 0:66300c77c6e9 47 if(!setOn()) //Could not power on module
tax 0:66300c77c6e9 48 {
tax 0:66300c77c6e9 49 DBG("Could not power on module.\n");
tax 0:66300c77c6e9 50 return PPP_MODEM;
tax 0:66300c77c6e9 51 }
tax 0:66300c77c6e9 52
tax 0:66300c77c6e9 53 //wait(10); //Wait for module to init.
tax 0:66300c77c6e9 54
tax 0:66300c77c6e9 55 ATErr atErr;
tax 0:66300c77c6e9 56 for(int i=0; i<3; i++)
tax 0:66300c77c6e9 57 {
tax 0:66300c77c6e9 58 atErr = m_pIf->open(&m_serial); //3 tries
tax 0:66300c77c6e9 59 if(!atErr)
tax 0:66300c77c6e9 60 break;
tax 0:66300c77c6e9 61 DBG("Could not open AT If, trying again.\n");
tax 0:66300c77c6e9 62 wait(4);
tax 0:66300c77c6e9 63 }
tax 0:66300c77c6e9 64
tax 0:66300c77c6e9 65 if(atErr)
tax 0:66300c77c6e9 66 {
tax 0:66300c77c6e9 67 setOff();
tax 0:66300c77c6e9 68 return PPP_MODEM;
tax 0:66300c77c6e9 69 }
tax 0:66300c77c6e9 70
tax 0:66300c77c6e9 71 DBG("AT If opened.\n");
tax 0:66300c77c6e9 72
tax 0:66300c77c6e9 73 PPPErr pppErr;
tax 0:66300c77c6e9 74 for(int i=0; i<3; i++)
tax 0:66300c77c6e9 75 {
tax 0:66300c77c6e9 76 DBG("Trying to connect.\n");
tax 0:66300c77c6e9 77 pppErr = PPPNetIf::GPRSConnect(apn, userId, password);
tax 0:66300c77c6e9 78 if(!pppErr)
tax 0:66300c77c6e9 79 break;
tax 0:66300c77c6e9 80 DBG("Could not connect.\n");
tax 0:66300c77c6e9 81 wait(4);
tax 0:66300c77c6e9 82 }
tax 0:66300c77c6e9 83 if(pppErr)
tax 0:66300c77c6e9 84 {
tax 0:66300c77c6e9 85 setOff();
tax 0:66300c77c6e9 86 return pppErr;
tax 0:66300c77c6e9 87 }
tax 0:66300c77c6e9 88
tax 0:66300c77c6e9 89 DBG("Connected.\n");
tax 0:66300c77c6e9 90
tax 0:66300c77c6e9 91 return PPP_OK;
tax 0:66300c77c6e9 92 }
tax 0:66300c77c6e9 93
tax 0:66300c77c6e9 94 PPPErr GPRSModuleNetIf::disconnect()
tax 0:66300c77c6e9 95 {
tax 0:66300c77c6e9 96 DBG("Disconnecting...\n");
tax 0:66300c77c6e9 97 PPPErr pppErr = PPPNetIf::disconnect();
tax 0:66300c77c6e9 98 if(pppErr)
tax 0:66300c77c6e9 99 return pppErr;
tax 0:66300c77c6e9 100
tax 0:66300c77c6e9 101 m_pIf->close();
tax 0:66300c77c6e9 102
tax 0:66300c77c6e9 103 DBG("Powering off module.\n")
tax 0:66300c77c6e9 104 setOff(); //Power off module
tax 0:66300c77c6e9 105
tax 0:66300c77c6e9 106 DBG("Off.\n")
tax 0:66300c77c6e9 107
tax 0:66300c77c6e9 108 return PPP_OK;
tax 0:66300c77c6e9 109 }
tax 0:66300c77c6e9 110
tax 0:66300c77c6e9 111
tax 0:66300c77c6e9 112 #endif