From: Florian Fainelli <f.fainelli@gmail.com>
To: Petri Gynther <pgynther@google.com>, netdev@vger.kernel.org
Cc: davem@davemloft.net, jaedon.shin@gmail.com
Subject: Re: [PATCH net-next] net: bcmgenet: collect Rx discarded packet count
Date: Tue, 10 Mar 2015 12:43:47 -0700 [thread overview]
Message-ID: <54FF4973.30306@gmail.com> (raw)
In-Reply-To: <20150310191800.C5812220365@puck.mtv.corp.google.com>
On 10/03/15 12:18, Petri Gynther wrote:
> Bits 31:16 of RDMA_PROD_INDEX contain Rx discarded packet count, which
> are the Rx packets that had to be dropped by MAC hardware since there
> was no room on the Rx queue. Add code to collect this information into
> the netdev stats.
>
> Signed-off-by: Petri Gynther <pgynther@google.com>
> ---
> drivers/net/ethernet/broadcom/genet/bcmgenet.c | 10 ++++++++++
> 1 file changed, 10 insertions(+)
>
> diff --git a/drivers/net/ethernet/broadcom/genet/bcmgenet.c b/drivers/net/ethernet/broadcom/genet/bcmgenet.c
> index 275be56..7aa1834 100644
> --- a/drivers/net/ethernet/broadcom/genet/bcmgenet.c
> +++ b/drivers/net/ethernet/broadcom/genet/bcmgenet.c
> @@ -1384,9 +1384,19 @@ static unsigned int bcmgenet_desc_rx(struct bcmgenet_priv *priv,
> int len, err;
> unsigned int rxpktprocessed = 0, rxpkttoprocess;
> unsigned int p_index;
> + unsigned int discards;
> unsigned int chksum_ok = 0;
>
> p_index = bcmgenet_rdma_ring_readl(priv, index, RDMA_PROD_INDEX);
> +
> + discards = (p_index >> DMA_P_INDEX_DISCARD_CNT_SHIFT) &
> + DMA_P_INDEX_DISCARD_CNT_MASK;
> + if (discards > 0) {
> + bcmgenet_rdma_ring_writel(priv, index, 0, RDMA_PROD_INDEX);
This adds an expensive register write (~300ns on MIPS, ~200ns on ARM) in
the hot-path, and the counter saturation happens at 0xffff, which I
would prefer we deal with explicitly, even though that means missing a
bunch of discard events once we have already saturated, rather than
resetting this counter *and* the producer index for every NAPI round we
get called.
You could also deal with this counter in the ethtool gstats functions
and perform the saturation handle there, since this is a slow path already.
> + dev->stats.rx_missed_errors += discards;
> + dev->stats.rx_errors += discards;
> + }
> +
> p_index &= DMA_P_INDEX_MASK;
>
> if (likely(p_index >= ring->c_index))
>
--
Florian
next prev parent reply other threads:[~2015-03-10 19:44 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-03-10 19:18 [PATCH net-next] net: bcmgenet: collect Rx discarded packet count Petri Gynther
2015-03-10 19:43 ` Florian Fainelli [this message]
2015-03-10 20:52 ` Petri Gynther
2015-03-10 21:29 ` David Miller
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=54FF4973.30306@gmail.com \
--to=f.fainelli@gmail.com \
--cc=davem@davemloft.net \
--cc=jaedon.shin@gmail.com \
--cc=netdev@vger.kernel.org \
--cc=pgynther@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.