Commit fb02eb4a authored by hayeswang's avatar hayeswang Committed by David S. Miller

r8152: support the new RTL8153 chip

Support the new USB gigabit ethernet.
Signed-off-by: default avatarHayes Wang <hayeswang@realtek.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent de18547d
...@@ -622,6 +622,7 @@ enum rtl_version { ...@@ -622,6 +622,7 @@ enum rtl_version {
RTL_VER_03, RTL_VER_03,
RTL_VER_04, RTL_VER_04,
RTL_VER_05, RTL_VER_05,
RTL_VER_06,
RTL_VER_MAX RTL_VER_MAX
}; };
...@@ -2560,7 +2561,10 @@ static void r8153_hw_phy_cfg(struct r8152 *tp) ...@@ -2560,7 +2561,10 @@ static void r8153_hw_phy_cfg(struct r8152 *tp)
u32 ocp_data; u32 ocp_data;
u16 data; u16 data;
if (tp->version == RTL_VER_03 || tp->version == RTL_VER_04 ||
tp->version == RTL_VER_05)
ocp_reg_write(tp, OCP_ADC_CFG, CKADSEL_L | ADC_EN | EN_EMI_L); ocp_reg_write(tp, OCP_ADC_CFG, CKADSEL_L | ADC_EN | EN_EMI_L);
data = r8152_mdio_read(tp, MII_BMCR); data = r8152_mdio_read(tp, MII_BMCR);
if (data & BMCR_PDOWN) { if (data & BMCR_PDOWN) {
data &= ~BMCR_PDOWN; data &= ~BMCR_PDOWN;
...@@ -3268,6 +3272,13 @@ static void r8153_init(struct r8152 *tp) ...@@ -3268,6 +3272,13 @@ static void r8153_init(struct r8152 *tp)
ocp_data &= ~ECM_ALDPS; ocp_data &= ~ECM_ALDPS;
ocp_write_byte(tp, MCU_TYPE_PLA, PLA_DMY_REG0, ocp_data); ocp_write_byte(tp, MCU_TYPE_PLA, PLA_DMY_REG0, ocp_data);
ocp_data = ocp_read_byte(tp, MCU_TYPE_USB, USB_CSR_DUMMY1);
if (ocp_read_word(tp, MCU_TYPE_USB, USB_BURST_SIZE) == 0)
ocp_data &= ~DYNAMIC_BURST;
else
ocp_data |= DYNAMIC_BURST;
ocp_write_byte(tp, MCU_TYPE_USB, USB_CSR_DUMMY1, ocp_data);
} else if (tp->version == RTL_VER_06) {
ocp_data = ocp_read_byte(tp, MCU_TYPE_USB, USB_CSR_DUMMY1); ocp_data = ocp_read_byte(tp, MCU_TYPE_USB, USB_CSR_DUMMY1);
if (ocp_read_word(tp, MCU_TYPE_USB, USB_BURST_SIZE) == 0) if (ocp_read_word(tp, MCU_TYPE_USB, USB_BURST_SIZE) == 0)
ocp_data &= ~DYNAMIC_BURST; ocp_data &= ~DYNAMIC_BURST;
...@@ -3908,6 +3919,10 @@ static void r8152b_get_version(struct r8152 *tp) ...@@ -3908,6 +3919,10 @@ static void r8152b_get_version(struct r8152 *tp)
tp->version = RTL_VER_05; tp->version = RTL_VER_05;
tp->mii.supports_gmii = 1; tp->mii.supports_gmii = 1;
break; break;
case 0x5c30:
tp->version = RTL_VER_06;
tp->mii.supports_gmii = 1;
break;
default: default:
netif_info(tp, probe, tp->netdev, netif_info(tp, probe, tp->netdev,
"Unknown version 0x%04x\n", version); "Unknown version 0x%04x\n", version);
...@@ -3953,6 +3968,7 @@ static int rtl_ops_init(struct r8152 *tp) ...@@ -3953,6 +3968,7 @@ static int rtl_ops_init(struct r8152 *tp)
case RTL_VER_03: case RTL_VER_03:
case RTL_VER_04: case RTL_VER_04:
case RTL_VER_05: case RTL_VER_05:
case RTL_VER_06:
ops->init = r8153_init; ops->init = r8153_init;
ops->enable = rtl8153_enable; ops->enable = rtl8153_enable;
ops->disable = rtl8153_disable; ops->disable = rtl8153_disable;
......
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