// -*- c-basic-offset: 4 -*- /* * threadmonitor.{cc,hh} -- bin-packing sort for tasks (SMP Click) * Benjie Chen, Eddie Kohler * * Copyright (c) 1999-2000 Massachusetts Institute of Technology * Copyright (c) 2004 Regents of the University of California * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, subject to the conditions * listed in the Click LICENSE file. These conditions include: you must * preserve this copyright notice, and you cannot mention the copyright * holders in advertising related to the Software without their permission. * The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This * notice is a summary of the Click LICENSE file; the license in that file is * legally binding. */ #include #include "threadmonitor.hh" #include #include #include #include #include ThreadMonitor::ThreadMonitor() : _timer(this) { } ThreadMonitor::~ThreadMonitor() { } int ThreadMonitor::configure(Vector &conf, ErrorHandler *errh) { _interval = 1000; _thresh = 1000; if (cp_va_parse(conf, this, errh, cpOptional, cpUnsigned, "interval", &_interval, cpUnsigned, "threshold", &_thresh, cpEnd) < 0) return -1; return 0; } int ThreadMonitor::initialize(ErrorHandler *) { _timer.initialize(this); _timer.schedule_after_msec(10); return 0; } void ThreadMonitor::run_timer(Timer *) { Master *m = router()->master(); StringAccum sa; unsigned now_jiffies = click_jiffies(); // report currently scheduled tasks (ignore pending list) for (int tid = 0; tid < m->nthreads(); tid++) { RouterThread *thread = m->thread(tid); thread->lock_tasks(); Task *end = thread->task_end(); for (Task *t = thread->task_begin(); t != end; t = thread->task_next(t)) if (t->cycles() >= _thresh) { sa << now_jiffies << ": on thread " << tid << ": " << (void *)t << " ("; if (Element *e = t->element()) sa << e->id(); else sa << "hook"; sa << "), cycles " << t->cycles() << '\n'; } thread->unlock_tasks(); } if (sa.length()) click_chatter("%s", sa.c_str()); _timer.schedule_after_msec(_interval); } ELEMENT_REQUIRES(linuxmodule smpclick) EXPORT_ELEMENT(ThreadMonitor)