First step: AutoIP compiled in and working

Dependencies:   mbed

Committer:
darran
Date:
Fri Jun 18 09:11:35 2010 +0000
Revision:
0:55a05330f8cc
Child:
1:4218cacaf696

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
darran 0:55a05330f8cc 1
darran 0:55a05330f8cc 2 /*
darran 0:55a05330f8cc 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
darran 0:55a05330f8cc 4
darran 0:55a05330f8cc 5 Permission is hereby granted, free of charge, to any person obtaining a copy
darran 0:55a05330f8cc 6 of this software and associated documentation files (the "Software"), to deal
darran 0:55a05330f8cc 7 in the Software without restriction, including without limitation the rights
darran 0:55a05330f8cc 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
darran 0:55a05330f8cc 9 copies of the Software, and to permit persons to whom the Software is
darran 0:55a05330f8cc 10 furnished to do so, subject to the following conditions:
darran 0:55a05330f8cc 11
darran 0:55a05330f8cc 12 The above copyright notice and this permission notice shall be included in
darran 0:55a05330f8cc 13 all copies or substantial portions of the Software.
darran 0:55a05330f8cc 14
darran 0:55a05330f8cc 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
darran 0:55a05330f8cc 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
darran 0:55a05330f8cc 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
darran 0:55a05330f8cc 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
darran 0:55a05330f8cc 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
darran 0:55a05330f8cc 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
darran 0:55a05330f8cc 21 THE SOFTWARE.
darran 0:55a05330f8cc 22 */
darran 0:55a05330f8cc 23
darran 0:55a05330f8cc 24 #include "GPRSModem.h"
darran 0:55a05330f8cc 25 #include "mbed.h"
darran 0:55a05330f8cc 26
darran 0:55a05330f8cc 27 #define __DEBUG
darran 0:55a05330f8cc 28 #include "dbg/dbg.h"
darran 0:55a05330f8cc 29
darran 0:55a05330f8cc 30 #define WAIT_BTW_NETW_POLLS 3.
darran 0:55a05330f8cc 31
darran 0:55a05330f8cc 32 #include "netCfg.h"
darran 0:55a05330f8cc 33 #if NET_GPRS
darran 0:55a05330f8cc 34
darran 0:55a05330f8cc 35 GPRSModem::GPRSModem() : ATIf()
darran 0:55a05330f8cc 36 {
darran 0:55a05330f8cc 37
darran 0:55a05330f8cc 38 }
darran 0:55a05330f8cc 39
darran 0:55a05330f8cc 40 GPRSModem::~GPRSModem()
darran 0:55a05330f8cc 41 {
darran 0:55a05330f8cc 42
darran 0:55a05330f8cc 43 }
darran 0:55a05330f8cc 44
darran 0:55a05330f8cc 45 GPRSErr GPRSModem::getNetworkState()
darran 0:55a05330f8cc 46 {
darran 0:55a05330f8cc 47 ATIf::flushBuffer();
darran 0:55a05330f8cc 48 /*
darran 0:55a05330f8cc 49 netState can be : (Telit_AT_Reference_Guide.pdf p.98)
darran 0:55a05330f8cc 50 0 - not registered, ME is not currently searching a new operator to register to
darran 0:55a05330f8cc 51 1 - registered, home network
darran 0:55a05330f8cc 52 2 - not registered, but ME is currently searching a new operator to register to
darran 0:55a05330f8cc 53 3 - registration denied
darran 0:55a05330f8cc 54 4 - unknown
darran 0:55a05330f8cc 55 5 - registered, roaming
darran 0:55a05330f8cc 56 */
darran 0:55a05330f8cc 57 // DBG("Network?...\r\n");
darran 0:55a05330f8cc 58 ATIf::setReadMode(false); //Discard chars
darran 0:55a05330f8cc 59 ATIf::setTimeout(10000);
darran 0:55a05330f8cc 60 ATIf::setLineMode(true); //Line mode
darran 0:55a05330f8cc 61 int netState = 0;
darran 0:55a05330f8cc 62 int len;
darran 0:55a05330f8cc 63 len = ATIf::printf("AT+CREG?"); //Registered ?
darran 0:55a05330f8cc 64 if(!len) DBG("\r\nprintf - len=%d\r\n",len);
darran 0:55a05330f8cc 65 if(!len)
darran 0:55a05330f8cc 66 return GPRS_MODEM; //Nothing was actually sent
darran 0:55a05330f8cc 67
darran 0:55a05330f8cc 68 len = ATIf::scanf("+CREG: 0,%d", &netState); //Get status
darran 0:55a05330f8cc 69 if(len != 1) DBG("\r\nscanf - len=%d\r\n",len);
darran 0:55a05330f8cc 70 if(len != 1) //Likely +CMS ERROR was returned
darran 0:55a05330f8cc 71 return GPRS_MODEM;
darran 0:55a05330f8cc 72
darran 0:55a05330f8cc 73 if( !!ATIf::checkOK() ) //Should not be a problem
darran 0:55a05330f8cc 74 {DBG("\r\nNOK\r\n"); return GPRS_MODEM; }
darran 0:55a05330f8cc 75
darran 0:55a05330f8cc 76 switch(netState)
darran 0:55a05330f8cc 77 {
darran 0:55a05330f8cc 78 case 1:
darran 0:55a05330f8cc 79 case 5: //TODO: Option allow roaming
darran 0:55a05330f8cc 80 DBG("\r\nNetwork is up!\r\n");
darran 0:55a05330f8cc 81 return GPRS_OK;
darran 0:55a05330f8cc 82 case 3:
darran 0:55a05330f8cc 83 DBG("\r\nAccess to network denied.\r\n");
darran 0:55a05330f8cc 84 return GPRS_DENIED;
darran 0:55a05330f8cc 85 case 0:
darran 0:55a05330f8cc 86 DBG("\r\nNo network.\r\n");
darran 0:55a05330f8cc 87 return GPRS_NONETWORK;
darran 0:55a05330f8cc 88 case 4:
darran 0:55a05330f8cc 89 case 2:
darran 0:55a05330f8cc 90 //DBG("\r\nRegistering...\r\n");
darran 0:55a05330f8cc 91 return GPRS_REGISTERING;
darran 0:55a05330f8cc 92 }
darran 0:55a05330f8cc 93
darran 0:55a05330f8cc 94 return GPRS_MODEM; // Should not reach this
darran 0:55a05330f8cc 95
darran 0:55a05330f8cc 96 }
darran 0:55a05330f8cc 97
darran 0:55a05330f8cc 98 GPRSErr GPRSModem::setNetworkUp()
darran 0:55a05330f8cc 99 {
darran 0:55a05330f8cc 100 ATIf::flushBuffer();
darran 0:55a05330f8cc 101 GPRSErr err = GPRS_REGISTERING;
darran 0:55a05330f8cc 102 while(true)
darran 0:55a05330f8cc 103 {
darran 0:55a05330f8cc 104 err = getNetworkState();
darran 0:55a05330f8cc 105 if(err != GPRS_REGISTERING)
darran 0:55a05330f8cc 106 break;
darran 0:55a05330f8cc 107 wait(WAIT_BTW_NETW_POLLS);
darran 0:55a05330f8cc 108 }
darran 0:55a05330f8cc 109 return err;
darran 0:55a05330f8cc 110 }
darran 0:55a05330f8cc 111
darran 0:55a05330f8cc 112 //Same, but for GPRS
darran 0:55a05330f8cc 113 GPRSErr GPRSModem::getGPRSState()
darran 0:55a05330f8cc 114 {
darran 0:55a05330f8cc 115 ATIf::flushBuffer();
darran 0:55a05330f8cc 116 /*
darran 0:55a05330f8cc 117 netState can be : (Telit_AT_Reference_Guide.pdf p.192)
darran 0:55a05330f8cc 118 0 - not registered, terminal is not currently searching a new operator to register to
darran 0:55a05330f8cc 119 1 - registered, home network
darran 0:55a05330f8cc 120 2 - not registered, but terminal is currently searching a new operator to register to
darran 0:55a05330f8cc 121 3 - registration denied
darran 0:55a05330f8cc 122 4 - unknown
darran 0:55a05330f8cc 123 5 - registered, roaming
darran 0:55a05330f8cc 124 */
darran 0:55a05330f8cc 125
darran 0:55a05330f8cc 126 DBG("GPRS?...\r\n");
darran 0:55a05330f8cc 127 ATIf::setReadMode(false); //Discard chars
darran 0:55a05330f8cc 128 ATIf::setTimeout(10000);
darran 0:55a05330f8cc 129 ATIf::setLineMode(true); //Line mode
darran 0:55a05330f8cc 130 int netState = 0;
darran 0:55a05330f8cc 131 int len;
darran 0:55a05330f8cc 132 len = ATIf::printf("AT+CGREG?"); //Registered ?
darran 0:55a05330f8cc 133 if(!len)
darran 0:55a05330f8cc 134 return GPRS_MODEM; //Nothing was actually sent
darran 0:55a05330f8cc 135
darran 0:55a05330f8cc 136 len = ATIf::scanf("+CGREG: %*d,%d", &netState); //Get GPRS status, see GSM 07.07 spec as Telit AT ref is wrong
darran 0:55a05330f8cc 137 if(len != 1) DBG("\r\nscanf - len=%d\r\n",len);
darran 0:55a05330f8cc 138 if(len != 1) //Likely +CMS ERROR was returned
darran 0:55a05330f8cc 139 return GPRS_MODEM;
darran 0:55a05330f8cc 140
darran 0:55a05330f8cc 141 if( !!ATIf::checkOK() ) //Should not be a problem
darran 0:55a05330f8cc 142 return GPRS_MODEM;
darran 0:55a05330f8cc 143
darran 0:55a05330f8cc 144 switch(netState)
darran 0:55a05330f8cc 145 {
darran 0:55a05330f8cc 146 case 1:
darran 0:55a05330f8cc 147 case 5: //TODO: Option allow roaming
darran 0:55a05330f8cc 148 DBG("\r\nNetwork is up!\r\n");
darran 0:55a05330f8cc 149 return GPRS_OK;
darran 0:55a05330f8cc 150 case 3:
darran 0:55a05330f8cc 151 DBG("\r\nAccess to network denied.\r\n");
darran 0:55a05330f8cc 152 return GPRS_DENIED;
darran 0:55a05330f8cc 153 case 0:
darran 0:55a05330f8cc 154 DBG("\r\nNo network.\r\n");
darran 0:55a05330f8cc 155 return GPRS_NONETWORK;
darran 0:55a05330f8cc 156 case 4:
darran 0:55a05330f8cc 157 case 2:
darran 0:55a05330f8cc 158 DBG("\r\nRegistering...\r\n");
darran 0:55a05330f8cc 159 return GPRS_REGISTERING;
darran 0:55a05330f8cc 160 }
darran 0:55a05330f8cc 161
darran 0:55a05330f8cc 162 return GPRS_MODEM; // Should not reach this
darran 0:55a05330f8cc 163
darran 0:55a05330f8cc 164 }
darran 0:55a05330f8cc 165
darran 0:55a05330f8cc 166 GPRSErr GPRSModem::setGPRSUp()
darran 0:55a05330f8cc 167 {
darran 0:55a05330f8cc 168 ATIf::flushBuffer();
darran 0:55a05330f8cc 169 GPRSErr err;
darran 0:55a05330f8cc 170
darran 0:55a05330f8cc 171 err = setNetworkUp();
darran 0:55a05330f8cc 172 if(err)
darran 0:55a05330f8cc 173 return err;
darran 0:55a05330f8cc 174
darran 0:55a05330f8cc 175 DBG("\r\nAttaching GPRS...\r\n");
darran 0:55a05330f8cc 176 ATIf::setReadMode(false); //Discard chars
darran 0:55a05330f8cc 177 ATIf::setTimeout(10000);
darran 0:55a05330f8cc 178 ATIf::setLineMode(true); //Line mode
darran 0:55a05330f8cc 179 int len;
darran 0:55a05330f8cc 180
darran 0:55a05330f8cc 181 err = getGPRSState();
darran 0:55a05330f8cc 182 if(err == GPRS_NONETWORK)
darran 0:55a05330f8cc 183 {
darran 0:55a05330f8cc 184 len = ATIf::printf("AT+CGATT=1"); //Attach
darran 0:55a05330f8cc 185 if(!len)
darran 0:55a05330f8cc 186 return GPRS_MODEM; //Nothing was actually sent
darran 0:55a05330f8cc 187
darran 0:55a05330f8cc 188 if( !!ATIf::checkOK() ) //Should not be a problem
darran 0:55a05330f8cc 189 return GPRS_MODEM;
darran 0:55a05330f8cc 190 }
darran 0:55a05330f8cc 191
darran 0:55a05330f8cc 192 while(true)
darran 0:55a05330f8cc 193 {
darran 0:55a05330f8cc 194 err = getGPRSState();
darran 0:55a05330f8cc 195 if(err != GPRS_REGISTERING)
darran 0:55a05330f8cc 196 break;
darran 0:55a05330f8cc 197 wait(WAIT_BTW_NETW_POLLS);
darran 0:55a05330f8cc 198 }
darran 0:55a05330f8cc 199 return err;
darran 0:55a05330f8cc 200 }
darran 0:55a05330f8cc 201
darran 0:55a05330f8cc 202 GPRSErr GPRSModem::setGPRSDown()
darran 0:55a05330f8cc 203 {
darran 0:55a05330f8cc 204 ATIf::flushBuffer();
darran 0:55a05330f8cc 205 DBG("\r\nDetaching GPRS...\r\n");
darran 0:55a05330f8cc 206 ATIf::setReadMode(false); //Discard chars
darran 0:55a05330f8cc 207 ATIf::setTimeout(10000);
darran 0:55a05330f8cc 208 ATIf::setLineMode(true); //Line mode
darran 0:55a05330f8cc 209 int len;
darran 0:55a05330f8cc 210
darran 0:55a05330f8cc 211 len = ATIf::printf("AT+CGATT=0"); //Detach
darran 0:55a05330f8cc 212 if(!len)
darran 0:55a05330f8cc 213 return GPRS_MODEM; //Nothing was actually sent
darran 0:55a05330f8cc 214
darran 0:55a05330f8cc 215 if( !!ATIf::checkOK() ) //Should not be a problem
darran 0:55a05330f8cc 216 return GPRS_MODEM;
darran 0:55a05330f8cc 217
darran 0:55a05330f8cc 218 return GPRS_OK;
darran 0:55a05330f8cc 219 }
darran 0:55a05330f8cc 220
darran 0:55a05330f8cc 221
darran 0:55a05330f8cc 222 GPRSErr GPRSModem::connect(const char* apn /*=NULL*/)
darran 0:55a05330f8cc 223 {
darran 0:55a05330f8cc 224 ATIf::flushBuffer();
darran 0:55a05330f8cc 225 GPRSErr err;
darran 0:55a05330f8cc 226
darran 0:55a05330f8cc 227 ATIf::setReadMode(false); //Discard chars
darran 0:55a05330f8cc 228 ATIf::setTimeout(5000);
darran 0:55a05330f8cc 229 ATIf::setLineMode(true); //Line mode
darran 0:55a05330f8cc 230
darran 0:55a05330f8cc 231 DBG("\r\nConnecting...\r\n");
darran 0:55a05330f8cc 232
darran 0:55a05330f8cc 233 int len;
darran 0:55a05330f8cc 234
darran 0:55a05330f8cc 235 if( apn != NULL ) //Config APN
darran 0:55a05330f8cc 236 {
darran 0:55a05330f8cc 237 len = ATIf::printf("AT+CGDCONT=1,\"IP\",\"%s\"",apn); //Define APN
darran 0:55a05330f8cc 238 if(!len)
darran 0:55a05330f8cc 239 return GPRS_MODEM; //Nothing was actually sent
darran 0:55a05330f8cc 240
darran 0:55a05330f8cc 241 if( !!ATIf::checkOK() ) //Should not be a problem
darran 0:55a05330f8cc 242 return GPRS_MODEM;
darran 0:55a05330f8cc 243 }
darran 0:55a05330f8cc 244
darran 0:55a05330f8cc 245 err = setGPRSUp();
darran 0:55a05330f8cc 246 if(err)
darran 0:55a05330f8cc 247 return err;
darran 0:55a05330f8cc 248
darran 0:55a05330f8cc 249 ATIf::setReadMode(false); //Discard chars
darran 0:55a05330f8cc 250 ATIf::setTimeout(60000);
darran 0:55a05330f8cc 251 ATIf::setLineMode(true); //Line mode
darran 0:55a05330f8cc 252 //
darran 0:55a05330f8cc 253 //len = ATIf::printf("AT+CGDATA=\"PPP\",1"); //Connect using PDP context #1
darran 0:55a05330f8cc 254 // len = ATIf::printf("ATDT *99***1#");
darran 0:55a05330f8cc 255 len = ATIf::printf("ATDT *99#");
darran 0:55a05330f8cc 256 if(!len)
darran 0:55a05330f8cc 257 return GPRS_MODEM; //Nothing was actually sent
darran 0:55a05330f8cc 258
darran 0:55a05330f8cc 259 len = ATIf::scanf("CONNECT"); //Beginning of session
darran 0:55a05330f8cc 260 if(len != 0) //Likely +CME ERROR was returned or NO CARRIER
darran 0:55a05330f8cc 261 return GPRS_MODEM;
darran 0:55a05330f8cc 262
darran 0:55a05330f8cc 263 ATIf::setSignals(false);
darran 0:55a05330f8cc 264
darran 0:55a05330f8cc 265 DBG("\r\nConnected.\r\n");
darran 0:55a05330f8cc 266
darran 0:55a05330f8cc 267 return GPRS_OK; //Time to enter a PPP Session !
darran 0:55a05330f8cc 268
darran 0:55a05330f8cc 269 }
darran 0:55a05330f8cc 270
darran 0:55a05330f8cc 271 GPRSErr GPRSModem::disconnect()
darran 0:55a05330f8cc 272 {
darran 0:55a05330f8cc 273 ATIf::flushBuffer();
darran 0:55a05330f8cc 274 ATIf::setReadMode(false); //Discard chars
darran 0:55a05330f8cc 275 ATIf::setTimeout(5000);
darran 0:55a05330f8cc 276 ATIf::setLineMode(true); //Line mode
darran 0:55a05330f8cc 277
darran 0:55a05330f8cc 278 if( !!ATIf::checkOK() ) //Should be present at the end of connection
darran 0:55a05330f8cc 279 return GPRS_MODEM;
darran 0:55a05330f8cc 280
darran 0:55a05330f8cc 281 GPRSErr err;
darran 0:55a05330f8cc 282 err = setGPRSDown();
darran 0:55a05330f8cc 283 if(err)
darran 0:55a05330f8cc 284 return err;
darran 0:55a05330f8cc 285
darran 0:55a05330f8cc 286 DBG("\r\nDisconnected.\r\n");
darran 0:55a05330f8cc 287
darran 0:55a05330f8cc 288 return GPRS_OK;
darran 0:55a05330f8cc 289 }
darran 0:55a05330f8cc 290
darran 0:55a05330f8cc 291 #endif
darran 0:55a05330f8cc 292