mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-03 09:04:21 +08:00
r8169: remove support for chip version 60
Detection of this chip version has been disabled for few kernel versions now. Nobody complained, so remove support for this chip version. Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
133706a960
commit
efc37109c7
@ -64,7 +64,7 @@ enum mac_version {
|
||||
RTL_GIGA_MAC_VER_51,
|
||||
RTL_GIGA_MAC_VER_52,
|
||||
RTL_GIGA_MAC_VER_53,
|
||||
RTL_GIGA_MAC_VER_60,
|
||||
/* support for RTL_GIGA_MAC_VER_60 has been removed */
|
||||
RTL_GIGA_MAC_VER_61,
|
||||
RTL_GIGA_MAC_VER_63,
|
||||
RTL_GIGA_MAC_NONE
|
||||
|
@ -137,7 +137,6 @@ static const struct {
|
||||
[RTL_GIGA_MAC_VER_51] = {"RTL8168ep/8111ep" },
|
||||
[RTL_GIGA_MAC_VER_52] = {"RTL8168fp/RTL8117", FIRMWARE_8168FP_3},
|
||||
[RTL_GIGA_MAC_VER_53] = {"RTL8168fp/RTL8117", },
|
||||
[RTL_GIGA_MAC_VER_60] = {"RTL8125A" },
|
||||
[RTL_GIGA_MAC_VER_61] = {"RTL8125A", FIRMWARE_8125A_3},
|
||||
/* reserve 62 for CFG_METHOD_4 in the vendor driver */
|
||||
[RTL_GIGA_MAC_VER_63] = {"RTL8125B", FIRMWARE_8125B_2},
|
||||
@ -680,7 +679,7 @@ static void rtl_pci_commit(struct rtl8169_private *tp)
|
||||
|
||||
static bool rtl_is_8125(struct rtl8169_private *tp)
|
||||
{
|
||||
return tp->mac_version >= RTL_GIGA_MAC_VER_60;
|
||||
return tp->mac_version >= RTL_GIGA_MAC_VER_61;
|
||||
}
|
||||
|
||||
static bool rtl_is_8168evl_up(struct rtl8169_private *tp)
|
||||
@ -2258,7 +2257,7 @@ static void rtl_init_rxcfg(struct rtl8169_private *tp)
|
||||
case RTL_GIGA_MAC_VER_40 ... RTL_GIGA_MAC_VER_53:
|
||||
RTL_W32(tp, RxConfig, RX128_INT_EN | RX_MULTI_EN | RX_DMA_BURST | RX_EARLY_OFF);
|
||||
break;
|
||||
case RTL_GIGA_MAC_VER_60 ... RTL_GIGA_MAC_VER_63:
|
||||
case RTL_GIGA_MAC_VER_61 ... RTL_GIGA_MAC_VER_63:
|
||||
RTL_W32(tp, RxConfig, RX_FETCH_DFLT_8125 | RX_DMA_BURST);
|
||||
break;
|
||||
default:
|
||||
@ -2442,7 +2441,7 @@ static void rtl_wait_txrx_fifo_empty(struct rtl8169_private *tp)
|
||||
rtl_loop_wait_high(tp, &rtl_txcfg_empty_cond, 100, 42);
|
||||
rtl_loop_wait_high(tp, &rtl_rxtx_empty_cond, 100, 42);
|
||||
break;
|
||||
case RTL_GIGA_MAC_VER_60 ... RTL_GIGA_MAC_VER_61:
|
||||
case RTL_GIGA_MAC_VER_61 ... RTL_GIGA_MAC_VER_61:
|
||||
rtl_loop_wait_high(tp, &rtl_rxtx_empty_cond, 100, 42);
|
||||
break;
|
||||
case RTL_GIGA_MAC_VER_63:
|
||||
@ -2688,7 +2687,7 @@ static void rtl_hw_aspm_clkreq_enable(struct rtl8169_private *tp, bool enable)
|
||||
|
||||
switch (tp->mac_version) {
|
||||
case RTL_GIGA_MAC_VER_46 ... RTL_GIGA_MAC_VER_48:
|
||||
case RTL_GIGA_MAC_VER_60 ... RTL_GIGA_MAC_VER_63:
|
||||
case RTL_GIGA_MAC_VER_61 ... RTL_GIGA_MAC_VER_63:
|
||||
/* reset ephy tx/rx disable timer */
|
||||
r8168_mac_ocp_modify(tp, 0xe094, 0xff00, 0);
|
||||
/* chip can trigger L1.2 */
|
||||
@ -2700,7 +2699,7 @@ static void rtl_hw_aspm_clkreq_enable(struct rtl8169_private *tp, bool enable)
|
||||
} else {
|
||||
switch (tp->mac_version) {
|
||||
case RTL_GIGA_MAC_VER_46 ... RTL_GIGA_MAC_VER_48:
|
||||
case RTL_GIGA_MAC_VER_60 ... RTL_GIGA_MAC_VER_63:
|
||||
case RTL_GIGA_MAC_VER_61 ... RTL_GIGA_MAC_VER_63:
|
||||
r8168_mac_ocp_modify(tp, 0xe092, 0x00ff, 0);
|
||||
break;
|
||||
default:
|
||||
@ -3573,46 +3572,6 @@ static void rtl_hw_start_8125_common(struct rtl8169_private *tp)
|
||||
udelay(10);
|
||||
}
|
||||
|
||||
static void rtl_hw_start_8125a_1(struct rtl8169_private *tp)
|
||||
{
|
||||
static const struct ephy_info e_info_8125a_1[] = {
|
||||
{ 0x01, 0xffff, 0xa812 },
|
||||
{ 0x09, 0xffff, 0x520c },
|
||||
{ 0x04, 0xffff, 0xd000 },
|
||||
{ 0x0d, 0xffff, 0xf702 },
|
||||
{ 0x0a, 0xffff, 0x8653 },
|
||||
{ 0x06, 0xffff, 0x001e },
|
||||
{ 0x08, 0xffff, 0x3595 },
|
||||
{ 0x20, 0xffff, 0x9455 },
|
||||
{ 0x21, 0xffff, 0x99ff },
|
||||
{ 0x02, 0xffff, 0x6046 },
|
||||
{ 0x29, 0xffff, 0xfe00 },
|
||||
{ 0x23, 0xffff, 0xab62 },
|
||||
|
||||
{ 0x41, 0xffff, 0xa80c },
|
||||
{ 0x49, 0xffff, 0x520c },
|
||||
{ 0x44, 0xffff, 0xd000 },
|
||||
{ 0x4d, 0xffff, 0xf702 },
|
||||
{ 0x4a, 0xffff, 0x8653 },
|
||||
{ 0x46, 0xffff, 0x001e },
|
||||
{ 0x48, 0xffff, 0x3595 },
|
||||
{ 0x60, 0xffff, 0x9455 },
|
||||
{ 0x61, 0xffff, 0x99ff },
|
||||
{ 0x42, 0xffff, 0x6046 },
|
||||
{ 0x69, 0xffff, 0xfe00 },
|
||||
{ 0x63, 0xffff, 0xab62 },
|
||||
};
|
||||
|
||||
rtl_set_def_aspm_entry_latency(tp);
|
||||
|
||||
/* disable aspm and clock request before access ephy */
|
||||
rtl_hw_aspm_clkreq_enable(tp, false);
|
||||
rtl_ephy_init(tp, e_info_8125a_1);
|
||||
|
||||
rtl_hw_start_8125_common(tp);
|
||||
rtl_hw_aspm_clkreq_enable(tp, true);
|
||||
}
|
||||
|
||||
static void rtl_hw_start_8125a_2(struct rtl8169_private *tp)
|
||||
{
|
||||
static const struct ephy_info e_info_8125a_2[] = {
|
||||
@ -3704,7 +3663,6 @@ static void rtl_hw_config(struct rtl8169_private *tp)
|
||||
[RTL_GIGA_MAC_VER_51] = rtl_hw_start_8168ep_3,
|
||||
[RTL_GIGA_MAC_VER_52] = rtl_hw_start_8117,
|
||||
[RTL_GIGA_MAC_VER_53] = rtl_hw_start_8117,
|
||||
[RTL_GIGA_MAC_VER_60] = rtl_hw_start_8125a_1,
|
||||
[RTL_GIGA_MAC_VER_61] = rtl_hw_start_8125a_2,
|
||||
[RTL_GIGA_MAC_VER_63] = rtl_hw_start_8125b,
|
||||
};
|
||||
@ -4099,7 +4057,6 @@ static unsigned int rtl_quirk_packet_padto(struct rtl8169_private *tp,
|
||||
|
||||
switch (tp->mac_version) {
|
||||
case RTL_GIGA_MAC_VER_34:
|
||||
case RTL_GIGA_MAC_VER_60:
|
||||
case RTL_GIGA_MAC_VER_61:
|
||||
case RTL_GIGA_MAC_VER_63:
|
||||
padto = max_t(unsigned int, padto, ETH_ZLEN);
|
||||
@ -5143,7 +5100,7 @@ static void rtl_hw_initialize(struct rtl8169_private *tp)
|
||||
case RTL_GIGA_MAC_VER_40 ... RTL_GIGA_MAC_VER_48:
|
||||
rtl_hw_init_8168g(tp);
|
||||
break;
|
||||
case RTL_GIGA_MAC_VER_60 ... RTL_GIGA_MAC_VER_63:
|
||||
case RTL_GIGA_MAC_VER_61 ... RTL_GIGA_MAC_VER_63:
|
||||
rtl_hw_init_8125(tp);
|
||||
break;
|
||||
default:
|
||||
@ -5234,7 +5191,7 @@ done:
|
||||
/* register is set if system vendor successfully tested ASPM 1.2 */
|
||||
static bool rtl_aspm_is_safe(struct rtl8169_private *tp)
|
||||
{
|
||||
if (tp->mac_version >= RTL_GIGA_MAC_VER_60 &&
|
||||
if (tp->mac_version >= RTL_GIGA_MAC_VER_61 &&
|
||||
r8168_mac_ocp_read(tp, 0xc0b2) & 0xf)
|
||||
return true;
|
||||
|
||||
|
@ -995,44 +995,6 @@ static void rtl8125_legacy_force_mode(struct phy_device *phydev)
|
||||
phy_modify_paged(phydev, 0xa5b, 0x12, BIT(15), 0);
|
||||
}
|
||||
|
||||
static void rtl8125a_1_hw_phy_config(struct rtl8169_private *tp,
|
||||
struct phy_device *phydev)
|
||||
{
|
||||
phy_modify_paged(phydev, 0xad4, 0x10, 0x03ff, 0x0084);
|
||||
phy_modify_paged(phydev, 0xad4, 0x17, 0x0000, 0x0010);
|
||||
phy_modify_paged(phydev, 0xad1, 0x13, 0x03ff, 0x0006);
|
||||
phy_modify_paged(phydev, 0xad3, 0x11, 0x003f, 0x0006);
|
||||
phy_modify_paged(phydev, 0xac0, 0x14, 0x0000, 0x1100);
|
||||
phy_modify_paged(phydev, 0xac8, 0x15, 0xf000, 0x7000);
|
||||
phy_modify_paged(phydev, 0xad1, 0x14, 0x0000, 0x0400);
|
||||
phy_modify_paged(phydev, 0xad1, 0x15, 0x0000, 0x03ff);
|
||||
phy_modify_paged(phydev, 0xad1, 0x16, 0x0000, 0x03ff);
|
||||
|
||||
r8168g_phy_param(phydev, 0x80ea, 0xff00, 0xc400);
|
||||
r8168g_phy_param(phydev, 0x80eb, 0x0700, 0x0300);
|
||||
r8168g_phy_param(phydev, 0x80f8, 0xff00, 0x1c00);
|
||||
r8168g_phy_param(phydev, 0x80f1, 0xff00, 0x3000);
|
||||
r8168g_phy_param(phydev, 0x80fe, 0xff00, 0xa500);
|
||||
r8168g_phy_param(phydev, 0x8102, 0xff00, 0x5000);
|
||||
r8168g_phy_param(phydev, 0x8105, 0xff00, 0x3300);
|
||||
r8168g_phy_param(phydev, 0x8100, 0xff00, 0x7000);
|
||||
r8168g_phy_param(phydev, 0x8104, 0xff00, 0xf000);
|
||||
r8168g_phy_param(phydev, 0x8106, 0xff00, 0x6500);
|
||||
r8168g_phy_param(phydev, 0x80dc, 0xff00, 0xed00);
|
||||
r8168g_phy_param(phydev, 0x80df, 0x0000, 0x0100);
|
||||
r8168g_phy_param(phydev, 0x80e1, 0x0100, 0x0000);
|
||||
|
||||
phy_modify_paged(phydev, 0xbf0, 0x13, 0x003f, 0x0038);
|
||||
r8168g_phy_param(phydev, 0x819f, 0xffff, 0xd0b6);
|
||||
|
||||
phy_write_paged(phydev, 0xbc3, 0x12, 0x5555);
|
||||
phy_modify_paged(phydev, 0xbf0, 0x15, 0x0e00, 0x0a00);
|
||||
phy_modify_paged(phydev, 0xa5c, 0x10, 0x0400, 0x0000);
|
||||
rtl8168g_enable_gphy_10m(phydev);
|
||||
|
||||
rtl8125a_config_eee_phy(phydev);
|
||||
}
|
||||
|
||||
static void rtl8125a_2_hw_phy_config(struct rtl8169_private *tp,
|
||||
struct phy_device *phydev)
|
||||
{
|
||||
@ -1188,7 +1150,6 @@ void r8169_hw_phy_config(struct rtl8169_private *tp, struct phy_device *phydev,
|
||||
[RTL_GIGA_MAC_VER_51] = rtl8168ep_2_hw_phy_config,
|
||||
[RTL_GIGA_MAC_VER_52] = rtl8117_hw_phy_config,
|
||||
[RTL_GIGA_MAC_VER_53] = rtl8117_hw_phy_config,
|
||||
[RTL_GIGA_MAC_VER_60] = rtl8125a_1_hw_phy_config,
|
||||
[RTL_GIGA_MAC_VER_61] = rtl8125a_2_hw_phy_config,
|
||||
[RTL_GIGA_MAC_VER_63] = rtl8125b_hw_phy_config,
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user