NetTribute library with debug turned on in FShandler Donatien Garner -> Segundo Equipo -> this version

Committer:
hexley
Date:
Fri Nov 19 01:54:45 2010 +0000
Revision:
0:281d6ff68967

        

Who changed what in which revision?

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