1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-18 03:52:11 +01:00

Add object to monitor the overo link status. Current just records the bytes/s

being sent and the connected status (based on sending more than 500 bytes per
second)
This commit is contained in:
James Cotton 2012-02-06 08:51:48 -06:00
parent 5b2376dbee
commit dbcb499d7f
4 changed files with 42 additions and 3 deletions

View File

@ -32,6 +32,7 @@
#include "openpilot.h" #include "openpilot.h"
#include "overosync.h" #include "overosync.h"
#include "overosyncstats.h"
// Private constants // Private constants
#define OVEROSYNC_PACKET_SIZE 256 #define OVEROSYNC_PACKET_SIZE 256
@ -68,6 +69,7 @@ struct overosync {
xSemaphoreHandle transaction_lock; xSemaphoreHandle transaction_lock;
xSemaphoreHandle buffer_lock; xSemaphoreHandle buffer_lock;
volatile bool transaction_done; volatile bool transaction_done;
uint32_t sent_bytes;
uint32_t write_pointer; uint32_t write_pointer;
uint32_t sent_objects; uint32_t sent_objects;
uint32_t failed_objects; uint32_t failed_objects;
@ -83,6 +85,11 @@ struct overosync *overosync;
*/ */
int32_t OveroSyncInitialize(void) int32_t OveroSyncInitialize(void)
{ {
if(pios_spi_overo_id == 0)
return -1;
OveroSyncStatsInitialize();
// Create object queues // Create object queues
queue = xQueueCreate(MAX_QUEUE_SIZE, sizeof(UAVObjEvent)); queue = xQueueCreate(MAX_QUEUE_SIZE, sizeof(UAVObjEvent));
@ -99,6 +106,9 @@ int32_t OveroSyncInitialize(void)
*/ */
int32_t OveroSyncStart(void) int32_t OveroSyncStart(void)
{ {
if(pios_spi_overo_id == 0)
return -1;
overosync = (struct overosync *) pvPortMalloc(sizeof(*overosync)); overosync = (struct overosync *) pvPortMalloc(sizeof(*overosync));
if(overosync == NULL) if(overosync == NULL)
return -1; return -1;
@ -114,13 +124,13 @@ int32_t OveroSyncStart(void)
overosync->active_transaction_id = 0; overosync->active_transaction_id = 0;
overosync->loading_transaction_id = 0; overosync->loading_transaction_id = 0;
overosync->write_pointer = 0; overosync->write_pointer = 0;
overosync->sent_bytes = 0;
// Process all registered objects and connect queue for updates // Process all registered objects and connect queue for updates
UAVObjIterate(&registerObject); UAVObjIterate(&registerObject);
// Start telemetry tasks // Start telemetry tasks
if(pios_spi_overo_id != 0) xTaskCreate(overoSyncTask, (signed char *)"OveroSync", STACK_SIZE_BYTES/4, NULL, TASK_PRIORITY, &overoSyncTaskHandle);
xTaskCreate(overoSyncTask, (signed char *)"OveroSync", STACK_SIZE_BYTES/4, NULL, TASK_PRIORITY, &overoSyncTaskHandle);
TaskMonitorAdd(TASKINFO_RUNNING_OVEROSYNC, overoSyncTaskHandle); TaskMonitorAdd(TASKINFO_RUNNING_OVEROSYNC, overoSyncTaskHandle);
@ -167,6 +177,9 @@ static void overoSyncTask(void *parameters)
transmitData(); transmitData();
portTickType lastUpdateTime = xTaskGetTickCount();
portTickType updateTime;
// Loop forever // Loop forever
while (1) { while (1) {
// Wait for queue message // Wait for queue message
@ -177,6 +190,17 @@ static void overoSyncTask(void *parameters)
//if(overosync->transaction_done) //if(overosync->transaction_done)
// transmitData(); // transmitData();
updateTime = xTaskGetTickCount();
if(((portTickType) (updateTime - lastUpdateTime)) > 1000) {
// Update stats. This will trigger a local send event too
OveroSyncStatsData syncStats;
syncStats.Send = overosync->sent_bytes;
syncStats.Connected = syncStats.Send > 500 ? OVEROSYNCSTATS_CONNECTED_TRUE : OVEROSYNCSTATS_CONNECTED_FALSE;
OveroSyncStatsSet(&syncStats);
overosync->sent_bytes = 0;
lastUpdateTime = updateTime;
}
overosync_transfers++; overosync_transfers++;
} }
} }
@ -233,7 +257,7 @@ static int32_t packData(uint8_t * data, int32_t length)
overosync->write_pointer; overosync->write_pointer;
memcpy(tx_buffer,data,length); memcpy(tx_buffer,data,length);
overosync->write_pointer += length; overosync->write_pointer += length;
overosync->sent_bytes += length;
overosync->sent_objects++; overosync->sent_objects++;
xSemaphoreGive(overosync->buffer_lock); xSemaphoreGive(overosync->buffer_lock);

View File

@ -55,6 +55,7 @@ UAVOBJSRCFILENAMES += mixersettings
UAVOBJSRCFILENAMES += mixerstatus UAVOBJSRCFILENAMES += mixerstatus
UAVOBJSRCFILENAMES += nedaccel UAVOBJSRCFILENAMES += nedaccel
UAVOBJSRCFILENAMES += objectpersistence UAVOBJSRCFILENAMES += objectpersistence
UAVOBJSRCFILENAMES += overosyncstats
UAVOBJSRCFILENAMES += positionactual UAVOBJSRCFILENAMES += positionactual
UAVOBJSRCFILENAMES += positiondesired UAVOBJSRCFILENAMES += positiondesired
UAVOBJSRCFILENAMES += ratedesired UAVOBJSRCFILENAMES += ratedesired

View File

@ -37,6 +37,7 @@ HEADERS += $$UAVOBJECT_SYNTHETICS/accessorydesired.h \
$$UAVOBJECT_SYNTHETICS/systemstats.h \ $$UAVOBJECT_SYNTHETICS/systemstats.h \
$$UAVOBJECT_SYNTHETICS/systemalarms.h \ $$UAVOBJECT_SYNTHETICS/systemalarms.h \
$$UAVOBJECT_SYNTHETICS/objectpersistence.h \ $$UAVOBJECT_SYNTHETICS/objectpersistence.h \
$$UAVOBJECT_SYNTHETICS/overosyncstats.h \
$$UAVOBJECT_SYNTHETICS/systemsettings.h \ $$UAVOBJECT_SYNTHETICS/systemsettings.h \
$$UAVOBJECT_SYNTHETICS/stabilizationsettings.h \ $$UAVOBJECT_SYNTHETICS/stabilizationsettings.h \
$$UAVOBJECT_SYNTHETICS/manualcontrolsettings.h \ $$UAVOBJECT_SYNTHETICS/manualcontrolsettings.h \
@ -90,6 +91,7 @@ SOURCES += $$UAVOBJECT_SYNTHETICS/accessorydesired.cpp \
$$UAVOBJECT_SYNTHETICS/systemstats.cpp \ $$UAVOBJECT_SYNTHETICS/systemstats.cpp \
$$UAVOBJECT_SYNTHETICS/systemalarms.cpp \ $$UAVOBJECT_SYNTHETICS/systemalarms.cpp \
$$UAVOBJECT_SYNTHETICS/objectpersistence.cpp \ $$UAVOBJECT_SYNTHETICS/objectpersistence.cpp \
$$UAVOBJECT_SYNTHETICS/overosyncstats.cpp \
$$UAVOBJECT_SYNTHETICS/systemsettings.cpp \ $$UAVOBJECT_SYNTHETICS/systemsettings.cpp \
$$UAVOBJECT_SYNTHETICS/stabilizationsettings.cpp \ $$UAVOBJECT_SYNTHETICS/stabilizationsettings.cpp \
$$UAVOBJECT_SYNTHETICS/manualcontrolsettings.cpp \ $$UAVOBJECT_SYNTHETICS/manualcontrolsettings.cpp \

View File

@ -0,0 +1,12 @@
<xml>
<object name="OveroSyncStats" singleinstance="true" settings="false">
<description>Maintains statistics on transfer rate to and from over</description>
<field name="Connected" units="" type="enum" options="False,True" elements="1" default="False"/>
<field name="Send" units="B/s" type="uint32" elements="1"/>
<field name="Received" units="B/s" type="uint32" elements="1"/>
<access gcs="readwrite" flight="readwrite"/>
<telemetrygcs acked="false" updatemode="manual" period="0"/>
<telemetryflight acked="false" updatemode="periodic" period="1000"/>
<logging updatemode="periodic" period="1000"/>
</object>
</xml>