From: Jiajia Liu <liujia6264@gmail.com>
To: jesse.brandeburg@intel.com, anthony.l.nguyen@intel.com,
davem@davemloft.net, edumazet@google.com, kuba@kernel.org,
pabeni@redhat.com
Cc: intel-wired-lan@lists.osuosl.org, netdev@vger.kernel.org,
linux-kernel@vger.kernel.org, Jiajia Liu <liujia6264@gmail.com>
Subject: [PATCH] e1000e: Add ADP_I219_LM17 to ME S0ix blacklist
Date: Tue, 17 Jan 2023 10:26:46 +0000 [thread overview]
Message-ID: <20230117102645.24920-1-liujia6264@gmail.com> (raw)
I219 on HP EliteOne 840 All in One cannot work after s2idle resume
when the link speed is Gigabit, Wake-on-LAN is enabled and then set
the link down before suspend. No issue found when requesting driver
to configure S0ix. Add workround to let ADP_I219_LM17 use the dirver
configured S0ix.
Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=216926
Signed-off-by: Jiajia Liu <liujia6264@gmail.com>
---
It's regarding the bug above, it looks it's causued by the ME S0ix.
And is there a method to make the ME S0ix path work?
drivers/net/ethernet/intel/e1000e/netdev.c | 25 ++++++++++++++++++++++
1 file changed, 25 insertions(+)
diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c
index 04acd1a992fa..7ee759dbd09d 100644
--- a/drivers/net/ethernet/intel/e1000e/netdev.c
+++ b/drivers/net/ethernet/intel/e1000e/netdev.c
@@ -6330,6 +6330,23 @@ static void e1000e_flush_lpic(struct pci_dev *pdev)
pm_runtime_put_sync(netdev->dev.parent);
}
+static u16 me_s0ix_blacklist[] = {
+ E1000_DEV_ID_PCH_ADP_I219_LM17,
+ 0
+};
+
+static bool e1000e_check_me_s0ix_blacklist(const struct e1000_adapter *adapter)
+{
+ u16 *list;
+
+ for (list = me_s0ix_blacklist; *list; list++) {
+ if (*list == adapter->pdev->device)
+ return true;
+ }
+
+ return false;
+}
+
/* S0ix implementation */
static void e1000e_s0ix_entry_flow(struct e1000_adapter *adapter)
{
@@ -6337,6 +6354,9 @@ static void e1000e_s0ix_entry_flow(struct e1000_adapter *adapter)
u32 mac_data;
u16 phy_data;
+ if (e1000e_check_me_s0ix_blacklist(adapter))
+ goto req_driver;
+
if (er32(FWSM) & E1000_ICH_FWSM_FW_VALID &&
hw->mac.type >= e1000_pch_adp) {
/* Request ME configure the device for S0ix */
@@ -6346,6 +6366,7 @@ static void e1000e_s0ix_entry_flow(struct e1000_adapter *adapter)
trace_e1000e_trace_mac_register(mac_data);
ew32(H2ME, mac_data);
} else {
+req_driver:
/* Request driver configure the device to S0ix */
/* Disable the periodic inband message,
* don't request PCIe clock in K1 page770_17[10:9] = 10b
@@ -6488,6 +6509,9 @@ static void e1000e_s0ix_exit_flow(struct e1000_adapter *adapter)
u16 phy_data;
u32 i = 0;
+ if (e1000e_check_me_s0ix_blacklist(adapter))
+ goto req_driver;
+
if (er32(FWSM) & E1000_ICH_FWSM_FW_VALID &&
hw->mac.type >= e1000_pch_adp) {
/* Keep the GPT clock enabled for CSME */
@@ -6523,6 +6547,7 @@ static void e1000e_s0ix_exit_flow(struct e1000_adapter *adapter)
else
e_dbg("DPG_EXIT_DONE cleared after %d msec\n", i * 10);
} else {
+req_driver:
/* Request driver unconfigure the device from S0ix */
/* Disable the Dynamic Power Gating in the MAC */
--
2.30.2
next reply other threads:[~2023-01-17 10:27 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-01-17 10:26 Jiajia Liu [this message]
2023-01-17 19:34 ` [PATCH] e1000e: Add ADP_I219_LM17 to ME S0ix blacklist Jacob Keller
2023-01-18 5:20 ` [Intel-wired-lan] " Neftin, Sasha
2023-01-18 9:08 ` Jia Liu
2023-01-22 9:30 ` Neftin, Sasha
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=20230117102645.24920-1-liujia6264@gmail.com \
--to=liujia6264@gmail.com \
--cc=anthony.l.nguyen@intel.com \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=intel-wired-lan@lists.osuosl.org \
--cc=jesse.brandeburg@intel.com \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.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