Demo program for LSM303 based boards
Dependencies: mbed AES BLE_API nRF51822 smallAES
Revision 8:682b575fd7b3, committed 2020-11-02
- Comitter:
- f3d
- Date:
- Mon Nov 02 08:48:54 2020 +0000
- Parent:
- 6:0038b9f778a5
- Commit message:
- First commit
Changed in this revision
| BLEservice.h | Show annotated file Show diff for this revision Revisions of this file |
| main.cpp | Show annotated file Show diff for this revision Revisions of this file |
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/BLEservice.h Mon Nov 02 08:48:54 2020 +0000
@@ -0,0 +1,72 @@
+//BLEservice.h
+#ifndef __BLESERVICE_H
+#define __BLESERVICE_H
+#define MAX_CHARACTERISTICS 16
+extern Serial pc;
+typedef void (*fptr)(void);
+
+class BLEservice {
+public:
+ uint16_t Service_UUID;
+ uint32_t Characteristic_Count;
+ uint16_t Characteristic_UUID_Array[MAX_CHARACTERISTICS]; // This will contain the list of characterisic UUID's
+ BLEservice(BLEDevice &_ble,uint16_t Service_UUID,uint32_t Characteristic_Count, uint16_t *Characteristic_UUID_Array, fptr init, fptr poll,int Notify=0): ble(_ble)
+ {
+
+ pc.printf("Entering constructor\r\n");
+ this->Service_UUID = Service_UUID;
+ this->Characteristic_Count = Characteristic_Count;
+ pc.printf("Array of %d chars created\r\n",Characteristic_Count);
+ for (int i=0;i<Characteristic_Count;i++)
+ {
+ pc.printf("UUID %d = %d\r\n",i,Characteristic_UUID_Array[i]);
+ printf("Address of Characteristic_UUID_Array = %p\r\n",this->Characteristic_UUID_Array);
+ this->Characteristic_UUID_Array[i]=Characteristic_UUID_Array[i];
+ }
+ pc.printf("chars copied\r\n");
+ this->init = init;
+ this->poll = poll;
+ Value = 0;
+ GattCharacteristic *charTable[MAX_CHARACTERISTICS];
+ for (int i=0; i < Characteristic_Count; i++)
+ {
+ if (Notify == 1)
+ {
+ Characteristics[i] = new ReadWriteGattCharacteristic<uint16_t>(this->Characteristic_UUID_Array[i],&Value,GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_NOTIFY);
+ }
+ else
+ {
+ Characteristics[i] = new ReadWriteGattCharacteristic<uint16_t>(this->Characteristic_UUID_Array[i],&Value);
+ }
+ charTable[i] = Characteristics[i];
+ printf("Characteristic %d added\r\n",this->Characteristic_UUID_Array[i]);
+ }
+ GattService Service(this->Service_UUID, charTable, Characteristic_Count);
+ pc.printf("Service created\r\n");
+ ble.addService(Service);
+ pc.printf("Service added\r\n");
+ }
+ ~BLEservice()
+ {
+
+ }
+ fptr init;
+ fptr poll;
+ uint16_t readCharacteristic(uint16_t index)
+ {
+ uint16_t Value,Len;
+ Len = sizeof(Value);
+ ble.gattServer().read(this->Characteristics[index]->getValueHandle(),(uint8_t *)&Value,&Len);
+ return Value;
+ }
+ void writeCharacteristic(uint16_t index, uint16_t Value)
+ {
+ pc.printf("Writing %d to handle %d\r\n",Value,this->Characteristics[index]->getValueHandle());
+
+ ble.gattServer().write(this->Characteristics[index]->getValueHandle(),(uint8_t *)&Value,sizeof(uint16_t));
+ }
+ BLEDevice &ble; // Keep track of the Bluetoot device we are attached to.
+ ReadWriteGattCharacteristic<uint16_t> * Characteristics[MAX_CHARACTERISTICS];
+ uint16_t Value;
+};
+#endif
--- a/main.cpp Sun Oct 04 17:28:24 2020 +0000
+++ b/main.cpp Mon Nov 02 08:48:54 2020 +0000
@@ -16,12 +16,224 @@
#include "mbed.h"
#include "ble/BLE.h"
+#include "BLEservice.h"
+void bleInitComplete(BLE::InitializationCompleteCallbackContext *params);
+void onBleInitError(BLE &ble, ble_error_t error);
+void disconnectionCallback(const Gap::DisconnectionCallbackParams_t *params);
+Ticker ticker;
+Serial pc(P0_24, P0_25);
-int main(void)
+const static char DEVICE_NAME[] = "Test2020";
+#define LED_SERVICE 0xA000
+#define BTN_SERVICE 0x1eee
+#define ACCEL_SERVICE 0xA012
+#define TEMP_SERVICE 0xA022
+static const uint16_t uuid16_list[] = {LED_SERVICE,BTN_SERVICE,ACCEL_SERVICE,TEMP_SERVICE};
+BLEservice * LED;
+BLEservice * Button;
+BLEservice *Accel;
+BLEservice *Temp;
+const int LSM303_MAG_ADDRESS=(0x1e << 1);
+DigitalOut col1(P0_4, 0);
+DigitalOut alivenessLED(P0_13, 0);
+DigitalOut actuatedLED(P0_14, 0);
+I2C i2c(P0_30, P0_0); // SDA is on P0_30, SCL is on P0_0
+const int LSM303_ACCEL_ADDRESS = (0x19<<1);
+void initTemp()
+{
+ //init code for temp sensor
+ char Data[8]; // Declare a buffer for data transfer
+ int Status;
+
+ Data[0] =0x1f;
+ Data[1] = 0b11000000;
+ i2c.write(LSM303_ACCEL_ADDRESS,Data,2);
+
+ Data[0] = 0x23;
+ Data[1] = 0b10000000;
+ i2c.write(LSM303_ACCEL_ADDRESS,Data,2);
+
+}
+void pollTemp()
+{
+ char Data[8]; // Declare a buffer for data transfer
+ int Status;
+ int16_t T;
+
+ Data[0]=0x80+ 0x0c; // Register number 0x28 has the X data (2 bytes)
+ Status = i2c.write(LSM303_ACCEL_ADDRESS,Data,1,true); // Write register number
+ Status = i2c.read(LSM303_ACCEL_ADDRESS,Data,2); // Read register contents
+ T = Data[1];
+ T = (T << 8) + Data[0];
+ T = T / 16;
+ T = (20 << 3) + T;
+ pc.printf("T=%d\r\n",T/4);
+ Temp->writeCharacteristic(0,T/4);
+}
+void initLED()
+{
+ actuatedLED = 0;
+}
+void pollLED()
+{
+ uint16_t Value;
+ Value = LED->readCharacteristic(0);
+ actuatedLED = Value;
+}
+DigitalIn ButtonA(P0_17);
+DigitalIn ButtonB(P0_26);
+void initButton()
{
+}
+void pollButton()
+{
+ uint16_t ValueA = ButtonA;
+ pc.printf("Button A = %d\r\n",ValueA);
+ Button->writeCharacteristic(0,ValueA);
+ uint16_t ValueB = ButtonB;
+ pc.printf("Button B = %d\r\n",ValueB);
+ Button->writeCharacteristic(1,ValueB);
+}
+
+
+
+void initAccel()
+{
+ // Wake the accelerometer from sleep mode by writing disabling low power mode, setting freq to 10Hz and enabling all three axes
+ char Data[8]; // Declare a buffer for data transfer
+ int Status;
+ Data[0]=0x20; // wake up LSM303 (max speed, all accel channels)
+ Data[1]=0x77;
+ Status = i2c.write(LSM303_ACCEL_ADDRESS,Data,2); // Write data to register
+
+ Data[0]=0x23; // enable high resolution mode
+ Data[1]=0x0e;
+ Status = i2c.write(LSM303_ACCEL_ADDRESS,Data,2); // Write data to register
+
+}
+void pollAccel()
+{
+ char Data[8]; // Declare a buffer for data transfer
+ int Status;
+ int16_t X;
+ Data[0]=0x80 + 0x28; // Register number 0x28 has the X data (2 bytes)
+ Status = i2c.write(LSM303_ACCEL_ADDRESS,Data,1,true); // Write register number
+ Status = i2c.read(LSM303_ACCEL_ADDRESS,Data,2); // Read register contents
+ X = Data[1];
+ X = (X << 8) + Data[0];
+
+ int16_t Y;
+ Data[0]=0x80 + 0x2a; // Register number 0x2a has the Y data (2 bytes)
+ Status = i2c.write(LSM303_ACCEL_ADDRESS,Data,1,true); // Write register number
+ Status = i2c.read(LSM303_ACCEL_ADDRESS,Data,2); // Read register contents
+ Y = Data[1];
+ Y = (Y << 8) + Data[0];
+
+ int16_t Z;
+ Data[0]=0x80 + 0x2c; // Register number 0x2c has the Z data (2 bytes)
+ Status = i2c.write(LSM303_ACCEL_ADDRESS,Data,1,true); // Write register number
+ Status = i2c.read(LSM303_ACCEL_ADDRESS,Data,2); // Read register contents
+ Z = Data[1];
+ Z = (Z << 8) + Data[0];
+ pc.printf("X : %d , Y %d , Z %d \r\n",X,Y,Z);
+ Accel->writeCharacteristic(0,X);
+ Accel->writeCharacteristic(1,Y);
+ Accel->writeCharacteristic(2,Z);
+}
+void onDataWrittenCallback(const GattWriteCallbackParams *params)
+{
+ pc.printf("Got writeback for %d\r\n",params->handle);
+}
+void tick()
+{
+}
+void pollIO()
+{
+ pc.printf("Poll\r\n");
+ LED->poll();
+ Button->poll();
+ Accel->poll();
+ Temp->poll();
+}
+int main(void)
+{
+ BLE &ble = BLE::Instance();
+ ble.init(bleInitComplete);
+ /* SpinWait for initialization to complete. This is necessary because the
+ * BLE object is used in the main loop below. */
+ while (ble.hasInitialized() == false) { /* spin loop */ }
+
+ pc.printf("BLE init complete\r\n");
+
+ uint16_t LED_char_array[]={0xabcd};
+ pc.printf("Creating LED Service\r\n");
+ LED = new BLEservice(ble,LED_SERVICE,1,LED_char_array,initLED,pollLED);
+ LED->init();
+ pc.printf("LED service ready\r\n");
+
+ uint16_t Button_char_array[]={0x2021,0x2022};
+ pc.printf("Creating Button Service\r\n");
+ Button = new BLEservice(ble,BTN_SERVICE,2,Button_char_array,initButton,pollButton,1);
+ Button->init();
+ pc.printf("Button service ready\r\n");
+
+ uint16_t Accel_char_array[]={0xA013,0xA014,0xA015};
+ pc.printf("Creating Accel Service\r\n");
+ Accel = new BLEservice(ble,ACCEL_SERVICE,3,Accel_char_array,initAccel,pollAccel);
+ Accel->init();
+ pc.printf("Accel service ready\r\n");
+
+ uint16_t Temp_char_array[]={0xf00d};
+ pc.printf("Creating Temp Service\r\n");
+ Temp = new BLEservice(ble,TEMP_SERVICE,1,Temp_char_array,initTemp,pollTemp);
+ Temp->init();
+ pc.printf("Temp service ready\r\n");
+
+ ticker.attach(tick, 1); /* wake from sleep every 100ms */
while (1)
- {
+ { pollIO();
+ ble.waitForEvent();
}
}
+void bleInitComplete(BLE::InitializationCompleteCallbackContext *params)
+{
+ BLE& ble = params->ble;
+ ble_error_t error = params->error;
+
+ if (error != BLE_ERROR_NONE) {
+ /* In case of error, forward the error handling to onBleInitError */
+ onBleInitError(ble, error);
+ return;
+ }
+
+ /* Ensure that it is the default instance of BLE */
+ if(ble.getInstanceID() != BLE::DEFAULT_INSTANCE) {
+ return;
+ }
+
+ ble.gap().onDisconnection(disconnectionCallback);
+ ble.gattServer().onDataWritten(onDataWrittenCallback);
+ // ble.gattServer().onDataRead(onDataReadCallback); // Nordic Soft device will not call this so have to poll instead
+
+
+ /* setup advertising */
+ ble.gap().accumulateAdvertisingPayload(GapAdvertisingData::BREDR_NOT_SUPPORTED | GapAdvertisingData::LE_GENERAL_DISCOVERABLE);
+ ble.gap().accumulateAdvertisingPayload(GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS, (uint8_t *)uuid16_list, sizeof(uuid16_list));
+ ble.gap().accumulateAdvertisingPayload(GapAdvertisingData::COMPLETE_LOCAL_NAME, (uint8_t *)DEVICE_NAME, sizeof(DEVICE_NAME));
+ ble.gap().setAdvertisingType(GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED);
+ ble.gap().setAdvertisingInterval(500); /* 500ms. */
+ pc.printf("Starting advertising\r\n");
+ ble.gap().startAdvertising();
+}
+void onBleInitError(BLE &ble, ble_error_t error)
+{
+ /* Initialization error handling should go here */
+ pc.printf("BLE init error\r\n");
+}
+void disconnectionCallback(const Gap::DisconnectionCallbackParams_t *params)
+{
+ pc.printf("Disconnected, restarting advertising\r\n");
+ BLE::Instance().gap().startAdvertising();
+}