Re: [PATCH 08/23] e1000: add multicast stats counters

2006-09-27 Thread Auke Kok

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 <[EMAIL PROTECTED]>

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

Signed-off-by: Mitch Williams <[EMAIL PROTECTED]>
Signed-off-by: Auke Kok <[EMAIL PROTECTED]>
---

 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.mp

Re: [PATCH 08/23] e1000: add multicast stats counters

2006-09-20 Thread Jeff Garzik

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


-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


RE: [PATCH 08/23] e1000: add multicast stats counters

2006-09-20 Thread cramerj
> 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
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH 08/23] e1000: add multicast stats counters

2006-09-20 Thread Jeff Garzik

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



-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH 08/23] e1000: add multicast stats counters

2006-09-20 Thread Williams, Mitch A
>> +{ "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

-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH 08/23] e1000: add multicast stats counters

2006-09-19 Thread Jeff Garzik

Kok, Auke wrote:

Signed-off-by: Mitch Williams <[EMAIL PROTECTED]>
Signed-off-by: Auke Kok <[EMAIL PROTECTED]>
---

 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



-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[PATCH 08/23] e1000: add multicast stats counters

2006-09-19 Thread Kok, Auke

Signed-off-by: Mitch Williams <[EMAIL PROTECTED]>
Signed-off-by: Auke Kok <[EMAIL PROTECTED]>
---

 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 <[EMAIL PROTECTED]>
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html