Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 49559854 authored by Mitch Williams's avatar Mitch Williams Committed by Auke Kok
Browse files

e1000: add multicast stats counters



Add 4 multicast and broadcast hardware counters (rx/tx), and eliminate
as many non-hardware counters as possible.

Signed-off-by: default avatarMitch Williams <mitch.a.williams@intel.com>
Signed-off-by: default avatarAuke Kok <auke-jan.h.kok@intel.com>
parent 35574764
Loading
Loading
Loading
Loading
+18 −14
Original line number Original line Diff line number Diff line
@@ -56,26 +56,30 @@ struct e1000_stats {
#define E1000_STAT(m) sizeof(((struct e1000_adapter *)0)->m), \
#define E1000_STAT(m) sizeof(((struct e1000_adapter *)0)->m), \
		      offsetof(struct e1000_adapter, m)
		      offsetof(struct e1000_adapter, m)
static const struct e1000_stats e1000_gstrings_stats[] = {
static const struct e1000_stats e1000_gstrings_stats[] = {
	{ "rx_packets", E1000_STAT(net_stats.rx_packets) },
	{ "rx_packets", E1000_STAT(stats.gprc) },
	{ "tx_packets", E1000_STAT(net_stats.tx_packets) },
	{ "tx_packets", E1000_STAT(stats.gptc) },
	{ "rx_bytes", E1000_STAT(net_stats.rx_bytes) },
	{ "rx_bytes", E1000_STAT(stats.gorcl) },
	{ "tx_bytes", E1000_STAT(net_stats.tx_bytes) },
	{ "tx_bytes", E1000_STAT(stats.gotcl) },
	{ "rx_errors", E1000_STAT(net_stats.rx_errors) },
	{ "rx_broadcast", E1000_STAT(stats.bprc) },
	{ "tx_errors", E1000_STAT(net_stats.tx_errors) },
	{ "tx_broadcast", E1000_STAT(stats.bptc) },
	{ "rx_multicast", E1000_STAT(stats.mprc) },
	{ "tx_multicast", E1000_STAT(stats.mptc) },
	{ "rx_errors", E1000_STAT(stats.rxerrc) },
	{ "tx_errors", E1000_STAT(stats.txerrc) },
	{ "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
	{ "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
	{ "multicast", E1000_STAT(net_stats.multicast) },
	{ "multicast", E1000_STAT(stats.mprc) },
	{ "collisions", E1000_STAT(net_stats.collisions) },
	{ "collisions", E1000_STAT(stats.colc) },
	{ "rx_length_errors", E1000_STAT(net_stats.rx_length_errors) },
	{ "rx_length_errors", E1000_STAT(stats.rlerrc) },
	{ "rx_over_errors", E1000_STAT(net_stats.rx_over_errors) },
	{ "rx_over_errors", E1000_STAT(net_stats.rx_over_errors) },
	{ "rx_crc_errors", E1000_STAT(net_stats.rx_crc_errors) },
	{ "rx_crc_errors", E1000_STAT(stats.crcerrs) },
	{ "rx_frame_errors", E1000_STAT(net_stats.rx_frame_errors) },
	{ "rx_frame_errors", E1000_STAT(net_stats.rx_frame_errors) },
	{ "rx_no_buffer_count", E1000_STAT(stats.rnbc) },
	{ "rx_no_buffer_count", E1000_STAT(stats.rnbc) },
	{ "rx_missed_errors", E1000_STAT(net_stats.rx_missed_errors) },
	{ "rx_missed_errors", E1000_STAT(stats.mpc) },
	{ "tx_aborted_errors", E1000_STAT(net_stats.tx_aborted_errors) },
	{ "tx_aborted_errors", E1000_STAT(stats.ecol) },
	{ "tx_carrier_errors", E1000_STAT(net_stats.tx_carrier_errors) },
	{ "tx_carrier_errors", E1000_STAT(stats.tncrs) },
	{ "tx_fifo_errors", E1000_STAT(net_stats.tx_fifo_errors) },
	{ "tx_fifo_errors", E1000_STAT(net_stats.tx_fifo_errors) },
	{ "tx_heartbeat_errors", E1000_STAT(net_stats.tx_heartbeat_errors) },
	{ "tx_heartbeat_errors", E1000_STAT(net_stats.tx_heartbeat_errors) },
	{ "tx_window_errors", E1000_STAT(net_stats.tx_window_errors) },
	{ "tx_window_errors", E1000_STAT(stats.latecol) },
	{ "tx_abort_late_coll", E1000_STAT(stats.latecol) },
	{ "tx_abort_late_coll", E1000_STAT(stats.latecol) },
	{ "tx_deferred_ok", E1000_STAT(stats.dc) },
	{ "tx_deferred_ok", E1000_STAT(stats.dc) },
	{ "tx_single_coll_ok", E1000_STAT(stats.scc) },
	{ "tx_single_coll_ok", E1000_STAT(stats.scc) },
+3 −1
Original line number Original line Diff line number Diff line
@@ -1298,6 +1298,7 @@ struct e1000_hw_stats {
    uint64_t algnerrc;
    uint64_t algnerrc;
    uint64_t symerrs;
    uint64_t symerrs;
    uint64_t rxerrc;
    uint64_t rxerrc;
    uint64_t txerrc;
    uint64_t mpc;
    uint64_t mpc;
    uint64_t scc;
    uint64_t scc;
    uint64_t ecol;
    uint64_t ecol;
@@ -1330,8 +1331,9 @@ struct e1000_hw_stats {
    uint64_t gotch;
    uint64_t gotch;
    uint64_t rnbc;
    uint64_t rnbc;
    uint64_t ruc;
    uint64_t ruc;
    uint64_t rfc;
    uint64_t roc;
    uint64_t roc;
    uint64_t rlerrc;
    uint64_t rfc;
    uint64_t rjc;
    uint64_t rjc;
    uint64_t mgprc;
    uint64_t mgprc;
    uint64_t mgpdc;
    uint64_t mgpdc;
+4 −5
Original line number Original line Diff line number Diff line
@@ -3338,16 +3338,15 @@ e1000_update_stats(struct e1000_adapter *adapter)
		adapter->stats.crcerrs + adapter->stats.algnerrc +
		adapter->stats.crcerrs + adapter->stats.algnerrc +
		adapter->stats.ruc + adapter->stats.roc +
		adapter->stats.ruc + adapter->stats.roc +
		adapter->stats.cexterr;
		adapter->stats.cexterr;
	adapter->net_stats.rx_length_errors = adapter->stats.ruc +
	adapter->stats.rlerrc = adapter->stats.ruc + adapter->stats.roc;
	                                      adapter->stats.roc;
	adapter->net_stats.rx_length_errors = adapter->stats.rlerrc;
	adapter->net_stats.rx_crc_errors = adapter->stats.crcerrs;
	adapter->net_stats.rx_crc_errors = adapter->stats.crcerrs;
	adapter->net_stats.rx_frame_errors = adapter->stats.algnerrc;
	adapter->net_stats.rx_frame_errors = adapter->stats.algnerrc;
	adapter->net_stats.rx_missed_errors = adapter->stats.mpc;
	adapter->net_stats.rx_missed_errors = adapter->stats.mpc;


	/* Tx Errors */
	/* Tx Errors */

	adapter->stats.txerrc = adapter->stats.ecol + adapter->stats.latecol;
	adapter->net_stats.tx_errors = adapter->stats.ecol +
	adapter->net_stats.tx_errors = adapter->stats.txerrc;
	                               adapter->stats.latecol;
	adapter->net_stats.tx_aborted_errors = adapter->stats.ecol;
	adapter->net_stats.tx_aborted_errors = adapter->stats.ecol;
	adapter->net_stats.tx_window_errors = adapter->stats.latecol;
	adapter->net_stats.tx_window_errors = adapter->stats.latecol;
	adapter->net_stats.tx_carrier_errors = adapter->stats.tncrs;
	adapter->net_stats.tx_carrier_errors = adapter->stats.tncrs;