📄 ettmetric.cc
字号:
/* * ettmetric.{cc,hh} -- estimated transmission count (`ETT') metric * * Copyright (c) 2003 Massachusetts Institute of Technology * * 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/confparse.hh>#include <click/error.hh>#include <click/straccum.hh>#include "ettmetric.hh"#include "ettstat.hh"#include <elements/wifi/linktable.hh>CLICK_DECLS #define max(a, b) ((a) > (b) ? (a) : (b))#define min(a, b) ((a) < (b) ? (a) : (b))ETTMetric::ETTMetric() : LinkMetric(), _link_table(0){}ETTMetric::~ETTMetric(){}void *ETTMetric::cast(const char *n) { if (strcmp(n, "ETTMetric") == 0) return (ETTMetric *) this; else if (strcmp(n, "LinkMetric") == 0) return (LinkMetric *) this; else return 0;}intETTMetric::configure(Vector<String> &conf, ErrorHandler *errh){ int res = cp_va_parse(conf, this, errh, cpKeywords, "LT", cpElement, "LinkTable element", &_link_table, cpEnd); if (res < 0) return res; if (_link_table == 0) { click_chatter("%{element}: no LTelement specified", this); } if (_link_table && _link_table->cast("LinkTable") == 0) { return errh->error("LinkTable element is not a LinkTable"); } return 0;}int ETTMetric::get_tx_rate(EtherAddress) { return 2;}voidETTMetric::update_link(IPAddress from, IPAddress to, Vector<RateSize> rs, Vector<int> fwd, Vector<int> rev, uint32_t seq){ if (!from || !to) { click_chatter("%{element}::update_link called with %s %s\n", this, from.s().cc(), to.s().cc()); return; } int one_ack_fwd = 0; int one_ack_rev = 0; int six_ack_fwd = 0; int six_ack_rev = 0; /* * if we don't have a few probes going out, just pick * the smallest size for fwd rate */ int one_ack_size = 0; int six_ack_size = 0; for (int x = 0; x < rs.size(); x++) { if (rs[x]._rate == 2 && (!one_ack_size || one_ack_size > rs[x]._size)) { one_ack_size = rs[x]._size; one_ack_fwd = fwd[x]; one_ack_rev = rev[x]; } else if (rs[x]._rate == 12 && (!six_ack_size || six_ack_size > rs[x]._size)) { six_ack_size = rs[x]._size; six_ack_fwd = fwd[x]; six_ack_rev = rev[x]; } } if (!one_ack_fwd && !six_ack_fwd && !one_ack_rev && !six_ack_rev) { return; } int rev_metric = 0; int fwd_metric = 0; int best_rev_rate = 0; int best_fwd_rate = 0; for (int x = 0; x < rs.size(); x++) { if (rs[x]._size >= 100) { int ack_fwd = 0; int ack_rev = 0; if ((rs[x]._rate == 2) || (rs[x]._rate == 4) || (rs[x]._rate == 11) || (rs[x]._rate == 22)) { ack_fwd = one_ack_fwd; ack_rev = one_ack_rev; } else { ack_fwd = six_ack_fwd; ack_rev = six_ack_rev; } int metric = ett_metric(ack_rev, fwd[x], rs[x]._rate); if (!fwd_metric || (metric && metric < fwd_metric)) { best_fwd_rate = rs[x]._rate; fwd_metric = metric; } metric = ett_metric(ack_fwd, rev[x], rs[x]._rate); if (!rev_metric || (metric && metric < rev_metric)) { rev_metric = metric; best_rev_rate= rs[x]._rate; } } } /* update linktable */ if (fwd_metric && _link_table && !_link_table->update_link(from, to, seq, 0, fwd_metric)) { click_chatter("%{element} couldn't update link %s > %d > %s\n", this, from.s().cc(), fwd_metric, to.s().cc()); } if (rev_metric && _link_table && !_link_table->update_link(to, from, seq, 0, rev_metric)){ click_chatter("%{element} couldn't update link %s < %d < %s\n", this, from.s().cc(), rev_metric, to.s().cc()); }}voidETTMetric::add_handlers(){ add_default_handlers(true);}ELEMENT_PROVIDES(GridGenericMetric)EXPORT_ELEMENT(ETTMetric)CLICK_ENDDECLS
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -