FRDM K64F Metronome

Committer:
ram54288
Date:
Sun May 14 18:35:07 2017 +0000
Revision:
0:a2cb7295a1f7
Initial commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ram54288 0:a2cb7295a1f7 1 /* ESP8266Interface Example
ram54288 0:a2cb7295a1f7 2 * Copyright (c) 2015 ARM Limited
ram54288 0:a2cb7295a1f7 3 *
ram54288 0:a2cb7295a1f7 4 * Licensed under the Apache License, Version 2.0 (the "License");
ram54288 0:a2cb7295a1f7 5 * you may not use this file except in compliance with the License.
ram54288 0:a2cb7295a1f7 6 * You may obtain a copy of the License at
ram54288 0:a2cb7295a1f7 7 *
ram54288 0:a2cb7295a1f7 8 * http://www.apache.org/licenses/LICENSE-2.0
ram54288 0:a2cb7295a1f7 9 *
ram54288 0:a2cb7295a1f7 10 * Unless required by applicable law or agreed to in writing, software
ram54288 0:a2cb7295a1f7 11 * distributed under the License is distributed on an "AS IS" BASIS,
ram54288 0:a2cb7295a1f7 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
ram54288 0:a2cb7295a1f7 13 * See the License for the specific language governing permissions and
ram54288 0:a2cb7295a1f7 14 * limitations under the License.
ram54288 0:a2cb7295a1f7 15 */
ram54288 0:a2cb7295a1f7 16
ram54288 0:a2cb7295a1f7 17 #ifndef ESP8266_H
ram54288 0:a2cb7295a1f7 18 #define ESP8266_H
ram54288 0:a2cb7295a1f7 19
ram54288 0:a2cb7295a1f7 20 #include "ATParser.h"
ram54288 0:a2cb7295a1f7 21
ram54288 0:a2cb7295a1f7 22 /** ESP8266Interface class.
ram54288 0:a2cb7295a1f7 23 This is an interface to a ESP8266 radio.
ram54288 0:a2cb7295a1f7 24 */
ram54288 0:a2cb7295a1f7 25 class ESP8266
ram54288 0:a2cb7295a1f7 26 {
ram54288 0:a2cb7295a1f7 27 public:
ram54288 0:a2cb7295a1f7 28 ESP8266(PinName tx, PinName rx, bool debug=false);
ram54288 0:a2cb7295a1f7 29
ram54288 0:a2cb7295a1f7 30 /**
ram54288 0:a2cb7295a1f7 31 * Startup the ESP8266
ram54288 0:a2cb7295a1f7 32 *
ram54288 0:a2cb7295a1f7 33 * @param mode mode of WIFI 1-client, 2-host, 3-both
ram54288 0:a2cb7295a1f7 34 * @return true only if ESP8266 was setup correctly
ram54288 0:a2cb7295a1f7 35 */
ram54288 0:a2cb7295a1f7 36 bool startup(int mode);
ram54288 0:a2cb7295a1f7 37
ram54288 0:a2cb7295a1f7 38 /**
ram54288 0:a2cb7295a1f7 39 * Reset ESP8266
ram54288 0:a2cb7295a1f7 40 *
ram54288 0:a2cb7295a1f7 41 * @return true only if ESP8266 resets successfully
ram54288 0:a2cb7295a1f7 42 */
ram54288 0:a2cb7295a1f7 43 bool reset(void);
ram54288 0:a2cb7295a1f7 44
ram54288 0:a2cb7295a1f7 45 /**
ram54288 0:a2cb7295a1f7 46 * Enable/Disable DHCP
ram54288 0:a2cb7295a1f7 47 *
ram54288 0:a2cb7295a1f7 48 * @param enabled DHCP enabled when true
ram54288 0:a2cb7295a1f7 49 * @param mode mode of DHCP 0-softAP, 1-station, 2-both
ram54288 0:a2cb7295a1f7 50 * @return true only if ESP8266 enables/disables DHCP successfully
ram54288 0:a2cb7295a1f7 51 */
ram54288 0:a2cb7295a1f7 52 bool dhcp(bool enabled, int mode);
ram54288 0:a2cb7295a1f7 53
ram54288 0:a2cb7295a1f7 54 /**
ram54288 0:a2cb7295a1f7 55 * Connect ESP8266 to AP
ram54288 0:a2cb7295a1f7 56 *
ram54288 0:a2cb7295a1f7 57 * @param ap the name of the AP
ram54288 0:a2cb7295a1f7 58 * @param passPhrase the password of AP
ram54288 0:a2cb7295a1f7 59 * @return true only if ESP8266 is connected successfully
ram54288 0:a2cb7295a1f7 60 */
ram54288 0:a2cb7295a1f7 61 bool connect(const char *ap, const char *passPhrase);
ram54288 0:a2cb7295a1f7 62
ram54288 0:a2cb7295a1f7 63 /**
ram54288 0:a2cb7295a1f7 64 * Disconnect ESP8266 from AP
ram54288 0:a2cb7295a1f7 65 *
ram54288 0:a2cb7295a1f7 66 * @return true only if ESP8266 is disconnected successfully
ram54288 0:a2cb7295a1f7 67 */
ram54288 0:a2cb7295a1f7 68 bool disconnect(void);
ram54288 0:a2cb7295a1f7 69
ram54288 0:a2cb7295a1f7 70 /**
ram54288 0:a2cb7295a1f7 71 * Get the IP address of ESP8266
ram54288 0:a2cb7295a1f7 72 *
ram54288 0:a2cb7295a1f7 73 * @return null-teriminated IP address or null if no IP address is assigned
ram54288 0:a2cb7295a1f7 74 */
ram54288 0:a2cb7295a1f7 75 const char *getIPAddress(void);
ram54288 0:a2cb7295a1f7 76
ram54288 0:a2cb7295a1f7 77 /**
ram54288 0:a2cb7295a1f7 78 * Get the MAC address of ESP8266
ram54288 0:a2cb7295a1f7 79 *
ram54288 0:a2cb7295a1f7 80 * @return null-terminated MAC address or null if no MAC address is assigned
ram54288 0:a2cb7295a1f7 81 */
ram54288 0:a2cb7295a1f7 82 const char *getMACAddress(void);
ram54288 0:a2cb7295a1f7 83
ram54288 0:a2cb7295a1f7 84 /** Get the local gateway
ram54288 0:a2cb7295a1f7 85 *
ram54288 0:a2cb7295a1f7 86 * @return Null-terminated representation of the local gateway
ram54288 0:a2cb7295a1f7 87 * or null if no network mask has been recieved
ram54288 0:a2cb7295a1f7 88 */
ram54288 0:a2cb7295a1f7 89 const char *getGateway();
ram54288 0:a2cb7295a1f7 90
ram54288 0:a2cb7295a1f7 91 /** Get the local network mask
ram54288 0:a2cb7295a1f7 92 *
ram54288 0:a2cb7295a1f7 93 * @return Null-terminated representation of the local network mask
ram54288 0:a2cb7295a1f7 94 * or null if no network mask has been recieved
ram54288 0:a2cb7295a1f7 95 */
ram54288 0:a2cb7295a1f7 96 const char *getNetmask();
ram54288 0:a2cb7295a1f7 97
ram54288 0:a2cb7295a1f7 98 /* Return RSSI for active connection
ram54288 0:a2cb7295a1f7 99 *
ram54288 0:a2cb7295a1f7 100 * @return Measured RSSI
ram54288 0:a2cb7295a1f7 101 */
ram54288 0:a2cb7295a1f7 102 int8_t getRSSI();
ram54288 0:a2cb7295a1f7 103
ram54288 0:a2cb7295a1f7 104 /**
ram54288 0:a2cb7295a1f7 105 * Check if ESP8266 is conenected
ram54288 0:a2cb7295a1f7 106 *
ram54288 0:a2cb7295a1f7 107 * @return true only if the chip has an IP address
ram54288 0:a2cb7295a1f7 108 */
ram54288 0:a2cb7295a1f7 109 bool isConnected(void);
ram54288 0:a2cb7295a1f7 110
ram54288 0:a2cb7295a1f7 111 /** Scan for available networks
ram54288 0:a2cb7295a1f7 112 *
ram54288 0:a2cb7295a1f7 113 * @param ap Pointer to allocated array to store discovered AP
ram54288 0:a2cb7295a1f7 114 * @param limit Size of allocated @a res array, or 0 to only count available AP
ram54288 0:a2cb7295a1f7 115 * @return Number of entries in @a res, or if @a count was 0 number of available networks, negative on error
ram54288 0:a2cb7295a1f7 116 * see @a nsapi_error
ram54288 0:a2cb7295a1f7 117 */
ram54288 0:a2cb7295a1f7 118 int scan(WiFiAccessPoint *res, unsigned limit);
ram54288 0:a2cb7295a1f7 119
ram54288 0:a2cb7295a1f7 120 /**
ram54288 0:a2cb7295a1f7 121 * Open a socketed connection
ram54288 0:a2cb7295a1f7 122 *
ram54288 0:a2cb7295a1f7 123 * @param type the type of socket to open "UDP" or "TCP"
ram54288 0:a2cb7295a1f7 124 * @param id id to give the new socket, valid 0-4
ram54288 0:a2cb7295a1f7 125 * @param port port to open connection with
ram54288 0:a2cb7295a1f7 126 * @param addr the IP address of the destination
ram54288 0:a2cb7295a1f7 127 * @return true only if socket opened successfully
ram54288 0:a2cb7295a1f7 128 */
ram54288 0:a2cb7295a1f7 129 bool open(const char *type, int id, const char* addr, int port);
ram54288 0:a2cb7295a1f7 130
ram54288 0:a2cb7295a1f7 131 /**
ram54288 0:a2cb7295a1f7 132 * Sends data to an open socket
ram54288 0:a2cb7295a1f7 133 *
ram54288 0:a2cb7295a1f7 134 * @param id id of socket to send to
ram54288 0:a2cb7295a1f7 135 * @param data data to be sent
ram54288 0:a2cb7295a1f7 136 * @param amount amount of data to be sent - max 1024
ram54288 0:a2cb7295a1f7 137 * @return true only if data sent successfully
ram54288 0:a2cb7295a1f7 138 */
ram54288 0:a2cb7295a1f7 139 bool send(int id, const void *data, uint32_t amount);
ram54288 0:a2cb7295a1f7 140
ram54288 0:a2cb7295a1f7 141 /**
ram54288 0:a2cb7295a1f7 142 * Receives data from an open socket
ram54288 0:a2cb7295a1f7 143 *
ram54288 0:a2cb7295a1f7 144 * @param id id to receive from
ram54288 0:a2cb7295a1f7 145 * @param data placeholder for returned information
ram54288 0:a2cb7295a1f7 146 * @param amount number of bytes to be received
ram54288 0:a2cb7295a1f7 147 * @return the number of bytes received
ram54288 0:a2cb7295a1f7 148 */
ram54288 0:a2cb7295a1f7 149 int32_t recv(int id, void *data, uint32_t amount);
ram54288 0:a2cb7295a1f7 150
ram54288 0:a2cb7295a1f7 151 /**
ram54288 0:a2cb7295a1f7 152 * Closes a socket
ram54288 0:a2cb7295a1f7 153 *
ram54288 0:a2cb7295a1f7 154 * @param id id of socket to close, valid only 0-4
ram54288 0:a2cb7295a1f7 155 * @return true only if socket is closed successfully
ram54288 0:a2cb7295a1f7 156 */
ram54288 0:a2cb7295a1f7 157 bool close(int id);
ram54288 0:a2cb7295a1f7 158
ram54288 0:a2cb7295a1f7 159 /**
ram54288 0:a2cb7295a1f7 160 * Allows timeout to be changed between commands
ram54288 0:a2cb7295a1f7 161 *
ram54288 0:a2cb7295a1f7 162 * @param timeout_ms timeout of the connection
ram54288 0:a2cb7295a1f7 163 */
ram54288 0:a2cb7295a1f7 164 void setTimeout(uint32_t timeout_ms);
ram54288 0:a2cb7295a1f7 165
ram54288 0:a2cb7295a1f7 166 /**
ram54288 0:a2cb7295a1f7 167 * Checks if data is available
ram54288 0:a2cb7295a1f7 168 */
ram54288 0:a2cb7295a1f7 169 bool readable();
ram54288 0:a2cb7295a1f7 170
ram54288 0:a2cb7295a1f7 171 /**
ram54288 0:a2cb7295a1f7 172 * Checks if data can be written
ram54288 0:a2cb7295a1f7 173 */
ram54288 0:a2cb7295a1f7 174 bool writeable();
ram54288 0:a2cb7295a1f7 175
ram54288 0:a2cb7295a1f7 176 /**
ram54288 0:a2cb7295a1f7 177 * Attach a function to call whenever network state has changed
ram54288 0:a2cb7295a1f7 178 *
ram54288 0:a2cb7295a1f7 179 * @param func A pointer to a void function, or 0 to set as none
ram54288 0:a2cb7295a1f7 180 */
ram54288 0:a2cb7295a1f7 181 void attach(Callback<void()> func);
ram54288 0:a2cb7295a1f7 182
ram54288 0:a2cb7295a1f7 183 /**
ram54288 0:a2cb7295a1f7 184 * Attach a function to call whenever network state has changed
ram54288 0:a2cb7295a1f7 185 *
ram54288 0:a2cb7295a1f7 186 * @param obj pointer to the object to call the member function on
ram54288 0:a2cb7295a1f7 187 * @param method pointer to the member function to call
ram54288 0:a2cb7295a1f7 188 */
ram54288 0:a2cb7295a1f7 189 template <typename T, typename M>
ram54288 0:a2cb7295a1f7 190 void attach(T *obj, M method) {
ram54288 0:a2cb7295a1f7 191 attach(Callback<void()>(obj, method));
ram54288 0:a2cb7295a1f7 192 }
ram54288 0:a2cb7295a1f7 193
ram54288 0:a2cb7295a1f7 194 private:
ram54288 0:a2cb7295a1f7 195 BufferedSerial _serial;
ram54288 0:a2cb7295a1f7 196 ATParser _parser;
ram54288 0:a2cb7295a1f7 197
ram54288 0:a2cb7295a1f7 198 struct packet {
ram54288 0:a2cb7295a1f7 199 struct packet *next;
ram54288 0:a2cb7295a1f7 200 int id;
ram54288 0:a2cb7295a1f7 201 uint32_t len;
ram54288 0:a2cb7295a1f7 202 // data follows
ram54288 0:a2cb7295a1f7 203 } *_packets, **_packets_end;
ram54288 0:a2cb7295a1f7 204 void _packet_handler();
ram54288 0:a2cb7295a1f7 205 bool recv_ap(nsapi_wifi_ap_t *ap);
ram54288 0:a2cb7295a1f7 206
ram54288 0:a2cb7295a1f7 207 char _ip_buffer[16];
ram54288 0:a2cb7295a1f7 208 char _gateway_buffer[16];
ram54288 0:a2cb7295a1f7 209 char _netmask_buffer[16];
ram54288 0:a2cb7295a1f7 210 char _mac_buffer[18];
ram54288 0:a2cb7295a1f7 211 };
ram54288 0:a2cb7295a1f7 212
ram54288 0:a2cb7295a1f7 213 #endif