Program that uses the QuickStart Library to interface a SmartMesh IP mote: Connects to the default network and starts publishing a random walk value every 5 seconds.
Fork of QSL_SimplePublish by
QSL SimplePublish
SmartMesh IP QuickStart Library
- GitHub repository
- Current release used: REL-1.0.2.2
- Documentation
- Discussion
dn_qsl_api.h@0:d3f5fdf2e6da, 2016-09-01 (annotated)
- Committer:
- jhbr
- Date:
- Thu Sep 01 14:53:55 2016 +0000
- Revision:
- 0:d3f5fdf2e6da
Initial commit of working example
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
jhbr | 0:d3f5fdf2e6da | 1 | /* |
jhbr | 0:d3f5fdf2e6da | 2 | Copyright (c) 2016, Dust Networks. All rights reserved. |
jhbr | 0:d3f5fdf2e6da | 3 | |
jhbr | 0:d3f5fdf2e6da | 4 | QuickStart Library API. |
jhbr | 0:d3f5fdf2e6da | 5 | |
jhbr | 0:d3f5fdf2e6da | 6 | \license See attached DN_LICENSE.txt. |
jhbr | 0:d3f5fdf2e6da | 7 | */ |
jhbr | 0:d3f5fdf2e6da | 8 | |
jhbr | 0:d3f5fdf2e6da | 9 | #ifndef DN_QSL_API_H |
jhbr | 0:d3f5fdf2e6da | 10 | #define DN_QSL_API_H |
jhbr | 0:d3f5fdf2e6da | 11 | |
jhbr | 0:d3f5fdf2e6da | 12 | #include "dn_common.h" |
jhbr | 0:d3f5fdf2e6da | 13 | #include "dn_defaults.h" |
jhbr | 0:d3f5fdf2e6da | 14 | |
jhbr | 0:d3f5fdf2e6da | 15 | //=========================== defines ========================================= |
jhbr | 0:d3f5fdf2e6da | 16 | |
jhbr | 0:d3f5fdf2e6da | 17 | #define DN_DEST_IP DN_DEFAULT_DEST_IP |
jhbr | 0:d3f5fdf2e6da | 18 | |
jhbr | 0:d3f5fdf2e6da | 19 | //=========================== typedef ========================================= |
jhbr | 0:d3f5fdf2e6da | 20 | |
jhbr | 0:d3f5fdf2e6da | 21 | //=========================== variables ======================================= |
jhbr | 0:d3f5fdf2e6da | 22 | |
jhbr | 0:d3f5fdf2e6da | 23 | //=========================== prototypes ====================================== |
jhbr | 0:d3f5fdf2e6da | 24 | |
jhbr | 0:d3f5fdf2e6da | 25 | #ifdef __cplusplus |
jhbr | 0:d3f5fdf2e6da | 26 | extern "C" { |
jhbr | 0:d3f5fdf2e6da | 27 | #endif |
jhbr | 0:d3f5fdf2e6da | 28 | |
jhbr | 0:d3f5fdf2e6da | 29 | //===== init |
jhbr | 0:d3f5fdf2e6da | 30 | |
jhbr | 0:d3f5fdf2e6da | 31 | /** |
jhbr | 0:d3f5fdf2e6da | 32 | \brief Initialize the necessary structures and underlying C Library. |
jhbr | 0:d3f5fdf2e6da | 33 | |
jhbr | 0:d3f5fdf2e6da | 34 | Has to be run once before any of the other functions below is run. |
jhbr | 0:d3f5fdf2e6da | 35 | |
jhbr | 0:d3f5fdf2e6da | 36 | \return A boolean indicating the success of the initialization. |
jhbr | 0:d3f5fdf2e6da | 37 | */ |
jhbr | 0:d3f5fdf2e6da | 38 | bool dn_qsl_init(void); |
jhbr | 0:d3f5fdf2e6da | 39 | |
jhbr | 0:d3f5fdf2e6da | 40 | |
jhbr | 0:d3f5fdf2e6da | 41 | //===== isConnected |
jhbr | 0:d3f5fdf2e6da | 42 | |
jhbr | 0:d3f5fdf2e6da | 43 | /** |
jhbr | 0:d3f5fdf2e6da | 44 | \brief Return TRUE if the mote is connected to a network. |
jhbr | 0:d3f5fdf2e6da | 45 | |
jhbr | 0:d3f5fdf2e6da | 46 | Simply checks if the FSM is in the CONNECTED state. |
jhbr | 0:d3f5fdf2e6da | 47 | |
jhbr | 0:d3f5fdf2e6da | 48 | \return A boolean indicating if the mote is connected to a network. |
jhbr | 0:d3f5fdf2e6da | 49 | */ |
jhbr | 0:d3f5fdf2e6da | 50 | bool dn_qsl_isConnected(void); |
jhbr | 0:d3f5fdf2e6da | 51 | |
jhbr | 0:d3f5fdf2e6da | 52 | |
jhbr | 0:d3f5fdf2e6da | 53 | //===== connect |
jhbr | 0:d3f5fdf2e6da | 54 | |
jhbr | 0:d3f5fdf2e6da | 55 | /** |
jhbr | 0:d3f5fdf2e6da | 56 | \brief Attempt to make the mote connect to a network with the given parameters. |
jhbr | 0:d3f5fdf2e6da | 57 | |
jhbr | 0:d3f5fdf2e6da | 58 | If the passed network ID, join key or source port is zero/NULL, default values |
jhbr | 0:d3f5fdf2e6da | 59 | are used. If non-zero, the passed service will be requested after joining a |
jhbr | 0:d3f5fdf2e6da | 60 | network. A new service can be requested later by calling connect again with the |
jhbr | 0:d3f5fdf2e6da | 61 | same network ID, join key and source port. Further, if the requested service is |
jhbr | 0:d3f5fdf2e6da | 62 | also indifferent, the function simply returns TRUE. |
jhbr | 0:d3f5fdf2e6da | 63 | |
jhbr | 0:d3f5fdf2e6da | 64 | \param netID The ID of the network to attempt to connect with. |
jhbr | 0:d3f5fdf2e6da | 65 | \param joinKey The join key to use in the connection attempt. |
jhbr | 0:d3f5fdf2e6da | 66 | \param srcPort The port that you expect to get downstream data on. |
jhbr | 0:d3f5fdf2e6da | 67 | \param service_ms The service to request after establishing a connection, given in milliseconds. |
jhbr | 0:d3f5fdf2e6da | 68 | \return A boolean indicating if the connection attempt and/or service request was successful. |
jhbr | 0:d3f5fdf2e6da | 69 | */ |
jhbr | 0:d3f5fdf2e6da | 70 | bool dn_qsl_connect(uint16_t netID, const uint8_t* joinKey, uint16_t srcPort, uint32_t service_ms); |
jhbr | 0:d3f5fdf2e6da | 71 | |
jhbr | 0:d3f5fdf2e6da | 72 | |
jhbr | 0:d3f5fdf2e6da | 73 | //===== send |
jhbr | 0:d3f5fdf2e6da | 74 | |
jhbr | 0:d3f5fdf2e6da | 75 | /** |
jhbr | 0:d3f5fdf2e6da | 76 | \brief Send a packet into the network. |
jhbr | 0:d3f5fdf2e6da | 77 | |
jhbr | 0:d3f5fdf2e6da | 78 | Tells the mote send a packet with the given payload into the network. |
jhbr | 0:d3f5fdf2e6da | 79 | Said packet is sent to the provided destination port (default if 0) and the |
jhbr | 0:d3f5fdf2e6da | 80 | IPv6 address defined by DEST_IP (default is the well-known manager address). |
jhbr | 0:d3f5fdf2e6da | 81 | The FSM waits for a confirmation from the mote that the packet was accepted |
jhbr | 0:d3f5fdf2e6da | 82 | and queued up for transmission. Note that end-to-end delivery is not |
jhbr | 0:d3f5fdf2e6da | 83 | guaranteed with the utilized UDP, but reliability is typically > 99.9 %. |
jhbr | 0:d3f5fdf2e6da | 84 | |
jhbr | 0:d3f5fdf2e6da | 85 | \param payload Pointer to a byte array containing the payload. |
jhbr | 0:d3f5fdf2e6da | 86 | \param payloadSize_B Byte size of the payload. |
jhbr | 0:d3f5fdf2e6da | 87 | \param destPort The destination port for the packet. |
jhbr | 0:d3f5fdf2e6da | 88 | \return A boolean indicating if the packet was queued up for transmission. |
jhbr | 0:d3f5fdf2e6da | 89 | */ |
jhbr | 0:d3f5fdf2e6da | 90 | bool dn_qsl_send(const uint8_t* payload, uint8_t payloadSize_B, uint16_t destPort); |
jhbr | 0:d3f5fdf2e6da | 91 | |
jhbr | 0:d3f5fdf2e6da | 92 | |
jhbr | 0:d3f5fdf2e6da | 93 | //===== read |
jhbr | 0:d3f5fdf2e6da | 94 | |
jhbr | 0:d3f5fdf2e6da | 95 | /** |
jhbr | 0:d3f5fdf2e6da | 96 | \brief Read the FIFO buffered inbox of downstream messages. |
jhbr | 0:d3f5fdf2e6da | 97 | |
jhbr | 0:d3f5fdf2e6da | 98 | As the payload of downstream messages are pushed into a buffered FIFO inbox, |
jhbr | 0:d3f5fdf2e6da | 99 | calling this function will pop the first one (oldest) stored into the provided |
jhbr | 0:d3f5fdf2e6da | 100 | buffer and return the byte size. An empty inbox will simply return 0. |
jhbr | 0:d3f5fdf2e6da | 101 | |
jhbr | 0:d3f5fdf2e6da | 102 | \param readBuffer Pointer to a byte array to store the read message payload. |
jhbr | 0:d3f5fdf2e6da | 103 | \return The number of bytes read into the provided buffer. |
jhbr | 0:d3f5fdf2e6da | 104 | */ |
jhbr | 0:d3f5fdf2e6da | 105 | uint8_t dn_qsl_read(uint8_t* readBuffer); |
jhbr | 0:d3f5fdf2e6da | 106 | |
jhbr | 0:d3f5fdf2e6da | 107 | #ifdef __cplusplus |
jhbr | 0:d3f5fdf2e6da | 108 | } |
jhbr | 0:d3f5fdf2e6da | 109 | #endif |
jhbr | 0:d3f5fdf2e6da | 110 | |
jhbr | 0:d3f5fdf2e6da | 111 | #endif |