netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [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 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 [PATCH 08/23] e1000: add multicast stats counters 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 23:50 [PATCH 08/23] e1000: add multicast stats counters cramerj
2006-09-21  0:47 ` Jeff Garzik
2006-09-27 20:09   ` Auke Kok
  -- strict thread matches above, loose matches on Subject: below --
2006-09-20 16:38 Williams, Mitch A
2006-09-20 19:22 ` Jeff Garzik
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).