Skip to content

Commit

Permalink
load_mon move from NuttX LPWORK to PX4 work queue lp_default
Browse files Browse the repository at this point in the history
  • Loading branch information
dagar authored May 28, 2019
1 parent 5d6cc7d commit 6627c60
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 25 deletions.
1 change: 1 addition & 0 deletions src/modules/load_mon/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -38,5 +38,6 @@ px4_add_module(
SRCS
load_mon.cpp
DEPENDS
px4_work_queue
)

41 changes: 16 additions & 25 deletions src/modules/load_mon/load_mon.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@
#include <px4_defines.h>
#include <px4_module.h>
#include <px4_module_params.h>
#include <px4_workqueue.h>
#include <px4_work_queue/ScheduledWorkItem.hpp>
#include <systemlib/cpuload.h>
#include <uORB/topics/cpuload.h>
#include <uORB/topics/task_stack_info.h>
Expand All @@ -68,7 +68,7 @@ extern "C" __EXPORT int load_mon_main(int argc, char *argv[]);
// Run it at 1 Hz.
const unsigned LOAD_MON_INTERVAL_US = 1000000;

class LoadMon : public ModuleBase<LoadMon>, public ModuleParams
class LoadMon : public ModuleBase<LoadMon>, public ModuleParams, public px4::ScheduledWorkItem
{
public:
LoadMon();
Expand All @@ -88,12 +88,11 @@ class LoadMon : public ModuleBase<LoadMon>, public ModuleParams
/** @see ModuleBase::print_status() */
int print_status() override;

/** Trampoline for the work queue. */
static void cycle_trampoline(void *arg);
void start();

private:
/** Do a compute and schedule the next cycle. */
void _cycle();
void Run() override;

/** Do a calculation of the CPU load and publish it. */
void _cpuload();
Expand All @@ -113,8 +112,6 @@ class LoadMon : public ModuleBase<LoadMon>, public ModuleParams
(ParamBool<px4::params::SYS_STCK_EN>) _param_sys_stck_en
)

work_s _work{};

orb_advert_t _cpuload_pub{nullptr};

hrt_abstime _last_idle_time{0};
Expand All @@ -125,12 +122,15 @@ class LoadMon : public ModuleBase<LoadMon>, public ModuleParams

LoadMon::LoadMon() :
ModuleParams(nullptr),
ScheduledWorkItem(px4::wq_configurations::lp_default),
_stack_perf(perf_alloc(PC_ELAPSED, "stack_check"))
{
}

LoadMon::~LoadMon()
{
ScheduleClear();

perf_free(_stack_perf);
}

Expand All @@ -143,28 +143,22 @@ int LoadMon::task_spawn(int argc, char *argv[])
return -1;
}

/* Schedule a cycle to start things. */
int ret = work_queue(LPWORK, &obj->_work, (worker_t)&LoadMon::cycle_trampoline, obj, 0);

if (ret < 0) {
delete obj;
return ret;
}

_object.store(obj);
_task_id = task_id_is_work_queue;

/* Schedule a cycle to start things. */
obj->start();

return 0;
}

void
LoadMon::cycle_trampoline(void *arg)
LoadMon::start()
{
LoadMon *dev = reinterpret_cast<LoadMon *>(arg);

dev->_cycle();
ScheduleOnInterval(LOAD_MON_INTERVAL_US);
}

void LoadMon::_cycle()
void LoadMon::Run()
{
_cpuload();

Expand All @@ -176,11 +170,8 @@ void LoadMon::_cycle()

#endif

if (!should_exit()) {
work_queue(LPWORK, &_work, (worker_t)&LoadMon::cycle_trampoline, this,
USEC2TICK(LOAD_MON_INTERVAL_US));

} else {
if (should_exit()) {
ScheduleClear();
exit_and_cleanup();
}
}
Expand Down

0 comments on commit 6627c60

Please sign in to comment.