* [PATCH 08/23] e1000: add multicast stats counters
2006-09-19 17:26 [PATCH 00/23] e100, e1000, ixgb updates Kok, Auke
@ 2006-09-19 17:28 ` Kok, Auke
2006-09-19 19:28 ` Jeff Garzik
0 siblings, 1 reply; 7+ messages in thread
From: Kok, Auke @ 2006-09-19 17:28 UTC (permalink / raw)
To: Garzik, Jeff
Cc: netdev, Brandeburg, Jesse, Kok, Auke, Kok, Auke, Ronciak, John
Signed-off-by: Mitch Williams <mitch.a.williams@intel.com>
Signed-off-by: Auke Kok <auke-jan.h.kok@intel.com>
---
drivers/net/e1000/e1000_ethtool.c | 4 ++++
1 files changed, 4 insertions(+), 0 deletions(-)
diff --git a/drivers/net/e1000/e1000_ethtool.c b/drivers/net/e1000/e1000_ethtool.c
index a954746..0d329d6 100644
--- a/drivers/net/e1000/e1000_ethtool.c
+++ b/drivers/net/e1000/e1000_ethtool.c
@@ -60,6 +60,10 @@ static const struct e1000_stats e1000_gs
{ "tx_packets", E1000_STAT(net_stats.tx_packets) },
{ "rx_bytes", E1000_STAT(net_stats.rx_bytes) },
{ "tx_bytes", E1000_STAT(net_stats.tx_bytes) },
+ { "rx_broadcast", E1000_STAT(stats.bprc) },
+ { "tx_broadcast", E1000_STAT(stats.bptc) },
+ { "rx_multicast", E1000_STAT(stats.mprc) },
+ { "tx_multicast", E1000_STAT(stats.mptc) },
{ "rx_errors", E1000_STAT(net_stats.rx_errors) },
{ "tx_errors", E1000_STAT(net_stats.tx_errors) },
{ "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
---
Auke Kok <auke-jan.h.kok@intel.com>
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH 08/23] e1000: add multicast stats counters
2006-09-19 17:28 ` [PATCH 08/23] e1000: add multicast stats counters Kok, Auke
@ 2006-09-19 19:28 ` Jeff Garzik
0 siblings, 0 replies; 7+ messages in thread
From: Jeff Garzik @ 2006-09-19 19:28 UTC (permalink / raw)
To: Kok, Auke; +Cc: netdev, Brandeburg, Jesse, Kok, Auke, Ronciak, John
Kok, Auke wrote:
> Signed-off-by: Mitch Williams <mitch.a.williams@intel.com>
> Signed-off-by: Auke Kok <auke-jan.h.kok@intel.com>
> ---
>
> drivers/net/e1000/e1000_ethtool.c | 4 ++++
> 1 files changed, 4 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/net/e1000/e1000_ethtool.c b/drivers/net/e1000/e1000_ethtool.c
> index a954746..0d329d6 100644
> --- a/drivers/net/e1000/e1000_ethtool.c
> +++ b/drivers/net/e1000/e1000_ethtool.c
> @@ -60,6 +60,10 @@ static const struct e1000_stats e1000_gs
> { "tx_packets", E1000_STAT(net_stats.tx_packets) },
> { "rx_bytes", E1000_STAT(net_stats.rx_bytes) },
> { "tx_bytes", E1000_STAT(net_stats.tx_bytes) },
> + { "rx_broadcast", E1000_STAT(stats.bprc) },
> + { "tx_broadcast", E1000_STAT(stats.bptc) },
> + { "rx_multicast", E1000_STAT(stats.mprc) },
> + { "tx_multicast", E1000_STAT(stats.mptc) },
> { "rx_errors", E1000_STAT(net_stats.rx_errors) },
> { "tx_errors", E1000_STAT(net_stats.tx_errors) },
> { "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
NAK -- you also need to remove the standard net stats, which are
exported elsewhere
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 08/23] e1000: add multicast stats counters
@ 2006-09-20 16:38 Williams, Mitch A
2006-09-20 19:22 ` Jeff Garzik
0 siblings, 1 reply; 7+ messages in thread
From: Williams, Mitch A @ 2006-09-20 16:38 UTC (permalink / raw)
To: netdev, Jeff Garzik; +Cc: Kok, Auke-jan H, Brandeburg, Jesse, Ronciak, John
>> + { "rx_broadcast", E1000_STAT(stats.bprc) },
>> + { "tx_broadcast", E1000_STAT(stats.bptc) },
>> + { "rx_multicast", E1000_STAT(stats.mprc) },
>> + { "tx_multicast", E1000_STAT(stats.mptc) },
>> { "rx_errors", E1000_STAT(net_stats.rx_errors) },
>> { "tx_errors", E1000_STAT(net_stats.tx_errors) },
>> { "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
>
>NAK -- you also need to remove the standard net stats, which are
>exported elsewhere
Jeff, can you please explain the reason for this NAK a little more?
Neither Auke nor I understand why you rejected the patch.
This patch just adds the display of a few more stats in Ethtool. It
doesn't affect any other counters, and is really just a convenience
feature. I added this to the driver because of a customer request.
Thank you in advance for edifying us.
-Mitch
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 08/23] e1000: add multicast stats counters
2006-09-20 16:38 [PATCH 08/23] e1000: add multicast stats counters Williams, Mitch A
@ 2006-09-20 19:22 ` Jeff Garzik
0 siblings, 0 replies; 7+ messages in thread
From: Jeff Garzik @ 2006-09-20 19:22 UTC (permalink / raw)
To: Williams, Mitch A
Cc: netdev, Kok, Auke-jan H, Brandeburg, Jesse, Ronciak, John
Williams, Mitch A wrote:
>>> + { "rx_broadcast", E1000_STAT(stats.bprc) },
>>> + { "tx_broadcast", E1000_STAT(stats.bptc) },
>>> + { "rx_multicast", E1000_STAT(stats.mprc) },
>>> + { "tx_multicast", E1000_STAT(stats.mptc) },
>>> { "rx_errors", E1000_STAT(net_stats.rx_errors) },
>>> { "tx_errors", E1000_STAT(net_stats.tx_errors) },
>>> { "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
>> NAK -- you also need to remove the standard net stats, which are
>> exported elsewhere
>
> Jeff, can you please explain the reason for this NAK a little more?
> Neither Auke nor I understand why you rejected the patch.
>
> This patch just adds the display of a few more stats in Ethtool. It
> doesn't affect any other counters, and is really just a convenience
> feature. I added this to the driver because of a customer request.
Adding those stats is fine. You guys just need to remove the existing
mess first.
Jeff
^ permalink raw reply [flat|nested] 7+ messages in thread
* RE: [PATCH 08/23] e1000: add multicast stats counters
@ 2006-09-20 23:50 cramerj
2006-09-21 0:47 ` Jeff Garzik
0 siblings, 1 reply; 7+ messages in thread
From: cramerj @ 2006-09-20 23:50 UTC (permalink / raw)
To: Jeff Garzik, Williams, Mitch A
Cc: netdev, Kok, Auke-jan H, Brandeburg, Jesse, Ronciak, John
> Williams, Mitch A wrote:
> >>> + { "rx_broadcast", E1000_STAT(stats.bprc) },
> >>> + { "tx_broadcast", E1000_STAT(stats.bptc) },
> >>> + { "rx_multicast", E1000_STAT(stats.mprc) },
> >>> + { "tx_multicast", E1000_STAT(stats.mptc) },
> >>> { "rx_errors", E1000_STAT(net_stats.rx_errors) },
> >>> { "tx_errors", E1000_STAT(net_stats.tx_errors) },
> >>> { "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
> >> NAK -- you also need to remove the standard net stats, which are
> >> exported elsewhere
> >
> > Jeff, can you please explain the reason for this NAK a little more?
> > Neither Auke nor I understand why you rejected the patch.
> >
> > This patch just adds the display of a few more stats in Ethtool. It
> > doesn't affect any other counters, and is really just a convenience
> > feature. I added this to the driver because of a customer request.
>
> Adding those stats is fine. You guys just need to remove the existing
> mess first.
>
> Jeff
>
Since we have 1-to-1 mapping of some of our statistics registers to the
net_stats, we could s/net_stats/stats/. However, there are a few
net_stats (e.g. net_stats.rx_errors) that encapsulate more than one
e1000 statistic register of which we don't have a private stat member
defined.
For those statistics, is it really necessary to add another stat
structure just to rm "net_stats" from that list we pass to ethtool? At
best, it would look something like this...
{ "foo_count", E1000_STAT(stats.foo) },
- { "rx_errors", E1000_STAT(net_stats.rx_errors) },
+ { "rx_errors", E1000_STAT(eth_stats.rx_errors) },
{ "bar_count", E1000_STAT(stats.bar) },
If so, well, OK. I'm just scratching my head as to why it's a "mess"
as-is.
I've missed obvious alternatives before; care to enlighten?
-Jeb
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 08/23] e1000: add multicast stats counters
2006-09-20 23:50 cramerj
@ 2006-09-21 0:47 ` Jeff Garzik
2006-09-27 20:09 ` Auke Kok
0 siblings, 1 reply; 7+ messages in thread
From: Jeff Garzik @ 2006-09-21 0:47 UTC (permalink / raw)
To: cramerj
Cc: Williams, Mitch A, netdev, Kok, Auke-jan H, Brandeburg, Jesse,
Ronciak, John
cramerj wrote:
>> Williams, Mitch A wrote:
>>>>> + { "rx_broadcast", E1000_STAT(stats.bprc) },
>>>>> + { "tx_broadcast", E1000_STAT(stats.bptc) },
>>>>> + { "rx_multicast", E1000_STAT(stats.mprc) },
>>>>> + { "tx_multicast", E1000_STAT(stats.mptc) },
>>>>> { "rx_errors", E1000_STAT(net_stats.rx_errors) },
>>>>> { "tx_errors", E1000_STAT(net_stats.tx_errors) },
>>>>> { "tx_dropped", E1000_STAT(net_stats.tx_dropped) },
>>>> NAK -- you also need to remove the standard net stats, which are
>>>> exported elsewhere
>>> Jeff, can you please explain the reason for this NAK a little more?
>>> Neither Auke nor I understand why you rejected the patch.
>>> This patch just adds the display of a few more stats in Ethtool. It
>>> doesn't affect any other counters, and is really just a convenience
>>> feature. I added this to the driver because of a customer request.
>> Adding those stats is fine. You guys just need to remove the existing
>> mess first.
> Since we have 1-to-1 mapping of some of our statistics registers to the
> net_stats, we could s/net_stats/stats/. However, there are a few
> net_stats (e.g. net_stats.rx_errors) that encapsulate more than one
> e1000 statistic register of which we don't have a private stat member
> defined.
>
> For those statistics, is it really necessary to add another stat
> structure just to rm "net_stats" from that list we pass to ethtool? At
> best, it would look something like this...
>
> { "foo_count", E1000_STAT(stats.foo) },
> - { "rx_errors", E1000_STAT(net_stats.rx_errors) },
> + { "rx_errors", E1000_STAT(eth_stats.rx_errors) },
> { "bar_count", E1000_STAT(stats.bar) },
>
> If so, well, OK. I'm just scratching my head as to why it's a "mess"
> as-is.
The ethtool get-stats sub ioctl has _always_ been for exporting _only_
NIC-private statistics.
So, no, there is no inherent connection between adding multicast stats
and removing ones that should have never been in the list. But if I
don't put my foot down, this will never get corrected.
Jeff
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 08/23] e1000: add multicast stats counters
2006-09-21 0:47 ` Jeff Garzik
@ 2006-09-27 20:09 ` Auke Kok
0 siblings, 0 replies; 7+ messages in thread
From: Auke Kok @ 2006-09-27 20:09 UTC (permalink / raw)
To: Jeff Garzik
Cc: cramerj, Williams, Mitch A, netdev, Brandeburg, Jesse,
Ronciak, John
Jeff Garzik wrote:
> cramerj wrote:
>>> Williams, Mitch A wrote:
>>>>>> + { "rx_broadcast", E1000_STAT(stats.bprc) }, + {
>>>>>> "tx_broadcast", E1000_STAT(stats.bptc) }, + { "rx_multicast",
>>>>>> E1000_STAT(stats.mprc) }, + { "tx_multicast",
>>>>>> E1000_STAT(stats.mptc) }, { "rx_errors",
>>>>>> E1000_STAT(net_stats.rx_errors) }, { "tx_errors",
>>>>>> E1000_STAT(net_stats.tx_errors) }, { "tx_dropped",
>>>>>> E1000_STAT(net_stats.tx_dropped) },
>>>>> NAK -- you also need to remove the standard net stats, which are
>>>>> exported elsewhere
>>>> Jeff, can you please explain the reason for this NAK a little more?
>>>> Neither Auke nor I understand why you rejected the patch.
>
>>>> This patch just adds the display of a few more stats in Ethtool. It
>>>> doesn't affect any other counters, and is really just a convenience
>>>> feature. I added this to the driver because of a customer request.
>>> Adding those stats is fine. You guys just need to remove the existing
>>> mess first.
>
>> Since we have 1-to-1 mapping of some of our statistics registers to the
>> net_stats, we could s/net_stats/stats/. However, there are a few
>> net_stats (e.g. net_stats.rx_errors) that encapsulate more than one e1000
>> statistic register of which we don't have a private stat member defined.
>>
>> For those statistics, is it really necessary to add another stat structure
>> just to rm "net_stats" from that list we pass to ethtool? At best, it
>> would look something like this...
>>
>> { "foo_count", E1000_STAT(stats.foo) }, - { "rx_errors",
>> E1000_STAT(net_stats.rx_errors) }, + { "rx_errors",
>> E1000_STAT(eth_stats.rx_errors) }, { "bar_count", E1000_STAT(stats.bar) },
>>
>>
>> If so, well, OK. I'm just scratching my head as to why it's a "mess"
>> as-is.
>
> The ethtool get-stats sub ioctl has _always_ been for exporting _only_
> NIC-private statistics.
>
> So, no, there is no inherent connection between adding multicast stats and
> removing ones that should have never been in the list. But if I don't put
> my foot down, this will never get corrected.
okay, here's my offer - we fix it as much as we can. I realize that it may not
be enough but I doubt that removeing stats makes people happy. I suggest that
we take one step in the right direction and another one later if we must.
this is in my queue.
Auke
---
e1000: add multicast stats counters
From: Mitch Williams <mitch.a.williams@intel.com>
Add 4 multicast and broadcast hardware counters (rx/tx), and eliminate
as many non-hardware counters as possible.
Signed-off-by: Mitch Williams <mitch.a.williams@intel.com>
Signed-off-by: Auke Kok <auke-jan.h.kok@intel.com>
---
drivers/net/e1000/e1000_ethtool.c | 32 ++++++++++++++++++--------------
drivers/net/e1000/e1000_hw.h | 4 +++-
drivers/net/e1000/e1000_main.c | 9 ++++-----
3 files changed, 25 insertions(+), 20 deletions(-)
diff --git a/drivers/net/e1000/e1000_ethtool.c /drivers/net/e1000/e1000_ethtool.c
index 858c14d..9791b8a 100644
--- a/drivers/net/e1000/e1000_ethtool.c
+++ b/drivers/net/e1000/e1000_ethtool.c
@@ -56,26 +56,30 @@ struct e1000_stats {
#define E1000_STAT(m) sizeof(((struct e1000_adapter *)0)->m), \
offsetof(struct e1000_adapter, m)
static const struct e1000_stats e1000_gstrings_stats[] = {
- { "rx_packets", E1000_STAT(net_stats.rx_packets) },
- { "tx_packets", E1000_STAT(net_stats.tx_packets) },
- { "rx_bytes", E1000_STAT(net_stats.rx_bytes) },
- { "tx_bytes", E1000_STAT(net_stats.tx_bytes) },
- { "rx_errors", E1000_STAT(net_stats.rx_errors) },
- { "tx_errors", E1000_STAT(net_stats.tx_errors) },
+ { "rx_packets", E1000_STAT(stats.gprc) },
+ { "tx_packets", E1000_STAT(stats.gptc) },
+ { "rx_bytes", E1000_STAT(stats.gorcl) },
+ { "tx_bytes", E1000_STAT(stats.gotcl) },
+ { "rx_broadcast", E1000_STAT(stats.bprc) },
+ { "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) },
- { "multicast", E1000_STAT(net_stats.multicast) },
- { "collisions", E1000_STAT(net_stats.collisions) },
- { "rx_length_errors", E1000_STAT(net_stats.rx_length_errors) },
+ { "multicast", E1000_STAT(stats.mprc) },
+ { "collisions", E1000_STAT(stats.colc) },
+ { "rx_length_errors", E1000_STAT(stats.rlerrc) },
{ "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_no_buffer_count", E1000_STAT(stats.rnbc) },
- { "rx_missed_errors", E1000_STAT(net_stats.rx_missed_errors) },
- { "tx_aborted_errors", E1000_STAT(net_stats.tx_aborted_errors) },
- { "tx_carrier_errors", E1000_STAT(net_stats.tx_carrier_errors) },
+ { "rx_missed_errors", E1000_STAT(stats.mpc) },
+ { "tx_aborted_errors", E1000_STAT(stats.ecol) },
+ { "tx_carrier_errors", E1000_STAT(stats.tncrs) },
{ "tx_fifo_errors", E1000_STAT(net_stats.tx_fifo_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_deferred_ok", E1000_STAT(stats.dc) },
{ "tx_single_coll_ok", E1000_STAT(stats.scc) },
diff --git a/drivers/net/e1000/e1000_hw.h b/drivers/net/e1000/e1000_hw.h
index 47f34f2..113344e 100644
--- a/drivers/net/e1000/e1000_hw.h
+++ b/drivers/net/e1000/e1000_hw.h
@@ -1298,6 +1298,7 @@ struct e1000_hw_stats {
uint64_t algnerrc;
uint64_t symerrs;
uint64_t rxerrc;
+ uint64_t txerrc;
uint64_t mpc;
uint64_t scc;
uint64_t ecol;
@@ -1330,8 +1331,9 @@ struct e1000_hw_stats {
uint64_t gotch;
uint64_t rnbc;
uint64_t ruc;
- uint64_t rfc;
uint64_t roc;
+ uint64_t rlerrc;
+ uint64_t rfc;
uint64_t rjc;
uint64_t mgprc;
uint64_t mgpdc;
diff --git a/drivers/net/e1000/e1000_main.c b/drivers/net/e1000/e1000_main.c
index 447b7c8..5296a82 100644
--- a/drivers/net/e1000/e1000_main.c
+++ b/drivers/net/e1000/e1000_main.c
@@ -3338,16 +3338,15 @@ #define PHY_IDLE_ERROR_COUNT_MASK 0x00FF
adapter->stats.crcerrs + adapter->stats.algnerrc +
adapter->stats.ruc + adapter->stats.roc +
adapter->stats.cexterr;
- adapter->net_stats.rx_length_errors = adapter->stats.ruc +
- adapter->stats.roc;
+ adapter->stats.rlerrc = adapter->stats.ruc + 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_frame_errors = adapter->stats.algnerrc;
adapter->net_stats.rx_missed_errors = adapter->stats.mpc;
/* Tx Errors */
-
- adapter->net_stats.tx_errors = adapter->stats.ecol +
- adapter->stats.latecol;
+ adapter->stats.txerrc = adapter->stats.ecol + adapter->stats.latecol;
+ adapter->net_stats.tx_errors = adapter->stats.txerrc;
adapter->net_stats.tx_aborted_errors = adapter->stats.ecol;
adapter->net_stats.tx_window_errors = adapter->stats.latecol;
^ permalink raw reply related [flat|nested] 7+ messages in thread
end of thread, other threads:[~2006-09-27 20:11 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-09-20 16:38 [PATCH 08/23] e1000: add multicast stats counters Williams, Mitch A
2006-09-20 19:22 ` Jeff Garzik
-- strict thread matches above, loose matches on Subject: below --
2006-09-20 23:50 cramerj
2006-09-21 0:47 ` Jeff Garzik
2006-09-27 20:09 ` Auke Kok
2006-09-19 17:26 [PATCH 00/23] e100, e1000, ixgb updates Kok, Auke
2006-09-19 17:28 ` [PATCH 08/23] e1000: add multicast stats counters Kok, Auke
2006-09-19 19:28 ` Jeff Garzik
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).