netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
To: David Decotigny <david.decotigny@google.com>
Cc: "Brandeburg, Jesse" <jesse.brandeburg@intel.com>,
	"Allan, Bruce W" <bruce.w.allan@intel.com>,
	"Wyborny, Carolyn" <carolyn.wyborny@intel.com>,
	"Skidmore, Donald C" <donald.c.skidmore@intel.com>,
	"Rose, Gregory V" <gregory.v.rose@intel.com>,
	"Waskiewicz Jr, Peter P" <peter.p.waskiewicz.jr@intel.com>,
	"Duyck, Alexander H" <alexander.h.duyck@intel.com>,
	"Ronciak, John" <john.ronciak@intel.com>,
	"e1000-devel@lists.sourceforge.net"
	<e1000-devel@lists.sourceforge.net>,
	"netdev@vger.kernel.org" <netdev@vger.kernel.org>,
	"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
	Paul Gortmaker <paul.gortmaker@windriver.com>,
	Ying Cai <ycai@google.com>
Subject: Re: [PATCH FIX net v2] net-e1000(e): Fix default interrupt throttle rate not set in NIC HW
Date: Wed, 16 Nov 2011 20:02:12 -0800	[thread overview]
Message-ID: <1321502533.2304.24.camel@jtkirshe-mobl> (raw)
In-Reply-To: <75e944ced8ad7c58a0b838c0fe2a9e315f9e0c37.1321494268.git.david.decotigny@google.com>

