mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2024-11-29 07:24:13 +01:00
taskmonitor: move taskmonitor into flight/Libraries
taskmonitor.[ch] existed as (nearly) identical copies under CC and OP directories. Both builds now reference the common version under Libraries.
This commit is contained in:
parent
387ea77d30
commit
8cd4816d7b
@ -136,7 +136,6 @@ SRC += ${OPMODULEDIR}/System/systemmod.c
|
|||||||
SRC += $(OPSYSTEM)/coptercontrol.c
|
SRC += $(OPSYSTEM)/coptercontrol.c
|
||||||
SRC += $(OPSYSTEM)/pios_board.c
|
SRC += $(OPSYSTEM)/pios_board.c
|
||||||
SRC += $(OPSYSTEM)/alarms.c
|
SRC += $(OPSYSTEM)/alarms.c
|
||||||
SRC += $(OPSYSTEM)/taskmonitor.c
|
|
||||||
SRC += $(OPUAVTALK)/uavtalk.c
|
SRC += $(OPUAVTALK)/uavtalk.c
|
||||||
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
||||||
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
||||||
@ -233,6 +232,7 @@ SRC += $(PIOSCOMMON)/printf-stdarg.c
|
|||||||
## Libraries for flight calculations
|
## Libraries for flight calculations
|
||||||
SRC += $(FLIGHTLIB)/fifo_buffer.c
|
SRC += $(FLIGHTLIB)/fifo_buffer.c
|
||||||
SRC += $(FLIGHTLIB)/CoordinateConversions.c
|
SRC += $(FLIGHTLIB)/CoordinateConversions.c
|
||||||
|
SRC += $(FLIGHTLIB)/taskmonitor.c
|
||||||
|
|
||||||
## CMSIS for STM32
|
## CMSIS for STM32
|
||||||
SRC += $(CMSISDIR)/core_cm3.c
|
SRC += $(CMSISDIR)/core_cm3.c
|
||||||
|
@ -1,42 +0,0 @@
|
|||||||
/**
|
|
||||||
******************************************************************************
|
|
||||||
* @addtogroup OpenPilotSystem OpenPilot System
|
|
||||||
* @{
|
|
||||||
* @addtogroup OpenPilotLibraries OpenPilot System Libraries
|
|
||||||
* @{
|
|
||||||
* @file taskmonitor.h
|
|
||||||
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
||||||
* @brief Include file of the task monitoring library
|
|
||||||
* @see The GNU Public License (GPL) Version 3
|
|
||||||
*
|
|
||||||
*****************************************************************************/
|
|
||||||
/*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful, but
|
|
||||||
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
||||||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License along
|
|
||||||
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
||||||
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
|
||||||
#ifndef TASKMONITOR_H
|
|
||||||
#define TASKMONITOR_H
|
|
||||||
|
|
||||||
#include "taskinfo.h"
|
|
||||||
|
|
||||||
int32_t TaskMonitorInitialize(void);
|
|
||||||
int32_t TaskMonitorAdd(TaskInfoRunningElem task, xTaskHandle handle);
|
|
||||||
void TaskMonitorUpdateAll(void);
|
|
||||||
|
|
||||||
#endif // TASKMONITOR_H
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @}
|
|
||||||
* @}
|
|
||||||
*/
|
|
@ -139,7 +139,6 @@ SRC += ${OPMODULEDIR}/System/systemmod.c
|
|||||||
SRC += $(OPSYSTEM)/openpilot.c
|
SRC += $(OPSYSTEM)/openpilot.c
|
||||||
SRC += $(OPSYSTEM)/pios_board.c
|
SRC += $(OPSYSTEM)/pios_board.c
|
||||||
SRC += $(OPSYSTEM)/alarms.c
|
SRC += $(OPSYSTEM)/alarms.c
|
||||||
SRC += $(OPSYSTEM)/taskmonitor.c
|
|
||||||
SRC += $(OPUAVTALK)/uavtalk.c
|
SRC += $(OPUAVTALK)/uavtalk.c
|
||||||
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
||||||
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
||||||
@ -208,6 +207,7 @@ SRC += $(FLIGHTLIB)/ahrs_comm_objects.c
|
|||||||
SRC += $(FLIGHTLIB)/fifo_buffer.c
|
SRC += $(FLIGHTLIB)/fifo_buffer.c
|
||||||
SRC += $(FLIGHTLIB)/WorldMagModel.c
|
SRC += $(FLIGHTLIB)/WorldMagModel.c
|
||||||
SRC += $(FLIGHTLIB)/CoordinateConversions.c
|
SRC += $(FLIGHTLIB)/CoordinateConversions.c
|
||||||
|
SRC += $(FLIGHTLIB)/taskmonitor.c
|
||||||
|
|
||||||
## CMSIS for STM32
|
## CMSIS for STM32
|
||||||
SRC += $(CMSISDIR)/core_cm3.c
|
SRC += $(CMSISDIR)/core_cm3.c
|
||||||
|
@ -149,7 +149,6 @@ SRC += ${OPMODULEDIR}/System/systemmod.c
|
|||||||
SRC += $(OPSYSTEM)/openpilot.c
|
SRC += $(OPSYSTEM)/openpilot.c
|
||||||
SRC += $(OPSYSTEM)/pios_board_posix.c
|
SRC += $(OPSYSTEM)/pios_board_posix.c
|
||||||
SRC += $(OPSYSTEM)/alarms.c
|
SRC += $(OPSYSTEM)/alarms.c
|
||||||
SRC += $(OPSYSTEM)/taskmonitor.c
|
|
||||||
SRC += $(OPUAVTALK)/uavtalk.c
|
SRC += $(OPUAVTALK)/uavtalk.c
|
||||||
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
SRC += $(OPUAVOBJ)/uavobjectmanager.c
|
||||||
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
SRC += $(OPUAVOBJ)/eventdispatcher.c
|
||||||
@ -189,6 +188,7 @@ SRC += $(PIOSPOSIX)/pios_rcvr.c
|
|||||||
SRC += $(FLIGHTLIB)/fifo_buffer.c
|
SRC += $(FLIGHTLIB)/fifo_buffer.c
|
||||||
SRC += $(FLIGHTLIB)/WorldMagModel.c
|
SRC += $(FLIGHTLIB)/WorldMagModel.c
|
||||||
SRC += $(FLIGHTLIB)/CoordinateConversions.c
|
SRC += $(FLIGHTLIB)/CoordinateConversions.c
|
||||||
|
SRC += $(FLIGHTLIB)/taskmonitor.c
|
||||||
## RTOS and RTOS Portable
|
## RTOS and RTOS Portable
|
||||||
SRC += $(RTOSSRCDIR)/list.c
|
SRC += $(RTOSSRCDIR)/list.c
|
||||||
SRC += $(RTOSSRCDIR)/queue.c
|
SRC += $(RTOSSRCDIR)/queue.c
|
||||||
|
@ -1,149 +0,0 @@
|
|||||||
/**
|
|
||||||
******************************************************************************
|
|
||||||
* @addtogroup OpenPilotSystem OpenPilot System
|
|
||||||
* @{
|
|
||||||
* @addtogroup OpenPilotLibraries OpenPilot System Libraries
|
|
||||||
* @{
|
|
||||||
* @file taskmonitor.h
|
|
||||||
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
|
|
||||||
* @brief Task monitoring library
|
|
||||||
* @see The GNU Public License (GPL) Version 3
|
|
||||||
*
|
|
||||||
*****************************************************************************/
|
|
||||||
/*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful, but
|
|
||||||
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
||||||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License along
|
|
||||||
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
||||||
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
*/
|
|
||||||
#include "openpilot.h"
|
|
||||||
//#include "taskmonitor.h"
|
|
||||||
|
|
||||||
// Private constants
|
|
||||||
|
|
||||||
// Private types
|
|
||||||
|
|
||||||
// Private variables
|
|
||||||
static xSemaphoreHandle lock;
|
|
||||||
static xTaskHandle handles[TASKINFO_RUNNING_NUMELEM];
|
|
||||||
static uint32_t lastMonitorTime;
|
|
||||||
|
|
||||||
// Private functions
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Initialize library
|
|
||||||
*/
|
|
||||||
int32_t TaskMonitorInitialize(void)
|
|
||||||
{
|
|
||||||
lock = xSemaphoreCreateRecursiveMutex();
|
|
||||||
memset(handles, 0, sizeof(xTaskHandle)*TASKINFO_RUNNING_NUMELEM);
|
|
||||||
lastMonitorTime = 0;
|
|
||||||
#if defined(DIAG_TASKS)
|
|
||||||
lastMonitorTime = portGET_RUN_TIME_COUNTER_VALUE();
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Register a task handle with the library
|
|
||||||
*/
|
|
||||||
int32_t TaskMonitorAdd(TaskInfoRunningElem task, xTaskHandle handle)
|
|
||||||
{
|
|
||||||
if (task < TASKINFO_RUNNING_NUMELEM)
|
|
||||||
{
|
|
||||||
xSemaphoreTakeRecursive(lock, portMAX_DELAY);
|
|
||||||
handles[task] = handle;
|
|
||||||
xSemaphoreGiveRecursive(lock);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove a task handle from the library
|
|
||||||
*/
|
|
||||||
int32_t TaskMonitorRemove(TaskInfoRunningElem task)
|
|
||||||
{
|
|
||||||
if (task < TASKINFO_RUNNING_NUMELEM)
|
|
||||||
{
|
|
||||||
xSemaphoreTakeRecursive(lock, portMAX_DELAY);
|
|
||||||
handles[task] = 0;
|
|
||||||
xSemaphoreGiveRecursive(lock);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Update the status of all tasks
|
|
||||||
*/
|
|
||||||
void TaskMonitorUpdateAll(void)
|
|
||||||
{
|
|
||||||
#if defined(DIAG_TASKS)
|
|
||||||
TaskInfoData data;
|
|
||||||
int n;
|
|
||||||
|
|
||||||
// Lock
|
|
||||||
xSemaphoreTakeRecursive(lock, portMAX_DELAY);
|
|
||||||
|
|
||||||
#if ( configGENERATE_RUN_TIME_STATS == 1 )
|
|
||||||
uint32_t currentTime;
|
|
||||||
uint32_t deltaTime;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Calculate the amount of elapsed run time between the last time we
|
|
||||||
* measured and now. Scale so that we can convert task run times
|
|
||||||
* directly to percentages.
|
|
||||||
*/
|
|
||||||
currentTime = portGET_RUN_TIME_COUNTER_VALUE();
|
|
||||||
deltaTime = ((currentTime - lastMonitorTime) / 100) ? : 1; /* avoid divide-by-zero if the interval is too small */
|
|
||||||
lastMonitorTime = currentTime;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Update all task information
|
|
||||||
for (n = 0; n < TASKINFO_RUNNING_NUMELEM; ++n)
|
|
||||||
{
|
|
||||||
if (handles[n] != 0)
|
|
||||||
{
|
|
||||||
data.Running[n] = TASKINFO_RUNNING_TRUE;
|
|
||||||
#if defined(ARCH_POSIX) || defined(ARCH_WIN32)
|
|
||||||
data.StackRemaining[n] = 10000;
|
|
||||||
#else
|
|
||||||
data.StackRemaining[n] = uxTaskGetStackHighWaterMark(handles[n]) * 4;
|
|
||||||
#if ( configGENERATE_RUN_TIME_STATS == 1 )
|
|
||||||
/* Generate run time stats */
|
|
||||||
data.RunningTime[n] = uxTaskGetRunTime(handles[n]) / deltaTime;
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
data.Running[n] = TASKINFO_RUNNING_FALSE;
|
|
||||||
data.StackRemaining[n] = 0;
|
|
||||||
data.RunningTime[n] = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update object
|
|
||||||
TaskInfoSet(&data);
|
|
||||||
|
|
||||||
// Done
|
|
||||||
xSemaphoreGiveRecursive(lock);
|
|
||||||
#endif
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user