* [PATCH FIX net v2] net-e1000(e): Fix default interrupt throttle rate not set in NIC HW
[not found] <cover.1321494268.git.david.decotigny@google.com>
@ 2011-11-17 1:46 ` David Decotigny
[not found] ` <75e944ced8ad7c58a0b838c0fe2a9e315f9e0c37.1321494268.git.david.decotigny@google.com>
1 sibling, 0 replies; 2+ messages in thread
From: David Decotigny @ 2011-11-17 1:46 UTC (permalink / raw)
To: Jeff Kirsher, Jesse Brandeburg, Bruce Allan, Carolyn Wyborny,
Don
Cc: Paul Gortmaker, David Decotigny, Ying Cai
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 */
--
1.7.3.1
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH FIX net v2] net-e1000(e): Fix default interrupt throttle rate not set in NIC HW
[not found] ` <75e944ced8ad7c58a0b838c0fe2a9e315f9e0c37.1321494268.git.david.decotigny@google.com>
@ 2011-11-17 4:02 ` Jeff Kirsher
0 siblings, 0 replies; 2+ messages in thread
From: Jeff Kirsher @ 2011-11-17 4:02 UTC (permalink / raw)
To: David Decotigny
Cc: Brandeburg, Jesse, Allan, Bruce W, Wyborny, Carolyn,
Skidmore, Donald C, Rose, Gregory V, Waskiewicz Jr, Peter P,
Duyck, Alexander H, Ronciak, John,
e1000-devel@lists.sourceforge.net, netdev@vger.kernel.org,
linux-kernel@vger.kernel.org, Paul Gortmaker, Ying Cai
[-- 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 --]
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2011-11-17 4:02 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[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 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).