A multifunctional and modular Firmware for Multitech's mDot based on ARM mBed provides a widerange of functionality for several Sensors such as MAX44009, BME280, MPU9250, SI1143 and uBlox. It allows you to quickly build a Sensornode that measures specific data with its sensors and sends it via LoRaWAN.

Dependencies:   mDot_LoRa_Sensornode_Flowmeter_impl mbed-rtos mbed

LoRa-Sensornode Firmware for Multitech mDot

A multifunctional and modular Firmware for Multitech's mDot which provides a widerange of functionality for several Sensors. It allows you to quickly build a Sensornode that measures specific data with its sensors and sends it via LoRaWAN.

/media/uploads/mitea1/logo-lora-600x370.png /media/uploads/mitea1/mt_mdot_family_642px.png

Supported Sensors

Idea

The Firmware has some predefined Application Modes running different Tasks(Measurements). Each mode can be used in a different Scenario. Application_Modes define which sensors are used, how often they aquire data and how often the data has to be sent via LoRa. Lets say you just want to measure the Light then you choose an Application_Mode (or define one) that only runs TaskLight for light measurement. As a standard all measurements are taken every second and sent via LoRa but you can change that interval depending on your usage Scenario

Revision:
0:f2815503561f
Child:
4:2674bd4168f8
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/app/TaskAcceleration.cpp	Wed Jul 06 20:40:36 2016 +0000
@@ -0,0 +1,97 @@
+/*
+ * TaskAcceleration.cpp
+ *
+ *  Created on: May 30, 2016
+ *      Author: Adrian
+ */
+
+#include "TaskAcceleration.h"
+
+TaskAcceleration::TaskAcceleration(MPU9250* mpu9250,Mutex* mutexI2C, Queue<MPU9250AccelerationMessage,ACCELERATION_QUEUE_LENGHT>* queue){
+	this->mpu9250 = mpu9250;
+	setPriority(osPriorityNormal);
+	setStackSize(DEFAULT_STACK_SIZE);
+	setStackPointer(NULL);
+	setMutex(mutexI2C);
+	setQueue(queue);
+}
+
+TaskAcceleration::TaskAcceleration(MPU9250* mpu9250,rtos::Mutex* mutexI2C,rtos::Queue<MPU9250AccelerationMessage,ACCELERATION_QUEUE_LENGHT>* queue,
+	osPriority priority, uint32_t stackSize, unsigned char *stackPointer){
+	this->mpu9250 = mpu9250;
+	setPriority(priority);
+	setStackSize(stackSize);
+	setStackPointer(stackPointer);
+	setMutex(mutexI2C);
+	setQueue(queue);
+	setState(SLEEPING);
+}
+
+TaskAcceleration::~TaskAcceleration() {
+	// TODO Auto-generated destructor stub
+}
+
+osStatus TaskAcceleration::start(){
+	setState(RUNNING);
+	this->thread = new rtos::Thread(callBack,this);
+}
+
+osStatus TaskAcceleration::stop(){
+	thread->terminate();
+	setState(SLEEPING);
+	delete this->thread;
+}
+
+void TaskAcceleration::callBack(void const* data){
+	// WOODHAMMER METHOD of Casting!
+	const TaskAcceleration* constInstance = static_cast<const TaskAcceleration* >(data);
+	TaskAcceleration* instance = const_cast<TaskAcceleration*>(constInstance);
+
+	instance->measureAcceleration();
+}
+
+void TaskAcceleration::measureAcceleration(){
+	MPU9250AccelerationMessage mpu9250AccelerationMessage;
+
+	while(true){
+		mutexI2C->lock(osWaitForever);
+		mpu9250AccelerationMessage.setXAcceleration(mpu9250->getXAxisAcceleration());
+		mpu9250AccelerationMessage.setYAcceleration(mpu9250->getYAxisAcceleration());
+		mpu9250AccelerationMessage.setZAcceleration(mpu9250->getZAxisAcceleration());
+		mutexI2C->unlock();
+
+		queue->put(&mpu9250AccelerationMessage,osWaitForever);
+		osDelay(ACCELERATION_TASK_DELAY_MS);
+	}
+
+
+}
+
+void TaskAcceleration::setQueue(Queue<MPU9250AccelerationMessage,ACCELERATION_QUEUE_LENGHT>* queue){
+	this->queue = queue;
+}
+
+void TaskAcceleration::setMutex(Mutex* mutex){
+	this->mutexI2C = mutex;
+}
+
+void TaskAcceleration::setPriority(osPriority priority){
+	this->priority = priority;
+}
+
+void TaskAcceleration::setStackSize(uint32_t stacksize){
+	this->stack_size = stacksize;
+}
+
+void TaskAcceleration::setStackPointer(unsigned char* stackPointer){
+	this->stack_pointer = stackPointer;
+}
+
+void TaskAcceleration::setState(TASK_STATE state){
+	this->state = state;
+}
+
+TASK_STATE TaskAcceleration::getState(){
+	return state;
+}
+