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

📄 delayshaper.cc

📁 COPE the first practical network coding scheme which is developped on click
💻 CC
字号:
// -*- c-basic-offset: 4 -*-/* * delayshaper.{cc,hh} -- element pulls packets from input, delays returnign * the packet to output port. * * Copyright (c) 1999-2001 Massachusetts Institute of Technology * Copyright (c) 2003 International Computer Science Institute * * 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 <click/error.hh>#include <click/confparse.hh>#include <click/glue.hh>#include "delayshaper.hh"#include <click/standard/scheduleinfo.hh>CLICK_DECLSDelayShaper::DelayShaper()    : Element(1, 1), _p(0), _timer(this){}DelayShaper::~DelayShaper(){}void *DelayShaper::cast(const char *n){    if (strcmp(n, "DelayShaper") == 0)	return (DelayShaper *)this;    else if (strcmp(n, Notifier::EMPTY_NOTIFIER) == 0)	return static_cast<Notifier *>(this);    else	return Element::cast(n);}Notifier::SearchOpDelayShaper::notifier_search_op(){    return SEARCH_WAKE_CONTINUE;}intDelayShaper::configure(Vector<String> &conf, ErrorHandler *errh){    ActiveNotifier::initialize(router());    return cp_va_parse(conf, this, errh,		       cpTimestamp, "delay", &_delay, cpEnd);}intDelayShaper::initialize(ErrorHandler *){    _timer.initialize(this);    _upstream_signal = Notifier::upstream_empty_signal(this, 0, 0);    return 0;}voidDelayShaper::cleanup(CleanupStage){    if (_p)	_p->kill();}Packet *DelayShaper::pull(int){    // read a packet    if (!_p && (_p = input(0).pull())) {	if (!_p->timestamp_anno()._sec) // get timestamp if not set	    _p->timestamp_anno().set_now();	_p->timestamp_anno() += _delay;    }        if (_p) {	Timestamp now = Timestamp::now();	Timestamp diff = _p->timestamp_anno() - now;		if (diff._sec < 0 || (diff._sec == 0 && diff._subsec == 0)) {	    // packet ready for output	    Packet *p = _p;	    p->timestamp_anno() = now;	    _p = 0;	    return p;	} else if (diff._sec == 0 && diff._subsec < Timestamp::usec_to_subsec(100000)) {	    // small delta, don't go to sleep -- but mark our Signal as active,	    // since we have something ready. NB: should not wake listeners --	    // we are in pull()!	    set_signal_active(true);	} else {	    // large delta, go to sleep and schedule Timer	    _timer.schedule_at(_p->timestamp_anno());	    sleep_listeners();	}    } else if (!_upstream_signal) {	// no packet available, we go to sleep right away	sleep_listeners();    }    return 0;}voidDelayShaper::run_timer(){    wake_listeners();}StringDelayShaper::read_param(Element *e, void *){    DelayShaper *u = (DelayShaper *)e;    return cp_unparse_interval(u->_delay) + "\n";}intDelayShaper::write_param(const String &s, Element *e, void *, ErrorHandler *errh){    DelayShaper *u = (DelayShaper *)e;    if (!cp_time(cp_uncomment(s), &u->_delay))	return errh->error("delay must be a timestamp");    return 0;}voidDelayShaper::add_handlers(){    add_read_handler("delay", read_param, (void *)0);    add_write_handler("delay", write_param, (void *)0);}CLICK_ENDDECLSEXPORT_ELEMENT(DelayShaper)ELEMENT_MT_SAFE(DelayShaper)

⌨️ 快捷键说明

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