Demo application for using the AT&T IoT Starter Kit Powered by AWS.
Dependencies: SDFileSystem
Fork of ATT_AWS_IoT_demo by
IoT Starter Kit Powered by AWS Demo
This program demonstrates the AT&T IoT Starter Kit sending data directly into AWS IoT. It's explained and used in the Getting Started with the IoT Starter Kit Powered by AWS on starterkit.att.com.
What's required
- AT&T IoT LTE Add-on (also known as the Cellular Shield)
- NXP K64F - for programming
- microSD card - used to store your AWS security credentials
- AWS account
- Python, locally installed
If you don't already have an IoT Starter Kit, you can purchase a kit here. The IoT Starter Kit Powered by AWS includes the LTE cellular shield, K64F, and a microSD card.
Diff: WNCInterface/WncControllerK64F/MODSERIAL/MODSERIAL.cpp
- Revision:
- 15:6f2798e45099
diff -r 339320b096c5 -r 6f2798e45099 WNCInterface/WncControllerK64F/MODSERIAL/MODSERIAL.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/WNCInterface/WncControllerK64F/MODSERIAL/MODSERIAL.cpp Thu Dec 01 18:05:38 2016 +0000 @@ -0,0 +1,123 @@ +/* + Copyright (c) 2010 Andy Kirkham + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in + all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + THE SOFTWARE. + + @file MODSERIAL.h + @purpose Extends Serial to provide fully buffered IO + @version 1.6 + @date Nov 2010 + @author Andy Kirkham +*/ + +#include "MODSERIAL.h" +#include "MACROS.h" + +namespace AjK { + +MODSERIAL::MODSERIAL( PinName tx, PinName rx, const char* name ) : Serial( tx, rx, name ) +{ + init( MODSERIAL_DEFAULT_TX_BUFFER_SIZE, MODSERIAL_DEFAULT_RX_BUFFER_SIZE, rx ); +} + +MODSERIAL::MODSERIAL( PinName tx, PinName rx, int bufferSize, const char* name ) : Serial( tx, rx, name ) +{ + init( bufferSize, bufferSize, rx ); +} + +MODSERIAL::MODSERIAL( PinName tx, PinName rx, int txSize, int rxSize, const char* name ) : Serial( tx, rx, name ) +{ + init( txSize, rxSize, rx ); +} + +MODSERIAL::~MODSERIAL() +{ + NVIC_DisableIRQ(_IRQ); + if ( buffer[0] != NULL) free((char *)buffer[0] ); + if ( buffer[1] != NULL) free((char *)buffer[1] ); +} + +bool MODSERIAL::txBufferFull( void ) +{ + return MODSERIAL_TX_BUFFER_FULL; +} + +bool MODSERIAL::rxBufferFull( void ) +{ + return MODSERIAL_RX_BUFFER_FULL; +} + +bool MODSERIAL::txBufferEmpty( void ) +{ + return MODSERIAL_TX_BUFFER_EMPTY; +} + +bool MODSERIAL::rxBufferEmpty( void ) +{ + return MODSERIAL_RX_BUFFER_EMPTY; +} + + +int MODSERIAL::rxDiscardLastChar( void ) +{ + // This function can only be called indirectly from + // an rxCallback function. Therefore, we know we + // just placed a char into the buffer. + char c = buffer[RxIrq][buffer_in[RxIrq]]; + + if (buffer_count[RxIrq]) { + buffer_count[RxIrq]--; + buffer_in[RxIrq]--; + if (buffer_in[RxIrq] < 0) { + buffer_in[RxIrq] = buffer_size[RxIrq] - 1; + } + } + + return (int)c; +} + + +bool MODSERIAL::claim (FILE *stream) { +#if 0 + if ( _name == NULL) { + error("claim requires a name to be given in the instantiator of the MODSERIAL instance!\r\n"); + } + + //Add '/' before name: + char *path = new char[strlen(_name) + 2]; + sprintf(path, "/%s", _name); + + if (freopen(path, "w", stream) == NULL) { + // Failed, should not happen + return false; + } + + delete(path); + + //No buffering + setvbuf(stdout, NULL, _IONBF, buffer_size[TxIrq]); +#endif + + return true; +} + + + +}; // namespace AjK ends +