⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 threadmonitor.cc

📁 Click is a modular router toolkit. To use it you ll need to know how to compile and install the sof
💻 CC
字号:
// -*- 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 <click/config.h>#include "threadmonitor.hh"#include <click/straccum.hh>#include <click/confparse.hh>#include <click/router.hh>#include <click/master.hh>#include <click/error.hh>ThreadMonitor::ThreadMonitor()    : _timer(this){}ThreadMonitor::~ThreadMonitor(){}intThreadMonitor::configure(Vector<String> &conf, ErrorHandler *errh){    _interval = 1000;    _thresh = 1000;    if (cp_va_kparse(conf, this, errh,		     "INTERVAL", cpkP, cpUnsigned, &_interval,		     "THRESH", cpkP, cpUnsigned, &_thresh,		     cpEnd) < 0)	return -1;    return 0;}intThreadMonitor::initialize(ErrorHandler *){    _timer.initialize(this);    _timer.schedule_after_msec(10);    return 0;}voidThreadMonitor::run_timer(Timer *){    Master *m = router()->master();    StringAccum sa;    click_jiffies_t 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)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -