60 lines
995 B
Plaintext
60 lines
995 B
Plaintext
/*
|
|
AP_PerfMon
|
|
Code by Randy Mackay
|
|
*/
|
|
|
|
#include <AP_Common.h>
|
|
#include <AP_Progmem.h>
|
|
#include <AP_Param.h>
|
|
#include <AP_Math.h>
|
|
#include <AP_HAL.h>
|
|
#include <AP_HAL_AVR.h>
|
|
#include <AP_PerfMon.h> // PerfMonitor library
|
|
|
|
const AP_HAL::HAL& hal = AP_HAL_BOARD_DRIVER;
|
|
|
|
AP_PERFMON_REGISTER_FN(setup)
|
|
AP_PERFMON_REGISTER_FN(loop)
|
|
AP_PERFMON_REGISTER_FN(testFn)
|
|
AP_PERFMON_REGISTER_FN(testFn2)
|
|
|
|
void setup()
|
|
{
|
|
AP_PERFMON_FUNCTION(setup)
|
|
|
|
hal.console->print_P(PSTR("Performance Monitor test v1.1\n"));
|
|
}
|
|
|
|
void loop()
|
|
{
|
|
AP_PERFMON_FUNCTION(loop)
|
|
|
|
int16_t i = 0;
|
|
|
|
for( i=0; i<10; i++ ) {
|
|
testFn();
|
|
}
|
|
|
|
AP_PerfMon::DisplayAndClear(5);
|
|
//AP_PerfMon::DisplayResults();
|
|
//AP_PerfMon::ClearAll();
|
|
|
|
hal.scheduler->delay(2000);
|
|
}
|
|
|
|
void testFn()
|
|
{
|
|
AP_PERFMON_FUNCTION(testFn)
|
|
hal.scheduler->delay(10);
|
|
testFn2();
|
|
hal.scheduler->delay(10);
|
|
}
|
|
|
|
void testFn2()
|
|
{
|
|
AP_PERFMON_FUNCTION(testFn2)
|
|
hal.scheduler->delay(10);
|
|
}
|
|
|
|
AP_HAL_MAIN();
|