Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: BLE_API mbed nRF51822 nRF51_Vdd
Fork of BLE_Temp_Vdd_via_UART by
Diff: main.cpp
- Revision:
- 10:38852d243fb2
- Parent:
- 9:5f0732aa3008
- Child:
- 11:da2dc9a847a8
--- a/main.cpp Tue Sep 29 12:12:10 2015 +0000 +++ b/main.cpp Sun Jan 24 04:21:09 2016 +0000 @@ -14,62 +14,122 @@ * limitations under the License. */ +/* + * January 6th, 2016 Modified by Kenji Arai + * January 24th, 2016 + * http://www.page.sannet.ne.jp/kenjia/index.html + * http://mbed.org/users/kenjiArai/ + * + * Original: + * 1) BLE_UARTConsole + * https://developer.mbed.org/teams/Bluetooth-Low-Energy/code/BLE_UARTConsole/ + * 2) BLE_HTM_by_InTempSensr_pub + * https://developer.mbed.org/users/takafuminaka/code/BLE_HTM_by_InTempSensr_pub/ + * Tanks Takafumi Naka san! + * Tested Controller Device: + * iPhone6 UART application in nRF Toolbox + * https://itunes.apple.com/jp/app/nrf-toolbox/id820906058?mt=8 + * Please check data on "Show log" screen + */ + +// Include --------------------------------------------------------------------------------------- #include <string.h> #include "mbed.h" #include "BLE.h" +#include "UARTService.h" +#include "nrf_soc.h" // for internal Thermo sensoer +#include "nRF51_Vdd.h" // Read nRF51 Vdd voltage -#include "UARTService.h" +// Definition ------------------------------------------------------------------------------------ -#define NEED_CONSOLE_OUTPUT 1 /* Set this if you need debug messages on the console; - * it will have an impact on code-size and power consumption. */ +// Object ---------------------------------------------------------------------------------------- +BLE ble; +UARTService *uart; +nRF51_Vdd vdd(3.6f, 2.6f); + +// RAM ------------------------------------------------------------------------------------------- +static volatile bool triggerSensorPolling = false; -#if NEED_CONSOLE_OUTPUT -#define DEBUG(STR) { if (uart) uart->write(STR, strlen(STR)); } -#else -#define DEBUG(...) /* nothing */ -#endif /* #if NEED_CONSOLE_OUTPUT */ +// ROM / Constant data --------------------------------------------------------------------------- +const char *deviceName = "mbedBLE"; + +// Function prototypes --------------------------------------------------------------------------- +void Update_Values(void); -BLEDevice ble; -DigitalOut led1(LED1); -UARTService *uart; - -void disconnectionCallback(const Gap::DisconnectionCallbackParams_t *params) -{ - DEBUG("Disconnected!\n\r"); - DEBUG("Restarting the advertising process\n\r"); +//------------------------------------------------------------------------------------------------- +// Control Program +//------------------------------------------------------------------------------------------------- +void disconnectionCallback(const Gap::DisconnectionCallbackParams_t *params){ + if (uart){ + uart->writeString("Disconnected!\r\n"); + uart->writeString("Restarting the advertising process\r\n"); + } ble.startAdvertising(); } -void periodicCallback(void) -{ - led1 = !led1; - DEBUG("ping\r\n"); +void periodicCallback(void){ + triggerSensorPolling = true; } -int main(void) -{ - led1 = 1; +int main(void){ + // Set priodic interrupt Ticker ticker; - ticker.attach(periodicCallback, 1); - - DEBUG("Initialising the nRF51822\n\r"); + ticker.attach(periodicCallback, 5); + // Opening screen + printf("\r\nInitialising the nRF51822\r\n"); + printf("Temperature and CPU Vdd voltage via UART service\r\n"); + // setup BLE ble.init(); + ble.setDeviceName((const uint8_t *)deviceName); ble.onDisconnection(disconnectionCallback); - + // BLE Uart uart = new UARTService(ble); - - /* setup advertising */ + // setup advertising ble.accumulateAdvertisingPayload(GapAdvertisingData::BREDR_NOT_SUPPORTED); ble.setAdvertisingType(GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED); ble.accumulateAdvertisingPayload(GapAdvertisingData::SHORTENED_LOCAL_NAME, - (const uint8_t *)"BLE UART", sizeof("BLE UART") - 1); + (const uint8_t *)deviceName, + strlen(deviceName)); ble.accumulateAdvertisingPayload(GapAdvertisingData::COMPLETE_LIST_128BIT_SERVICE_IDS, - (const uint8_t *)UARTServiceUUID_reversed, sizeof(UARTServiceUUID_reversed)); - + (const uint8_t *)UARTServiceUUID_reversed, + sizeof(UARTServiceUUID_reversed)); ble.setAdvertisingInterval(160); /* 100ms; in multiples of 0.625ms. */ ble.startAdvertising(); - - while (true) { - ble.waitForEvent(); + while (true){ + if (triggerSensorPolling){ + triggerSensorPolling = false; + Update_Values(); + } else { + ble.waitForEvent(); + } } } + +void Update_Values(void){ + char buf[32]; + int32_t p_temp; + float temperature; + + // Update a temperature (inside nRF51822 chip) + sd_temp_get(&p_temp); + temperature = float(p_temp)/4.0f - 16.0f; + // 12 89 + sprintf(buf,"T:%+4.1fdC", temperature); + if (uart){ + uart->writeString(buf); + } + printf(buf); + // Update a Vdd voltage + // 01234 9 + sprintf(buf,",Vdd:%3.2fV ", vdd.read_real_value()); + if (uart){ + uart->writeString(buf); + } + printf(buf); + // 123456789 0 + sprintf(buf,"Charge:%d%% \r\n", vdd.read()); + if (uart){ + uart->writeString(buf); + } + printf(buf); +}