parent
a802961286
commit
7cd093ce95
17 changed files with 284 additions and 0 deletions
@ -0,0 +1,89 @@ |
|||||||
|
#include "NetworkIOMeter.h" |
||||||
|
|
||||||
|
#include "CRT.h" |
||||||
|
#include "Platform.h" |
||||||
|
|
||||||
|
|
||||||
|
static const int NetworkIOMeter_attributes[] = { |
||||||
|
METER_VALUE_IOREAD, |
||||||
|
METER_VALUE_IOWRITE, |
||||||
|
}; |
||||||
|
|
||||||
|
static unsigned long int cached_rxb_diff = 0; |
||||||
|
static unsigned long int cached_rxp_diff = 0; |
||||||
|
static unsigned long int cached_txb_diff = 0; |
||||||
|
static unsigned long int cached_txp_diff = 0; |
||||||
|
|
||||||
|
static void NetworkIOMeter_updateValues(ATTR_UNUSED Meter* this, char* buffer, int len) { |
||||||
|
static unsigned long int cached_rxb_total = 0; |
||||||
|
static unsigned long int cached_rxp_total = 0; |
||||||
|
static unsigned long int cached_txb_total = 0; |
||||||
|
static unsigned long int cached_txp_total = 0; |
||||||
|
static unsigned long long int cached_last_update = 0; |
||||||
|
|
||||||
|
struct timeval tv; |
||||||
|
gettimeofday(&tv, NULL); |
||||||
|
unsigned long long int timeInMilliSeconds = (unsigned long long int)tv.tv_sec * 1000 + (unsigned long long int)tv.tv_usec / 1000; |
||||||
|
unsigned long long int passedTimeInMs = timeInMilliSeconds - cached_last_update; |
||||||
|
|
||||||
|
/* update only every 500ms */ |
||||||
|
if (passedTimeInMs > 500) { |
||||||
|
unsigned long int bytesReceived, packetsReceived, bytesTransmitted, packetsTransmitted; |
||||||
|
|
||||||
|
Platform_getNetworkIO(&bytesReceived, &packetsReceived, &bytesTransmitted, &packetsTransmitted); |
||||||
|
|
||||||
|
cached_rxb_diff = (bytesReceived - cached_rxb_total) / 1024; /* Meter_humanUnit() expects unit in kilo */ |
||||||
|
cached_rxb_diff = 1000.0 * cached_rxb_diff / passedTimeInMs; /* convert to per second */ |
||||||
|
cached_rxb_total = bytesReceived; |
||||||
|
|
||||||
|
cached_rxp_diff = packetsReceived - cached_rxp_total; |
||||||
|
cached_rxp_total = packetsReceived; |
||||||
|
|
||||||
|
cached_txb_diff = (bytesTransmitted - cached_txb_total) / 1024; /* Meter_humanUnit() expects unit in kilo */ |
||||||
|
cached_txb_diff = 1000.0 * cached_txb_diff / passedTimeInMs; /* convert to per second */ |
||||||
|
cached_txb_total = bytesTransmitted; |
||||||
|
|
||||||
|
cached_txp_diff = packetsTransmitted - cached_txp_total; |
||||||
|
cached_txp_total = packetsTransmitted; |
||||||
|
|
||||||
|
cached_last_update = timeInMilliSeconds; |
||||||
|
} |
||||||
|
|
||||||
|
char bufferBytesReceived[12], bufferBytesTransmitted[12]; |
||||||
|
Meter_humanUnit(bufferBytesReceived, cached_rxb_diff, sizeof(bufferBytesReceived)); |
||||||
|
Meter_humanUnit(bufferBytesTransmitted, cached_txb_diff, sizeof(bufferBytesTransmitted)); |
||||||
|
xSnprintf(buffer, len, "rx:%siB/s tx:%siB/s", bufferBytesReceived, bufferBytesTransmitted); |
||||||
|
} |
||||||
|
|
||||||
|
static void NetworkIOMeter_display(ATTR_UNUSED const Object* cast, RichString* out) { |
||||||
|
char buffer[32]; |
||||||
|
|
||||||
|
RichString_write(out, CRT_colors[METER_TEXT], "rx: "); |
||||||
|
Meter_humanUnit(buffer, cached_rxb_diff, sizeof(buffer)); |
||||||
|
RichString_append(out, CRT_colors[METER_VALUE_IOREAD], buffer); |
||||||
|
RichString_append(out, CRT_colors[METER_VALUE_IOREAD], "iB/s"); |
||||||
|
|
||||||
|
RichString_append(out, CRT_colors[METER_TEXT], " tx: "); |
||||||
|
Meter_humanUnit(buffer, cached_txb_diff, sizeof(buffer)); |
||||||
|
RichString_append(out, CRT_colors[METER_VALUE_IOWRITE], buffer); |
||||||
|
RichString_append(out, CRT_colors[METER_VALUE_IOWRITE], "iB/s"); |
||||||
|
|
||||||
|
xSnprintf(buffer, sizeof(buffer), " (%lu/%lu packets) ", cached_rxp_diff, cached_txp_diff); |
||||||
|
RichString_append(out, CRT_colors[METER_TEXT], buffer); |
||||||
|
} |
||||||
|
|
||||||
|
const MeterClass NetworkIOMeter_class = { |
||||||
|
.super = { |
||||||
|
.extends = Class(Meter), |
||||||
|
.delete = Meter_delete, |
||||||
|
.display = NetworkIOMeter_display |
||||||
|
}, |
||||||
|
.updateValues = NetworkIOMeter_updateValues, |
||||||
|
.defaultMode = TEXT_METERMODE, |
||||||
|
.maxItems = 0, |
||||||
|
.total = 100.0, |
||||||
|
.attributes = NetworkIOMeter_attributes, |
||||||
|
.name = "NetworkIO", |
||||||
|
.uiName = "Network IO", |
||||||
|
.caption = "Network: " |
||||||
|
}; |
||||||
@ -0,0 +1,8 @@ |
|||||||
|
#ifndef HEADER_NetworkIOMeter |
||||||
|
#define HEADER_NetworkIOMeter |
||||||
|
|
||||||
|
#include "Meter.h" |
||||||
|
|
||||||
|
extern const MeterClass NetworkIOMeter_class; |
||||||
|
|
||||||
|
#endif /* HEADER_NetworkIOMeter */ |
||||||
Loading…
Reference in new issue