mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-19 04:52:12 +01:00
OP-1289 Only create local telemetry queues/tasks if needed
This commit is contained in:
parent
91e03a1541
commit
32a25e7044
@ -157,36 +157,45 @@ static void updateSettings(channelContext *channel);
|
|||||||
*/
|
*/
|
||||||
int32_t TelemetryStart(void)
|
int32_t TelemetryStart(void)
|
||||||
{
|
{
|
||||||
UAVObjIterate(®isterLocalObject);
|
// Only start the local telemetry tasks if needed
|
||||||
|
if (localPort()) {
|
||||||
|
UAVObjIterate(®isterLocalObject);
|
||||||
|
|
||||||
|
// Listen to objects of interest
|
||||||
|
#ifdef PIOS_TELEM_PRIORITY_QUEUE
|
||||||
|
GCSTelemetryStatsConnectQueue(localChannel.priorityQueue);
|
||||||
|
#else /* PIOS_TELEM_PRIORITY_QUEUE */
|
||||||
|
GCSTelemetryStatsConnectQueue(localChannel.queue);
|
||||||
|
#endif /* PIOS_TELEM_PRIORITY_QUEUE */
|
||||||
|
// Start telemetry tasks
|
||||||
|
xTaskCreate(telemetryTxTask,
|
||||||
|
"TelTx",
|
||||||
|
STACK_SIZE_TX_BYTES / 4,
|
||||||
|
&localChannel,
|
||||||
|
TASK_PRIORITY_TX,
|
||||||
|
&localChannel.txTaskHandle);
|
||||||
|
PIOS_TASK_MONITOR_RegisterTask(TASKINFO_RUNNING_TELEMETRYTX,
|
||||||
|
localChannel.txTaskHandle);
|
||||||
|
xTaskCreate(telemetryRxTask,
|
||||||
|
"TelRx",
|
||||||
|
STACK_SIZE_RX_BYTES / 4,
|
||||||
|
&localChannel,
|
||||||
|
TASK_PRIORITY_RX,
|
||||||
|
&localChannel.rxTaskHandle);
|
||||||
|
PIOS_TASK_MONITOR_RegisterTask(TASKINFO_RUNNING_TELEMETRYRX,
|
||||||
|
localChannel.rxTaskHandle);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Start the telemetry tasks associated with Radio/USB
|
||||||
UAVObjIterate(®isterRadioObject);
|
UAVObjIterate(®isterRadioObject);
|
||||||
|
|
||||||
// Listen to objects of interest
|
// Listen to objects of interest
|
||||||
#ifdef PIOS_TELEM_PRIORITY_QUEUE
|
#ifdef PIOS_TELEM_PRIORITY_QUEUE
|
||||||
GCSTelemetryStatsConnectQueue(localChannel.priorityQueue);
|
|
||||||
GCSTelemetryStatsConnectQueue(radioChannel.priorityQueue);
|
GCSTelemetryStatsConnectQueue(radioChannel.priorityQueue);
|
||||||
#else /* PIOS_TELEM_PRIORITY_QUEUE */
|
#else /* PIOS_TELEM_PRIORITY_QUEUE */
|
||||||
GCSTelemetryStatsConnectQueue(localChannel.queue);
|
|
||||||
GCSTelemetryStatsConnectQueue(radioChannel.queue);
|
GCSTelemetryStatsConnectQueue(radioChannel.queue);
|
||||||
#endif /* PIOS_TELEM_PRIORITY_QUEUE */
|
#endif /* PIOS_TELEM_PRIORITY_QUEUE */
|
||||||
|
|
||||||
// Start telemetry tasks
|
|
||||||
xTaskCreate(telemetryTxTask,
|
|
||||||
"TelTx",
|
|
||||||
STACK_SIZE_TX_BYTES / 4,
|
|
||||||
&localChannel,
|
|
||||||
TASK_PRIORITY_TX,
|
|
||||||
&localChannel.txTaskHandle);
|
|
||||||
PIOS_TASK_MONITOR_RegisterTask(TASKINFO_RUNNING_TELEMETRYTX,
|
|
||||||
localChannel.txTaskHandle);
|
|
||||||
xTaskCreate(telemetryRxTask,
|
|
||||||
"TelRx",
|
|
||||||
STACK_SIZE_RX_BYTES / 4,
|
|
||||||
&localChannel,
|
|
||||||
TASK_PRIORITY_RX,
|
|
||||||
&localChannel.rxTaskHandle);
|
|
||||||
PIOS_TASK_MONITOR_RegisterTask(TASKINFO_RUNNING_TELEMETRYRX,
|
|
||||||
localChannel.rxTaskHandle);
|
|
||||||
|
|
||||||
xTaskCreate(telemetryTxTask,
|
xTaskCreate(telemetryTxTask,
|
||||||
"RadioTx",
|
"RadioTx",
|
||||||
STACK_SIZE_RADIO_TX_BYTES / 4,
|
STACK_SIZE_RADIO_TX_BYTES / 4,
|
||||||
@ -207,6 +216,35 @@ int32_t TelemetryStart(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Intialise a telemetry channel */
|
||||||
|
void TelemetryInitializeChannel(channelContext *channel)
|
||||||
|
{
|
||||||
|
// Create object queues
|
||||||
|
channel->queue = xQueueCreate(MAX_QUEUE_SIZE,
|
||||||
|
sizeof(UAVObjEvent));
|
||||||
|
#if defined(PIOS_TELEM_PRIORITY_QUEUE)
|
||||||
|
channel->priorityQueue = xQueueCreate(MAX_QUEUE_SIZE,
|
||||||
|
sizeof(UAVObjEvent));
|
||||||
|
#endif /* PIOS_TELEM_PRIORITY_QUEUE */
|
||||||
|
|
||||||
|
// Initialise UAVTalk
|
||||||
|
channel->uavTalkCon = UAVTalkInitialize(&transmitLocalData);
|
||||||
|
|
||||||
|
// Create periodic event that will be used to update the telemetry stats
|
||||||
|
UAVObjEvent ev;
|
||||||
|
memset(&ev, 0, sizeof(UAVObjEvent));
|
||||||
|
|
||||||
|
#ifdef PIOS_TELEM_PRIORITY_QUEUE
|
||||||
|
EventPeriodicQueueCreate(&ev,
|
||||||
|
channel->priorityQueue,
|
||||||
|
STATS_UPDATE_PERIOD_MS);
|
||||||
|
#else /* PIOS_TELEM_PRIORITY_QUEUE */
|
||||||
|
EventPeriodicQueueCreate(&ev,
|
||||||
|
channel->queue,
|
||||||
|
STATS_UPDATE_PERIOD_MS);
|
||||||
|
#endif /* PIOS_TELEM_PRIORITY_QUEUE */
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialise the telemetry module
|
* Initialise the telemetry module
|
||||||
* \return -1 if initialisation failed
|
* \return -1 if initialisation failed
|
||||||
@ -214,58 +252,38 @@ int32_t TelemetryStart(void)
|
|||||||
*/
|
*/
|
||||||
int32_t TelemetryInitialize(void)
|
int32_t TelemetryInitialize(void)
|
||||||
{
|
{
|
||||||
|
HwSettingsInitialize();
|
||||||
|
|
||||||
FlightTelemetryStatsInitialize();
|
FlightTelemetryStatsInitialize();
|
||||||
GCSTelemetryStatsInitialize();
|
GCSTelemetryStatsInitialize();
|
||||||
|
|
||||||
// Initialize vars
|
// Initialize vars
|
||||||
timeOfLastObjectUpdate = 0;
|
timeOfLastObjectUpdate = 0;
|
||||||
|
|
||||||
// Create object queues
|
// Reset link stats
|
||||||
localChannel.queue = xQueueCreate(MAX_QUEUE_SIZE,
|
txErrors = 0;
|
||||||
sizeof(UAVObjEvent));
|
txRetries = 0;
|
||||||
radioChannel.queue = xQueueCreate(MAX_QUEUE_SIZE,
|
|
||||||
sizeof(UAVObjEvent));
|
|
||||||
#if defined(PIOS_TELEM_PRIORITY_QUEUE)
|
|
||||||
localChannel.priorityQueue = xQueueCreate(MAX_QUEUE_SIZE,
|
|
||||||
sizeof(UAVObjEvent));
|
|
||||||
radioChannel.priorityQueue = xQueueCreate(MAX_QUEUE_SIZE,
|
|
||||||
sizeof(UAVObjEvent));
|
|
||||||
#endif /* PIOS_TELEM_PRIORITY_QUEUE */
|
|
||||||
|
|
||||||
// Set channel port handlers
|
// Set channel port handlers
|
||||||
localChannel.getPort = localPort;
|
localChannel.getPort = localPort;
|
||||||
radioChannel.getPort = radioPort;
|
radioChannel.getPort = radioPort;
|
||||||
|
|
||||||
HwSettingsInitialize();
|
// Set the local telemetry baud rate
|
||||||
updateSettings(&localChannel);
|
updateSettings(&localChannel);
|
||||||
|
|
||||||
|
// Only initialise local channel if telemetry port enabled
|
||||||
|
if (localPort()) {
|
||||||
|
// Initialise channel
|
||||||
|
TelemetryInitializeChannel(&localChannel);
|
||||||
|
// Initialise UAVTalk
|
||||||
|
localChannel.uavTalkCon = UAVTalkInitialize(&transmitLocalData);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Initialise channel
|
||||||
|
TelemetryInitializeChannel(&radioChannel);
|
||||||
// Initialise UAVTalk
|
// Initialise UAVTalk
|
||||||
localChannel.uavTalkCon = UAVTalkInitialize(&transmitLocalData);
|
|
||||||
radioChannel.uavTalkCon = UAVTalkInitialize(&transmitRadioData);
|
radioChannel.uavTalkCon = UAVTalkInitialize(&transmitRadioData);
|
||||||
|
|
||||||
// Create periodic event that will be used to update the telemetry stats
|
|
||||||
// FIXME STATS_UPDATE_PERIOD_MS is 4000ms while FlighTelemetryStats update period is 5000ms...
|
|
||||||
txErrors = 0;
|
|
||||||
txRetries = 0;
|
|
||||||
UAVObjEvent ev;
|
|
||||||
memset(&ev, 0, sizeof(UAVObjEvent));
|
|
||||||
|
|
||||||
#ifdef PIOS_TELEM_PRIORITY_QUEUE
|
|
||||||
EventPeriodicQueueCreate(&ev,
|
|
||||||
localChannel.priorityQueue,
|
|
||||||
STATS_UPDATE_PERIOD_MS);
|
|
||||||
EventPeriodicQueueCreate(&ev,
|
|
||||||
radioChannel.priorityQueue,
|
|
||||||
STATS_UPDATE_PERIOD_MS);
|
|
||||||
#else /* PIOS_TELEM_PRIORITY_QUEUE */
|
|
||||||
EventPeriodicQueueCreate(&ev,
|
|
||||||
localChannel.queue,
|
|
||||||
STATS_UPDATE_PERIOD_MS);
|
|
||||||
EventPeriodicQueueCreate(&ev,
|
|
||||||
radioChannel.queue,
|
|
||||||
STATS_UPDATE_PERIOD_MS);
|
|
||||||
#endif /* PIOS_TELEM_PRIORITY_QUEUE */
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user