test

Committer:
yamaguch
Date:
Wed Nov 16 03:01:34 2011 +0000
Revision:
13:f99f407ed83c
Parent:
12:ea843204a68a
Child:
14:f767e0fbc620

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
yamaguch 9:48a9f99e2cfd 1 /*
yamaguch 9:48a9f99e2cfd 2 Copyright (c) 2011, Senio Networks, Inc.
yamaguch 9:48a9f99e2cfd 3
yamaguch 9:48a9f99e2cfd 4 Permission is hereby granted, free of charge, to any person obtaining a copy
yamaguch 9:48a9f99e2cfd 5 of this software and associated documentation files (the "Software"), to deal
yamaguch 9:48a9f99e2cfd 6 in the Software without restriction, including without limitation the rights
yamaguch 9:48a9f99e2cfd 7 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
yamaguch 9:48a9f99e2cfd 8 copies of the Software, and to permit persons to whom the Software is
yamaguch 9:48a9f99e2cfd 9 furnished to do so, subject to the following conditions:
yamaguch 9:48a9f99e2cfd 10
yamaguch 9:48a9f99e2cfd 11 The above copyright notice and this permission notice shall be included in
yamaguch 9:48a9f99e2cfd 12 all copies or substantial portions of the Software.
yamaguch 9:48a9f99e2cfd 13
yamaguch 9:48a9f99e2cfd 14 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
yamaguch 9:48a9f99e2cfd 15 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
yamaguch 9:48a9f99e2cfd 16 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
yamaguch 9:48a9f99e2cfd 17 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
yamaguch 9:48a9f99e2cfd 18 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
yamaguch 9:48a9f99e2cfd 19 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
yamaguch 9:48a9f99e2cfd 20 THE SOFTWARE.
yamaguch 9:48a9f99e2cfd 21 */
yamaguch 9:48a9f99e2cfd 22
yamaguch 9:48a9f99e2cfd 23 #ifndef XBEE_H
yamaguch 9:48a9f99e2cfd 24 #define XBEE_H
yamaguch 9:48a9f99e2cfd 25
yamaguch 9:48a9f99e2cfd 26 #include "mbed.h"
yamaguch 9:48a9f99e2cfd 27 #include "IOSample.h"
yamaguch 9:48a9f99e2cfd 28
yamaguch 9:48a9f99e2cfd 29 const int BUFSIZE = 512;
yamaguch 9:48a9f99e2cfd 30 const char ESCAPE = 0x7D;
yamaguch 9:48a9f99e2cfd 31 const char PREAMBLE = 0x7E;
yamaguch 9:48a9f99e2cfd 32
yamaguch 9:48a9f99e2cfd 33 /**
yamaguch 9:48a9f99e2cfd 34 * class for XBee module API mode interface
yamaguch 9:48a9f99e2cfd 35 */
yamaguch 9:48a9f99e2cfd 36 class XBee : public Serial {
yamaguch 9:48a9f99e2cfd 37 public:
yamaguch 10:56b31a94f98e 38 /**
yamaguch 11:88f50cc32d7e 39 *
yamaguch 10:56b31a94f98e 40 */
yamaguch 9:48a9f99e2cfd 41 enum FrameType {
yamaguch 13:f99f407ed83c 42 /**
yamaguch 13:f99f407ed83c 43 * No Data
yamaguch 13:f99f407ed83c 44 */
yamaguch 9:48a9f99e2cfd 45 None = 0,
yamaguch 11:88f50cc32d7e 46 /**
yamaguch 11:88f50cc32d7e 47 * AT Command Response
yamaguch 11:88f50cc32d7e 48 */
yamaguch 9:48a9f99e2cfd 49 ATCommandResponse,
yamaguch 13:f99f407ed83c 50
yamaguch 11:88f50cc32d7e 51 /**
yamaguch 11:88f50cc32d7e 52 * Modem Status
yamaguch 11:88f50cc32d7e 53 */
yamaguch 9:48a9f99e2cfd 54 ModemStatus,
yamaguch 13:f99f407ed83c 55
yamaguch 11:88f50cc32d7e 56 /**
yamaguch 11:88f50cc32d7e 57 */
yamaguch 9:48a9f99e2cfd 58 ZigBeeTransmitStatus,
yamaguch 13:f99f407ed83c 59
yamaguch 11:88f50cc32d7e 60 /**
yamaguch 11:88f50cc32d7e 61 */
yamaguch 9:48a9f99e2cfd 62 ZigBeeReceivePacket,
yamaguch 13:f99f407ed83c 63
yamaguch 11:88f50cc32d7e 64 /**
yamaguch 11:88f50cc32d7e 65 */
yamaguch 9:48a9f99e2cfd 66 ZigBeeExplicitRxIndicator,
yamaguch 13:f99f407ed83c 67
yamaguch 11:88f50cc32d7e 68 /**
yamaguch 11:88f50cc32d7e 69 */
yamaguch 9:48a9f99e2cfd 70 ZigBeeIODataSampleRxIndicator,
yamaguch 13:f99f407ed83c 71
yamaguch 11:88f50cc32d7e 72 /**
yamaguch 11:88f50cc32d7e 73 */
yamaguch 9:48a9f99e2cfd 74 XBeeSensorReadIndicator,
yamaguch 10:56b31a94f98e 75
yamaguch 11:88f50cc32d7e 76 /**
yamaguch 11:88f50cc32d7e 77 */
yamaguch 9:48a9f99e2cfd 78 NodeIdentificationIndicator,
yamaguch 13:f99f407ed83c 79
yamaguch 11:88f50cc32d7e 80 /**
yamaguch 11:88f50cc32d7e 81 */
yamaguch 9:48a9f99e2cfd 82 RemoteCommandResponse,
yamaguch 13:f99f407ed83c 83
yamaguch 11:88f50cc32d7e 84 /**
yamaguch 11:88f50cc32d7e 85 */
yamaguch 9:48a9f99e2cfd 86 Other
yamaguch 9:48a9f99e2cfd 87 };
yamaguch 10:56b31a94f98e 88 /**
yamaguch 10:56b31a94f98e 89 * ValueType
yamaguch 10:56b31a94f98e 90 */
yamaguch 9:48a9f99e2cfd 91 enum ValueType {
yamaguch 9:48a9f99e2cfd 92 FrameID,
yamaguch 9:48a9f99e2cfd 93 ATCommand,
yamaguch 9:48a9f99e2cfd 94 Status,
yamaguch 9:48a9f99e2cfd 95 CommandData,
yamaguch 9:48a9f99e2cfd 96 Address16,
yamaguch 9:48a9f99e2cfd 97 Address64,
yamaguch 9:48a9f99e2cfd 98 RetryCount,
yamaguch 9:48a9f99e2cfd 99 DeliveryStatus,
yamaguch 9:48a9f99e2cfd 100 DiscoveryStatus,
yamaguch 9:48a9f99e2cfd 101 ReceiveOptions,
yamaguch 9:48a9f99e2cfd 102 ReceivedData,
yamaguch 9:48a9f99e2cfd 103 RawData
yamaguch 9:48a9f99e2cfd 104 };
yamaguch 9:48a9f99e2cfd 105
yamaguch 9:48a9f99e2cfd 106 /**
yamaguch 9:48a9f99e2cfd 107 * creates an XBee interface object.
yamaguch 9:48a9f99e2cfd 108 *
yamaguch 9:48a9f99e2cfd 109 * @param ser Serial object through which XBee module is connected to mbed
yamaguch 9:48a9f99e2cfd 110 * @param apiMode API mode either 1 or 2 (use escape; default)
yamaguch 9:48a9f99e2cfd 111 * @param debug display debugging (I/O state) information through LEDs
yamaguch 9:48a9f99e2cfd 112 */
yamaguch 9:48a9f99e2cfd 113 XBee(Serial& ser, int apiMode = 2, bool debug = false);
yamaguch 9:48a9f99e2cfd 114
yamaguch 9:48a9f99e2cfd 115 /**
yamaguch 9:48a9f99e2cfd 116 * creates an XBee interface object.
yamaguch 9:48a9f99e2cfd 117 *
yamaguch 9:48a9f99e2cfd 118 * @param ser Serial object through which XBee module is connected to mbed
yamaguch 9:48a9f99e2cfd 119 * @param mon alternate Serial object for monitoring (use serial ports other than USBTX/USBRX)
yamaguch 9:48a9f99e2cfd 120 * @param apiMode API mode either 1 or 2 (use escape; default)
yamaguch 9:48a9f99e2cfd 121 * @param debug display debugging (I/O state) information through LEDs
yamaguch 9:48a9f99e2cfd 122 */
yamaguch 9:48a9f99e2cfd 123 XBee(Serial& ser, Serial& mon, int apiMode = 2, bool debug = false);
yamaguch 9:48a9f99e2cfd 124
yamaguch 9:48a9f99e2cfd 125 /**
yamaguch 9:48a9f99e2cfd 126 * initializes XBee module.
yamaguch 9:48a9f99e2cfd 127 *
yamaguch 9:48a9f99e2cfd 128 * issues VR command to test XBee modem connection
yamaguch 9:48a9f99e2cfd 129 *
yamaguch 9:48a9f99e2cfd 130 * @returns true if initialization succeeded, false otherwise
yamaguch 9:48a9f99e2cfd 131 */
yamaguch 9:48a9f99e2cfd 132 bool init(float timeout = 15.0);
yamaguch 9:48a9f99e2cfd 133
yamaguch 9:48a9f99e2cfd 134 /**
yamaguch 9:48a9f99e2cfd 135 * sets destination addresses.
yamaguch 9:48a9f99e2cfd 136 *
yamaguch 9:48a9f99e2cfd 137 * @param address64 64-bit destination address in unsigned long long
yamaguch 9:48a9f99e2cfd 138 * @param address16 16-bit destination address in unsigned short
yamaguch 9:48a9f99e2cfd 139 */
yamaguch 9:48a9f99e2cfd 140 void setDestination(unsigned long long address64, unsigned short address16 = 0xFFFE);
yamaguch 9:48a9f99e2cfd 141
yamaguch 9:48a9f99e2cfd 142 /**
yamaguch 9:48a9f99e2cfd 143 * sets destination addresses.
yamaguch 9:48a9f99e2cfd 144 *
yamaguch 9:48a9f99e2cfd 145 * @param address64 64-bit destination address in bytes (big endian)
yamaguch 9:48a9f99e2cfd 146 * @param address16 16-bit destination address in bytes
yamaguch 9:48a9f99e2cfd 147 */
yamaguch 9:48a9f99e2cfd 148 void setDestination(char address64[], char address16[]);
yamaguch 9:48a9f99e2cfd 149
yamaguch 9:48a9f99e2cfd 150 /**
yamaguch 9:48a9f99e2cfd 151 * sets 64-bit destination address.
yamaguch 9:48a9f99e2cfd 152 *
yamaguch 9:48a9f99e2cfd 153 * this function is used when 16-bit address is unknown
yamaguch 9:48a9f99e2cfd 154 * @param address64 64-bit destination address in bytes (big endian)
yamaguch 9:48a9f99e2cfd 155 */
yamaguch 9:48a9f99e2cfd 156 void setDestination(char address64[]);
yamaguch 9:48a9f99e2cfd 157
yamaguch 9:48a9f99e2cfd 158 /**
yamaguch 9:48a9f99e2cfd 159 * sends an AT command.
yamaguch 9:48a9f99e2cfd 160 *
yamaguch 9:48a9f99e2cfd 161 * @param command AT command char string
yamaguch 9:48a9f99e2cfd 162 * @param param parameter to the AT command (pointer to byte array)
yamaguch 9:48a9f99e2cfd 163 * @param param_length parameter length in bytes
yamaguch 9:48a9f99e2cfd 164 * @param queue true if command paramter is to be queued
yamaguch 9:48a9f99e2cfd 165 */
yamaguch 9:48a9f99e2cfd 166 void sendCommand(char* command, char* param = 0, int param_length = 0, bool queue = false);
yamaguch 9:48a9f99e2cfd 167
yamaguch 9:48a9f99e2cfd 168 /**
yamaguch 9:48a9f99e2cfd 169 * sends a remote AT command.
yamaguch 9:48a9f99e2cfd 170 *
yamaguch 9:48a9f99e2cfd 171 * sends an AT command to the XBee(s) at the destination address
yamaguch 9:48a9f99e2cfd 172 *
yamaguch 9:48a9f99e2cfd 173 * @param command AT command char string
yamaguch 9:48a9f99e2cfd 174 * @param param parameter to the AT command (pointer to byte array)
yamaguch 9:48a9f99e2cfd 175 * @param param_length parameter length in bytes
yamaguch 9:48a9f99e2cfd 176 * @param options remote command options
yamaguch 9:48a9f99e2cfd 177 */
yamaguch 9:48a9f99e2cfd 178 void sendRemoteCommand(char* command, char* param = 0, int param_length = 0, char options = 0x02);
yamaguch 9:48a9f99e2cfd 179
yamaguch 9:48a9f99e2cfd 180
yamaguch 9:48a9f99e2cfd 181 /**
yamaguch 9:48a9f99e2cfd 182 * executes an AT command then gets its result.
yamaguch 9:48a9f99e2cfd 183 *
yamaguch 9:48a9f99e2cfd 184 * @param command AT command char string
yamaguch 9:48a9f99e2cfd 185 * @param param parameter to the AT command (pointer to byte array)
yamaguch 9:48a9f99e2cfd 186 * @param param_length parameter length in bytes
yamaguch 9:48a9f99e2cfd 187 *
yamaguch 9:48a9f99e2cfd 188 * @returns pointer to the command result, if the result is a number (char, short, long, long long),
yamaguch 9:48a9f99e2cfd 189 * the address to the number will be returned; otherwise the address to the byte array
yamaguch 9:48a9f99e2cfd 190 * containing the command response will be returned.
yamaguch 9:48a9f99e2cfd 191 */
yamaguch 9:48a9f99e2cfd 192 void *executeCommand(char *command, char* param = 0, int laram_length = 0);
yamaguch 9:48a9f99e2cfd 193
yamaguch 9:48a9f99e2cfd 194 /**
yamaguch 9:48a9f99e2cfd 195 * sends data to the XBee(s) at the destination address.
yamaguch 9:48a9f99e2cfd 196 *
yamaguch 9:48a9f99e2cfd 197 * @param data address to the data (byte array)
yamaguch 9:48a9f99e2cfd 198 * @param length data length in bytes
yamaguch 9:48a9f99e2cfd 199 */
yamaguch 9:48a9f99e2cfd 200 void send(char *data, int length);
yamaguch 9:48a9f99e2cfd 201
yamaguch 9:48a9f99e2cfd 202 /**
yamaguch 9:48a9f99e2cfd 203 * sends data and confirm the transmit status.
yamaguch 9:48a9f99e2cfd 204 *
yamaguch 9:48a9f99e2cfd 205 * @param data address to the data (byte array)
yamaguch 9:48a9f99e2cfd 206 * @param length data length in bytes
yamaguch 9:48a9f99e2cfd 207 *
yamaguch 9:48a9f99e2cfd 208 * @returns true if sent successfully, false otherwise (either timeout or send error occurred)
yamaguch 9:48a9f99e2cfd 209 */
yamaguch 9:48a9f99e2cfd 210 bool sendConfirm(char *data, int length);
yamaguch 9:48a9f99e2cfd 211
yamaguch 9:48a9f99e2cfd 212 /**
yamaguch 9:48a9f99e2cfd 213 * sends data to the destination using printf format.
yamaguch 9:48a9f99e2cfd 214 *
yamaguch 9:48a9f99e2cfd 215 * @param format printf format string, followed by corresponding arguments
yamaguch 9:48a9f99e2cfd 216 *
yamaguch 9:48a9f99e2cfd 217 * @returns the number of charancters sent, or negative if error occurred
yamaguch 9:48a9f99e2cfd 218 */
yamaguch 9:48a9f99e2cfd 219 int printf(const char *format, ...);
yamaguch 9:48a9f99e2cfd 220
yamaguch 9:48a9f99e2cfd 221 /**
yamaguch 9:48a9f99e2cfd 222 * receives data frame from the XBee module.
yamaguch 9:48a9f99e2cfd 223 *
yamaguch 9:48a9f99e2cfd 224 * @param timeout seconds bofer time out
yamaguch 9:48a9f99e2cfd 225 *
yamaguch 9:48a9f99e2cfd 226 * @returns FrameType of the received frame data
yamaguch 9:48a9f99e2cfd 227 */
yamaguch 9:48a9f99e2cfd 228 FrameType receive(float timeout = 3.0);
yamaguch 9:48a9f99e2cfd 229
yamaguch 9:48a9f99e2cfd 230 /**
yamaguch 9:48a9f99e2cfd 231 * scan received data according to the specified format.
yamaguch 9:48a9f99e2cfd 232 *
yamaguch 9:48a9f99e2cfd 233 * @param type ValueType of the data to be scanned
yamaguch 9:48a9f99e2cfd 234 * @param value pointer to the byte array to store the scanned value
yamaguch 9:48a9f99e2cfd 235 * @param maxlength max size of the value in bytes
yamaguch 9:48a9f99e2cfd 236 * @param length pointer to an int to receive the actual data length
yamaguch 9:48a9f99e2cfd 237 *
yamaguch 9:48a9f99e2cfd 238 * @param true if scan succeeded, false otherwise
yamaguch 9:48a9f99e2cfd 239 */
yamaguch 9:48a9f99e2cfd 240 bool scan(ValueType type, char *value, int maxlength = 1, int *length = 0);
yamaguch 9:48a9f99e2cfd 241
yamaguch 9:48a9f99e2cfd 242 /**
yamaguch 9:48a9f99e2cfd 243 * gets the XBee firmware version.
yamaguch 9:48a9f99e2cfd 244 *
yamaguch 9:48a9f99e2cfd 245 * @returns XBee firmwre version in int (unsigned short value)
yamaguch 9:48a9f99e2cfd 246 */
yamaguch 9:48a9f99e2cfd 247 int getFirmwareVersion();
yamaguch 9:48a9f99e2cfd 248
yamaguch 9:48a9f99e2cfd 249 /**
yamaguch 9:48a9f99e2cfd 250 * gets the current frame ID.
yamaguch 9:48a9f99e2cfd 251 *
yamaguch 9:48a9f99e2cfd 252 * @returns frame ID number being used in the next send request
yamaguch 9:48a9f99e2cfd 253 */
yamaguch 9:48a9f99e2cfd 254 char getFrameID();
yamaguch 9:48a9f99e2cfd 255
yamaguch 9:48a9f99e2cfd 256 /**
yamaguch 9:48a9f99e2cfd 257 * sets to run in debug mode.
yamaguch 9:48a9f99e2cfd 258 *
yamaguch 9:48a9f99e2cfd 259 * @param debug true to display debugging information
yamaguch 9:48a9f99e2cfd 260 */
yamaguch 9:48a9f99e2cfd 261 void setDebug(bool debug);
yamaguch 9:48a9f99e2cfd 262
yamaguch 9:48a9f99e2cfd 263 /**
yamaguch 9:48a9f99e2cfd 264 * displays received data in dump format.
yamaguch 9:48a9f99e2cfd 265 */
yamaguch 9:48a9f99e2cfd 266 void dump();
yamaguch 9:48a9f99e2cfd 267
yamaguch 9:48a9f99e2cfd 268 /**
yamaguch 9:48a9f99e2cfd 269 * displays the internal data fields and receive buffer in dump format.
yamaguch 9:48a9f99e2cfd 270 */
yamaguch 9:48a9f99e2cfd 271 void dumpAll();
yamaguch 9:48a9f99e2cfd 272
yamaguch 9:48a9f99e2cfd 273 /**
yamaguch 9:48a9f99e2cfd 274 * operator overloading for testing XBee modem connection status.
yamaguch 9:48a9f99e2cfd 275 *
yamaguch 9:48a9f99e2cfd 276 * @returns false if XBee modem connection has an error
yamaguch 9:48a9f99e2cfd 277 */
yamaguch 9:48a9f99e2cfd 278 operator bool();
yamaguch 9:48a9f99e2cfd 279
yamaguch 9:48a9f99e2cfd 280 private:
yamaguch 9:48a9f99e2cfd 281 Serial mon;
yamaguch 9:48a9f99e2cfd 282 BusOut leds;
yamaguch 9:48a9f99e2cfd 283 int apiMode;
yamaguch 9:48a9f99e2cfd 284 volatile enum {UNKNOWN, LENGTH1, LENGTH2, DATA, SUMCHECK} state;
yamaguch 9:48a9f99e2cfd 285 volatile int cur, in, out, received, free;
yamaguch 9:48a9f99e2cfd 286 char frame_id;
yamaguch 9:48a9f99e2cfd 287 char destination64[8];
yamaguch 9:48a9f99e2cfd 288 char destination16[2];
yamaguch 9:48a9f99e2cfd 289 char buf[BUFSIZE];
yamaguch 9:48a9f99e2cfd 290 bool debug;
yamaguch 9:48a9f99e2cfd 291
yamaguch 9:48a9f99e2cfd 292 void send(char c);
yamaguch 9:48a9f99e2cfd 293 void send2(char c);
yamaguch 9:48a9f99e2cfd 294 void sendFrame(char* frame, int length);
yamaguch 9:48a9f99e2cfd 295 int createTxRequest(char frame_id, char* data, int data_length, char* buf, int buf_size);
yamaguch 9:48a9f99e2cfd 296 int createAtRequest(char frame_id, char* command, char* param, int param_length, bool queue, char* buf, int buf_size);
yamaguch 9:48a9f99e2cfd 297 int createRemoteAtRequest(char frame_id, char* command, char* param, int param_length, char options, char* buf, int buf_size);
yamaguch 9:48a9f99e2cfd 298 int seekFor(FrameType type, float timeout);
yamaguch 9:48a9f99e2cfd 299 FrameType getFrameType(char c);
yamaguch 9:48a9f99e2cfd 300 bool scan(int i, ValueType type, char *value, int maxlength = 1, int *length = 0);
yamaguch 9:48a9f99e2cfd 301 void flush();
yamaguch 9:48a9f99e2cfd 302 void rxInterruptHandler();
yamaguch 9:48a9f99e2cfd 303 void rxInterruptHandler2();
yamaguch 9:48a9f99e2cfd 304
yamaguch 9:48a9f99e2cfd 305 void dump(char* data, int length);
yamaguch 9:48a9f99e2cfd 306 void dumpIOSample(char *data, int length);
yamaguch 9:48a9f99e2cfd 307 void copy(char *toBuf, int fromIndex, int length);
yamaguch 9:48a9f99e2cfd 308 };
yamaguch 9:48a9f99e2cfd 309
yamaguch 9:48a9f99e2cfd 310 #endif