[-- Attachment #1: Type: text/plain, Size: 8357 bytes --]

On Wed, 2011-11-16 at 17:46 -0800, David Decotigny wrote:
> From: Ying Cai <ycai@google.com>
> 
> This change ensures that the itr/itr_setting adjustment logic is used,
> even for the default/compiled-in value.
> 
> Context:
>   When we changed the default InterruptThrottleRate value from default
>   (3 = dynamic mode) to 8000 for example, only adapter->itr_setting
>   (which controls interrupt coalescing mode) was set to 8000, but
>   adapter->itr (which controls the value set in NIC register) was not
>   updated accordingly. So from ethtool, it seemed the interrupt
>   throttling is enabled at 8000 intr/s, but the NIC actually was
>   running in dynamic mode which has lower CPU efficiency especially
>   when throughput is not high.
> 
> 
> 
> Signed-off-by: David Decotigny <david.decotigny@google.com>
> ---
>  drivers/net/ethernet/intel/e1000/e1000_param.c |   81 +++++++++++--------
>  drivers/net/ethernet/intel/e1000e/param.c      |   98 +++++++++++++-----------
>  2 files changed, 99 insertions(+), 80 deletions(-)
> 
> diff --git a/drivers/net/ethernet/intel/e1000/e1000_param.c b/drivers/net/ethernet/intel/e1000/e1000_param.c
> index 1301eba..595e462 100644
> --- a/drivers/net/ethernet/intel/e1000/e1000_param.c
> +++ b/drivers/net/ethernet/intel/e1000/e1000_param.c
> @@ -173,7 +173,7 @@ E1000_PARAM(RxAbsIntDelay, "Receive Absolute Interrupt Delay");
>  
>  /* Interrupt Throttle Rate (interrupts/sec)
>   *
> - * Valid Range: 100-100000 (0=off, 1=dynamic, 3=dynamic conservative)
> + * Valid Range: 100-100000 or one of: 0=off, 1=dynamic, 3=dynamic conservative
>   */
>  E1000_PARAM(InterruptThrottleRate, "Interrupt Throttling Rate");
>  #define DEFAULT_ITR                    3
> @@ -460,41 +460,54 @@ void __devinit e1000_check_options(struct e1000_adapter *adapter)
>  		};
>  
>  		if (num_InterruptThrottleRate > bd) {
> -			adapter->itr = InterruptThrottleRate[bd];
> -			switch (adapter->itr) {
> -			case 0:
> -				e_dev_info("%s turned off\n", opt.name);
> -				break;
> -			case 1:
> -				e_dev_info("%s set to dynamic mode\n",
> -					   opt.name);
> -				adapter->itr_setting = adapter->itr;
> -				adapter->itr = 20000;
> -				break;
> -			case 3:
> -				e_dev_info("%s set to dynamic conservative "
> -					   "mode\n", opt.name);
> -				adapter->itr_setting = adapter->itr;
> -				adapter->itr = 20000;
> -				break;
> -			case 4:
> -				e_dev_info("%s set to simplified "
> -				           "(2000-8000) ints mode\n", opt.name);
> -				adapter->itr_setting = adapter->itr;
> -				break;
> -			default:
> -				e1000_validate_option(&adapter->itr, &opt,
> -				        adapter);
> -				/* save the setting, because the dynamic bits
> -				 * change itr.
> -				 * clear the lower two bits because they are
> -				 * used as control */
> -				adapter->itr_setting = adapter->itr & ~3;
> -				break;
> -			}
> +			/* Make sure a message is printed for
> +			 * non-special values. And in case of an
> +			 * invalid option, display warning, use
> +			 * default and go through itr/itr_setting
> +			 * adjustment logic below */
> +			if ((adapter->itr < 0 || adapter->itr > 4)
> +			    && e1000_validate_option(&adapter->itr, &opt,
> +						     adapter))
> +				adapter->itr = opt.def;
>  		} else {
> -			adapter->itr_setting = opt.def;
> +			/* if no option specified, use default value
> +			   and go through the logic below to adjust
> +			   itr/itr_setting */
> +			adapter->itr = opt.def;
> +
> +			/* Make sure a message is printed for
> +			 * non-special default values */
> +			if (adapter->itr < 0 || adapter->itr > 4)
> +				e_dev_info("%s set to default %d\n",
> +					   opt.name, adapter->itr);
> +		}
> +
> +		adapter->itr_setting = adapter->itr;
> +		switch (adapter->itr) {
> +		case 0:
> +			e_dev_info("%s turned off\n", opt.name);
> +			break;
> +		case 1:
> +			e_dev_info("%s set to dynamic mode\n",
> +				   opt.name);
> +			adapter->itr = 20000;
> +			break;
> +		case 3:
> +			e_dev_info("%s set to dynamic conservative "
> +				   "mode\n", opt.name);
>  			adapter->itr = 20000;
> +			break;
> +		case 4:
> +			e_dev_info("%s set to simplified "
> +				   "(2000-8000) ints mode\n", opt.name);
> +			break;
> +		default:
> +			/* save the setting, because the dynamic bits
> +			 * change itr.
> +			 * clear the lower two bits because they are
> +			 * used as control */
> +			adapter->itr_setting &= ~3;
> +			break;
>  		}
>  	}
>  	{ /* Smart Power Down */
> diff --git a/drivers/net/ethernet/intel/e1000e/param.c b/drivers/net/ethernet/intel/e1000e/param.c
> index 20e93b0..41937e5 100644
> --- a/drivers/net/ethernet/intel/e1000e/param.c
> +++ b/drivers/net/ethernet/intel/e1000e/param.c
> @@ -106,7 +106,7 @@ E1000_PARAM(RxAbsIntDelay, "Receive Absolute Interrupt Delay");
>  /*
>   * Interrupt Throttle Rate (interrupts/sec)
>   *
> - * Valid Range: 100-100000 (0=off, 1=dynamic, 3=dynamic conservative)
> + * Valid Range: 100-100000 or one of: 0=off, 1=dynamic, 3=dynamic conservative
>   */
>  E1000_PARAM(InterruptThrottleRate, "Interrupt Throttling Rate");
>  #define DEFAULT_ITR 3
> @@ -335,53 +335,59 @@ void __devinit e1000e_check_options(struct e1000_adapter *adapter)
>  
>  		if (num_InterruptThrottleRate > bd) {
>  			adapter->itr = InterruptThrottleRate[bd];
> -			switch (adapter->itr) {
> -			case 0:
> -				e_info("%s turned off\n", opt.name);
> -				break;
> -			case 1:
> -				e_info("%s set to dynamic mode\n", opt.name);
> -				adapter->itr_setting = adapter->itr;
> -				adapter->itr = 20000;
> -				break;
> -			case 3:
> -				e_info("%s set to dynamic conservative mode\n",
> -					opt.name);
> -				adapter->itr_setting = adapter->itr;
> -				adapter->itr = 20000;
> -				break;
> -			case 4:
> -				e_info("%s set to simplified (2000-8000 ints) "
> -				       "mode\n", opt.name);
> -				adapter->itr_setting = 4;
> -				break;
> -			default:
> -				/*
> -				 * Save the setting, because the dynamic bits
> -				 * change itr.
> -				 */
> -				if (e1000_validate_option(&adapter->itr, &opt,
> -							  adapter) &&
> -				    (adapter->itr == 3)) {
> -					/*
> -					 * In case of invalid user value,
> -					 * default to conservative mode.
> -					 */
> -					adapter->itr_setting = adapter->itr;
> -					adapter->itr = 20000;
> -				} else {
> -					/*
> -					 * Clear the lower two bits because
> -					 * they are used as control.
> -					 */
> -					adapter->itr_setting =
> -						adapter->itr & ~3;
> -				}
> -				break;
> -			}
> +
> +			/* Make sure a message is printed for
> +			 * non-special values. And in case of an
> +			 * invalid option, display warning, use
> +			 * default and go through itr/itr_setting
> +			 * adjustment logic below */
> +			if ((adapter->itr < 0 || adapter->itr > 4)
> +			    && e1000_validate_option(&adapter->itr, &opt,
> +						     adapter))
> +				adapter->itr = opt.def;
>  		} else {
> -			adapter->itr_setting = opt.def;
> +			/* if no option specified, use default value
> +			   and go through the logic below to adjust
> +			   itr/itr_setting */
> +			adapter->itr = opt.def;
> +
> +			/* Make sure a message is printed for
> +			 * non-special default values */
> +			if (adapter->itr < 0 || adapter->itr > 4)
> +				e_info("%s set to default %d\n",
> +				       opt.name, adapter->itr);
> +		}
> +
> +
> +
> +		adapter->itr_setting = adapter->itr;
> +		switch (adapter->itr) {
> +		case 0:
> +			e_info("%s turned off\n", opt.name);
> +			break;
> +		case 1:
> +			e_info("%s set to dynamic mode\n", opt.name);
> +			adapter->itr = 20000;
> +			break;
> +		case 3:
> +			e_info("%s set to dynamic conservative mode\n",
> +			       opt.name);
>  			adapter->itr = 20000;
> +			break;
> +		case 4:
> +			e_info("%s set to simplified (2000-8000 ints) "
> +			       "mode\n", opt.name);
> +			break;
> +		default:
> +			/*
> +			 * Save the setting, because the dynamic bits
> +			 * change itr.
> +			 *
> +			 * Clear the lower two bits because
> +			 * they are used as control.
> +			 */
> +			adapter->itr_setting &= ~3;
> +			break;
>  		}
>  	}
>  	{ /* Interrupt Mode */

Thanks David, I have added this to my e1000e queue of patches.

[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 836 bytes --]

      parent reply	other threads:[~2011-11-17  4:02 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <cover.1321494268.git.david.decotigny@google.com>
2011-11-17  1:46 ` [PATCH FIX net v2] net-e1000(e): Fix default interrupt throttle rate not set in NIC HW David Decotigny
     [not found] ` <75e944ced8ad7c58a0b838c0fe2a9e315f9e0c37.1321494268.git.david.decotigny@google.com>
2011-11-17  4:02   ` Jeff Kirsher [this message]

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=1321502533.2304.24.camel@jtkirshe-mobl \
    --to=jeffrey.t.kirsher@intel.com \
    --cc=alexander.h.duyck@intel.com \
    --cc=bruce.w.allan@intel.com \
    --cc=carolyn.wyborny@intel.com \
    --cc=david.decotigny@google.com \
    --cc=donald.c.skidmore@intel.com \
    --cc=e1000-devel@lists.sourceforge.net \
    --cc=gregory.v.rose@intel.com \
    --cc=jesse.brandeburg@intel.com \
    --cc=john.ronciak@intel.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=netdev@vger.kernel.org \
    --cc=paul.gortmaker@windriver.com \
    --cc=peter.p.waskiewicz.jr@intel.com \
    --cc=ycai@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 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).