[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1362504410.2791.44.camel@bwh-desktop.uk.solarflarecom.com>
Date: Tue, 5 Mar 2013 17:26:50 +0000
From: Ben Hutchings <bhutchings@...arflare.com>
To: Eliezer Tamir <eliezer.tamir@...ux.jf.intel.com>
CC: <linux-kernel@...r.kernel.org>, <netdev@...r.kernel.org>,
Dave Miller <davem@...emloft.net>,
Jesse Brandeburg <jesse.brandeburg@...el.com>,
<e1000-devel@...ts.sourceforge.net>,
Willem de Bruijn <willemb@...gle.com>,
Andi Kleen <andi@...stfloor.org>, HPA <hpa@...or.com>,
Eliezer Tamir <eliezer@...ir.org.il>
Subject: Re: [RFC PATCH 3/5] ixgbe: Add support for ndo_ll_poll
On Wed, 2013-02-27 at 09:56 -0800, Eliezer Tamir wrote:
> Add the ixgbe driver code implementing ndo_ll_poll.
> It should be easy for other drivers to do something similar
> in order to enable support for CONFIG_INET_LL_RX_POLL
Yes... in fact I wonder whether the lock and state couldn't be added to
napi_struct instead of being driver-specific.
[...]
> --- a/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c
> +++ b/drivers/net/ethernet/intel/ixgbe/ixgbe_main.c
[...]
> static void ixgbe_napi_disable_all(struct ixgbe_adapter *adapter)
> {
> int q_idx;
>
> - for (q_idx = 0; q_idx < adapter->num_q_vectors; q_idx++)
> + local_bh_disable(); /* for ixgbe_qv_lock_napi() */
> + for (q_idx = 0; q_idx < adapter->num_q_vectors; q_idx++) {
> napi_disable(&adapter->q_vector[q_idx]->napi);
> + while (!ixgbe_qv_lock_napi(adapter->q_vector[q_idx])) {
> + pr_info("QV %d locked\n", q_idx);
> + msleep(1);
> + }
> + }
> + local_bh_enable();
> }
Sleeping with preemption disabled?
Ben.
--
Ben Hutchings, Staff Engineer, Solarflare
Not speaking for my employer; that's the marketing department's job.
They asked us to note that Solarflare product names are trademarked.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists