Commit a46604d7 authored by Heiner Kallweit's avatar Heiner Kallweit Committed by Jakub Kicinski

r8169: improve rtl_ocp_reg_failure

Use WARN_ONCE here to get a call trace in case of a problem.
This facilitates finding the offending code part.
Signed-off-by: default avatarHeiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 5f1e1224
...@@ -812,14 +812,9 @@ static void rtl_eri_clear_bits(struct rtl8169_private *tp, int addr, u32 m) ...@@ -812,14 +812,9 @@ static void rtl_eri_clear_bits(struct rtl8169_private *tp, int addr, u32 m)
rtl_w0w1_eri(tp, addr, 0, m); rtl_w0w1_eri(tp, addr, 0, m);
} }
static bool rtl_ocp_reg_failure(struct rtl8169_private *tp, u32 reg) static bool rtl_ocp_reg_failure(u32 reg)
{ {
if (reg & 0xffff0001) { return WARN_ONCE(reg & 0xffff0001, "Invalid ocp reg %x!\n", reg);
if (net_ratelimit())
netdev_err(tp->dev, "Invalid ocp reg %x!\n", reg);
return true;
}
return false;
} }
DECLARE_RTL_COND(rtl_ocp_gphy_cond) DECLARE_RTL_COND(rtl_ocp_gphy_cond)
...@@ -829,7 +824,7 @@ DECLARE_RTL_COND(rtl_ocp_gphy_cond) ...@@ -829,7 +824,7 @@ DECLARE_RTL_COND(rtl_ocp_gphy_cond)
static void r8168_phy_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data) static void r8168_phy_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data)
{ {
if (rtl_ocp_reg_failure(tp, reg)) if (rtl_ocp_reg_failure(reg))
return; return;
RTL_W32(tp, GPHY_OCP, OCPAR_FLAG | (reg << 15) | data); RTL_W32(tp, GPHY_OCP, OCPAR_FLAG | (reg << 15) | data);
...@@ -839,7 +834,7 @@ static void r8168_phy_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data) ...@@ -839,7 +834,7 @@ static void r8168_phy_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data)
static int r8168_phy_ocp_read(struct rtl8169_private *tp, u32 reg) static int r8168_phy_ocp_read(struct rtl8169_private *tp, u32 reg)
{ {
if (rtl_ocp_reg_failure(tp, reg)) if (rtl_ocp_reg_failure(reg))
return 0; return 0;
RTL_W32(tp, GPHY_OCP, reg << 15); RTL_W32(tp, GPHY_OCP, reg << 15);
...@@ -850,7 +845,7 @@ static int r8168_phy_ocp_read(struct rtl8169_private *tp, u32 reg) ...@@ -850,7 +845,7 @@ static int r8168_phy_ocp_read(struct rtl8169_private *tp, u32 reg)
static void r8168_mac_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data) static void r8168_mac_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data)
{ {
if (rtl_ocp_reg_failure(tp, reg)) if (rtl_ocp_reg_failure(reg))
return; return;
RTL_W32(tp, OCPDR, OCPAR_FLAG | (reg << 15) | data); RTL_W32(tp, OCPDR, OCPAR_FLAG | (reg << 15) | data);
...@@ -858,7 +853,7 @@ static void r8168_mac_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data) ...@@ -858,7 +853,7 @@ static void r8168_mac_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data)
static u16 r8168_mac_ocp_read(struct rtl8169_private *tp, u32 reg) static u16 r8168_mac_ocp_read(struct rtl8169_private *tp, u32 reg)
{ {
if (rtl_ocp_reg_failure(tp, reg)) if (rtl_ocp_reg_failure(reg))
return 0; return 0;
RTL_W32(tp, OCPDR, reg << 15); RTL_W32(tp, OCPDR, reg << 15);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment