/** ****************************************************************************** * * @file pios_instrumentation_helper.h * @author The LibrePilot Project, http://www.librepilot.org, Copyright (c) 2016 * The OpenPilot Team, http://www.openpilot.org Copyright (C) 2014. * @brief Macros to easily add optional performance monitoring to a module * * @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 */ /** * @addtogroup PIOS PiOS Instrumentation Support * @{ */ /** * \par * This is a collections of helper macros that ease adding instrumentation support. * \par * Step by step guide: * * Define PIOS_INSTRUMENT_MODULE before including this file to enable instrumentation for a module * *
#define PIOS_INSTRUMENT_MODULE * #include* * Declare the variables used to hold counter handlers. * Place the following code along all module variables declaration. *
PERF_DEFINE_COUNTER(counterUpd); * PERF_DEFINE_COUNTER(counterAccelSamples); * PERF_DEFINE_COUNTER(counterPeriod); * PERF_DEFINE_COUNTER(counterAtt);* * Counters needs to be initialized before they are used. * The following code needs to be added to a function called at module initialization. * the second parameter is a unique counter Id. * A good pracice is to use the upper half word as module id and lower as counter id * Optionally three strings containing Module Name, Counter description and unit of measure can be passed. * Those strings will be used in future to automatically extract the list of counters from code to managed * by GCS or some other custom tool. * * PERF_INIT_COUNTER(counterVariable, id, "MODULE NAME","COUNTER DESCRIPTION","UNIT OF MEASURE"); * *
PERF_INIT_COUNTER(counterUpd, 0xA7710001, "ATTITUDE", "Sensor update execution time", "us"); * PERF_INIT_COUNTER(counterAtt, 0xA7710002, "ATTITUDE", "Attitude estimation execution time", "us"); * PERF_INIT_COUNTER(counterPeriod, 0xA7710003, "ATTITUDE", "Sensor update period", "us"); * PERF_INIT_COUNTER(counterAccelSamples, 0xA7710004, "ATTITUDE", "Samples for each sensor cycle", "count");* * At this point you can start using the counters as in the following samples * * Track the time spent on a certain function: *
PERF_TIMED_SECTION_START(counterAtt); * updateAttitude(&accelState, &gyros); * PERF_TIMED_SECTION_END(counterAtt);* PERF_TIMED_SECTION_[START!STOP] marks the beginning and the end of the code to monitor * * Measure the mean of the period a certain point is reached: *
PERF_MEASURE_PERIOD(counterPeriod);* Note that the value stored in the counter is a long running mean while max and min are single point values * * Track an user defined int32_t value: *
PERF_TRACK_VALUE(counterAccelSamples, i);* the counter is then updated with the value of i. * * \par */ #ifndef PIOS_INSTRUMENTATION_HELPER_H #define PIOS_INSTRUMENTATION_HELPER_H #if defined(PIOS_INCLUDE_INSTRUMENTATION) && defined(PIOS_INSTRUMENT_MODULE) #include