A libery to connect to telegesis zigbee module. Bassed on implemtation of XBEE
Fork of xbee_lib by
telegesis.cpp
- Committer:
- gert_lauritsen
- Date:
- 2013-10-18
- Revision:
- 15:8d4990362a80
- Parent:
- 14:dcf2390f89e2
- Child:
- 17:5a3f81b10a61
File content as of revision 15:8d4990362a80:
#include "telegesis.h" #define CR 0x0D #define LF 0x0A zigbee::zigbee(PinName tx, PinName rx): _zbee(tx, rx) { _tx = tx; _rx = rx; _pos=0; _zbee.baud(19200); _zbee.attach(this, &zigbee::SeePacket, Serial::RxIrq); } zigbee::~zigbee() { } bool zigbee::wait4OK() { Timer t; t.reset(); t.start(); readPacket(); while ((strstr(_responseFrameString,"OK")==0) & (t.read_ms() < 500)) readPacket(); return (strstr(_responseFrameString,"OK")>0); } int zigbee::GetSerial() { /** comes with something like this Telegesis ETRX357-LRS R305C 000D6F0000D5F06A OK */ _zbee.printf("ATI\r"); readPacket(); readPacket(); //commando readPacket(); sscanf(_responseFrameString,"Telegesis %s",HWType); readPacket(); readPacket(); LocalID=hextoint(_responseFrameString); wait_ms(5); return 1; } int zigbee::SetKey(char* key){ /** S09: the link key. Write the same 128-bit number (32 hexadecimal characters) into every device S0A: security configuration. You must set bit 4 in the coordinator, and set bit 8 in all other devices. For more security set bit 2 also in the coordinator. The devices ignore the bits that are not relevant for them, so it is easiest to just set bits 8, 4, and 2 in all devices which gives S0A=0114. */ char psw[50]; sprintf(psw,"ATS09=%s;password\r",key); _zbee.printf(psw); wait4OK(); _zbee.printf("ATS0A=0114;password\r"); return 1; } void zigbee::RecieveData(char *data_buf, int numchar) { int count=0; if(numchar == 0) { numchar = sizeof(data_buf); } while(numchar!=count) { if(_zbee.readable()) { *data_buf = _zbee.getc(); data_buf+=1; count++; } } } int zigbee::Reset() { _zbee.printf("ATZ\r"); wait4OK(); return 1; } int zigbee::ATI() { GetSerial(); return 1; } int zigbee::PingOut() { //just return a OK (sends it ID out out the pan) _zbee.printf("AT+ANNCE\r"); wait4OK(); return 1; } int zigbee::PanScan() {// _zbee.printf("AT+PANSCAN\r"); return 1; } int zigbee::Establish_Network() {// _zbee.printf("AT+EN\r"); return 1; } int zigbee::JoinNetwork() { _zbee.printf("AT+JN\r"); return 1; } int zigbee::ScanNetwork() { _zbee.printf("AT+SN\r"); return 1; } int zigbee::NetworkInfo() { //Return something like this "+N=COO,12,-11,29F0,55C0E0DCE605C522" _zbee.printf("AT+N\r"); return 1; } int zigbee::UniCast(char *adr,char *payload) //Ascii mode with null terminated string { _zbee.printf("AT+UCAST:%s=%s\r",adr,payload); // _zbee.scanf ("UCAST:%X,%X=%s ",&EUI64,&framesize,Zdata); return 1; } int zigbee::UniCastb(char *adr,char *payload, char payloadSize) //sends data in binary format { _zbee.printf("AT+UCASTB:%X,%s\r",adr,payloadSize); //_zbee.scanf ("%*s"); return 1; } //-----------------------Handle incoming data------------------------------ unsigned long zigbee::hextolong(const char *hex) { //return 32 bit unsigned long result = 0; while (*hex) { //så længe det ikke er null if (*hex >= '0' && *hex <= '9') result += (*hex - '0'); else if (*hex >= 'A' && *hex <= 'F') result += (*hex - 'A' +10); else if (*hex >= 'a' && *hex <= 'f') result += (*hex - 'a'+ 10); if (*++hex) //if the neext isn't a null result <<= 4; } return result; } unsigned int zigbee::hextoint(const char *hex) { //return 16 bit unsigned int result = 0; while (*hex) { //så længe det ikke er null if (*hex >= '0' && *hex <= '9') result += (*hex - '0'); else if (*hex >= 'A' && *hex <= 'F') result += (*hex - 'A' +10); else if (*hex >= 'a' && *hex <= 'f') result += (*hex - 'a'+ 10); if (*++hex) //if the neext isn't a null result <<= 4; } return result; } //--------------------------------------------------------------- void zigbee::readPacket() { //read and waits for the packet Timer t; t.reset(); t.start(); while ((GotFrame==0) & (t.read_ms() < 500)){} t.stop(); GotFrame=0; } void zigbee::SeePacket() { char *p; b = _zbee.getc(); if ((b!=CR) & (b!=LF)) _responseFrameData[_pos]=b; _pos=(_pos+1) % MAX_FRAME_DATA_SIZE; if (b==CR) { memcpy(&_responseFrameString,&_responseFrameData,_pos); GotFrame=1; _responseFrameString[_pos]=0; //Nul terminate _pos=0; if (strstr(_responseFrameString,"+UCAST:")) { //returns on that we have sendt something //Do something } else if (strstr(_responseFrameString,"UCAST:")) {//checke for incoming UCAST data //if (sscanf (_responseFrameString,"UCAST:%X,%X=%s ",&EUI64,&framesize,Zdata)>0) p=strstr(_responseFrameString,"="); if (p) { p++; strcpy(Zdata,p); Zdat=1; } } if (strstr(_responseFrameString,"LeftPAN:")) PanOnline=0; //Local node has left the Pan if (strstr(_responseFrameString,"NEWNODE:")) { //NEWNODE: <NodeID>,<EUI64>,<Parent NodeID> //new node on the pan } if ((strstr(_responseFrameString,"OK")>0) & (strstr(_responseFrameString,"TOKDUMP")==0) ) { //if (ScriptState) ConnectScript(); //Ok=1; Cmd=0; LineNo=0; } if (strstr(_responseFrameString,"+N=")) { sscanf (_responseFrameString,"+N=%s,%d,%d,%4X,",Devicetype,&channel,&NodeID,&EPID); } if (strstr(_responseFrameString,"ACK")) { // PacketAck=1; p=strstr(_responseFrameString,":"); p++; //P indholder nu SEQ nummer SeqNumber=hextoint(p); } if (strstr(_responseFrameString,"NAK")) { PacketAck=0; p=strstr(_responseFrameString,":"); p++; //P indholder nu SEQ nummer SeqNumber=hextoint(p); } if (strstr(_responseFrameString,"SEQ")) { // PacketAck=1; p=strstr(_responseFrameString,":"); p++; //P indholder nu SEQ nummer SeqNumber=hextoint(p); } } }