rk_gmac: clean up code for setting up clock delay lines a bit

- break long lines
- move toggle to enable it under a single #ifdef notyet

I've tested it and it works, but I'm keeping the #ifdef notyet for now
because it didn't solve the original problem I was debugging.
This commit is contained in:
tnn 2019-11-09 17:21:48 +00:00
parent 636ecf90f7
commit 7bd92a1a3d
1 changed files with 63 additions and 39 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: rk_gmac.c,v 1.14 2019/07/21 08:24:32 mrg Exp $ */
/* $NetBSD: rk_gmac.c,v 1.15 2019/11/09 17:21:48 tnn Exp $ */
/*-
* Copyright (c) 2018 Jared McNeill <jmcneill@invisible.ca>
@ -28,7 +28,7 @@
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: rk_gmac.c,v 1.14 2019/07/21 08:24:32 mrg Exp $");
__KERNEL_RCSID(0, "$NetBSD: rk_gmac.c,v 1.15 2019/11/09 17:21:48 tnn Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@ -90,7 +90,7 @@ struct rk_gmac_softc {
#define RK3328_GRF_MAC_CON1_TXDLY_EN __BIT(0)
static void
rk3328_gmac_set_mode_rgmii(struct dwc_gmac_softc *sc, u_int tx_delay, u_int rx_delay)
rk3328_gmac_set_mode_rgmii(struct dwc_gmac_softc *sc, u_int tx_delay, u_int rx_delay, bool set_delay)
{
struct rk_gmac_softc * const rk_sc = (struct rk_gmac_softc *)sc;
uint32_t write_mask, write_val;
@ -98,19 +98,30 @@ rk3328_gmac_set_mode_rgmii(struct dwc_gmac_softc *sc, u_int tx_delay, u_int rx_d
syscon_lock(rk_sc->sc_syscon);
write_mask = (RK3328_GRF_MAC_CON1_MODE | RK3328_GRF_MAC_CON1_SEL) << 16;
write_val = __SHIFTIN(RK3328_GRF_MAC_CON1_SEL_RGMII, RK3328_GRF_MAC_CON1_SEL);
syscon_write_4(rk_sc->sc_syscon, RK3328_GRF_MAC_CON1, write_mask | write_val);
write_val = __SHIFTIN(RK3328_GRF_MAC_CON1_SEL_RGMII,
RK3328_GRF_MAC_CON1_SEL);
syscon_write_4(rk_sc->sc_syscon, RK3328_GRF_MAC_CON1,
write_mask | write_val);
#if notyet
write_mask = (RK3328_GRF_MAC_CON0_TXDLY | RK3328_GRF_MAC_CON0_RXDLY) << 16;
write_val = __SHIFTIN(tx_delay, RK3328_GRF_MAC_CON0_TXDLY) |
if (set_delay) {
write_mask = (
RK3328_GRF_MAC_CON0_TXDLY |
RK3328_GRF_MAC_CON0_RXDLY) << 16;
write_val =
__SHIFTIN(tx_delay, RK3328_GRF_MAC_CON0_TXDLY) |
__SHIFTIN(rx_delay, RK3328_GRF_MAC_CON0_RXDLY);
syscon_write_4(rk_sc->sc_syscon, RK3328_GRF_MAC_CON0, write_mask | write_val);
syscon_write_4(rk_sc->sc_syscon, RK3328_GRF_MAC_CON0,
write_mask | write_val);
write_mask = (RK3328_GRF_MAC_CON1_RXDLY_EN | RK3328_GRF_MAC_CON1_TXDLY_EN) << 16;
write_val = RK3328_GRF_MAC_CON1_RXDLY_EN | RK3328_GRF_MAC_CON1_TXDLY_EN;
syscon_write_4(rk_sc->sc_syscon, RK3328_GRF_MAC_CON1, write_mask | write_val);
#endif
write_mask = (
RK3328_GRF_MAC_CON1_RXDLY_EN |
RK3328_GRF_MAC_CON1_TXDLY_EN) << 16;
write_val =
RK3328_GRF_MAC_CON1_RXDLY_EN |
RK3328_GRF_MAC_CON1_TXDLY_EN;
syscon_write_4(rk_sc->sc_syscon, RK3328_GRF_MAC_CON1,
write_mask | write_val);
}
syscon_unlock(rk_sc->sc_syscon);
}
@ -163,32 +174,34 @@ rk3328_gmac_set_speed_rgmii(struct dwc_gmac_softc *sc, int speed)
#define RK3399_GRF_SOC_CON6_GMAC_CLK_TX_DL_CFG __BITS(6,0)
static void
rk3399_gmac_set_mode_rgmii(struct dwc_gmac_softc *sc, u_int tx_delay, u_int rx_delay)
rk3399_gmac_set_mode_rgmii(struct dwc_gmac_softc *sc, u_int tx_delay,
u_int rx_delay, bool set_delay)
{
struct rk_gmac_softc * const rk_sc = (struct rk_gmac_softc *)sc;
const uint32_t con5_mask =
(RK3399_GRF_SOC_CON5_RMII_MODE | RK3399_GRF_SOC_CON5_GMAC_PHY_INTF_SEL) << 16;
const uint32_t con5 = __SHIFTIN(1, RK3399_GRF_SOC_CON5_GMAC_PHY_INTF_SEL);
#if notyet
const uint32_t con6_mask =
(RK3399_GRF_SOC_CON6_GMAC_RXCLK_DLY_ENA |
RK3399_GRF_SOC_CON6_GMAC_TXCLK_DLY_ENA |
RK3399_GRF_SOC_CON6_GMAC_CLK_RX_DL_CFG |
RK3399_GRF_SOC_CON6_GMAC_CLK_TX_DL_CFG) << 16;
const uint32_t con6 =
(tx_delay ? RK3399_GRF_SOC_CON6_GMAC_TXCLK_DLY_ENA : 0) |
(rx_delay ? RK3399_GRF_SOC_CON6_GMAC_RXCLK_DLY_ENA : 0) |
__SHIFTIN(rx_delay, RK3399_GRF_SOC_CON6_GMAC_CLK_RX_DL_CFG) |
__SHIFTIN(tx_delay, RK3399_GRF_SOC_CON6_GMAC_CLK_TX_DL_CFG);
#endif
uint32_t write_mask, write_val;
syscon_lock(rk_sc->sc_syscon);
syscon_write_4(rk_sc->sc_syscon, RK3399_GRF_SOC_CON5, con5 | con5_mask);
#if notyet
syscon_write_4(rk_sc->sc_syscon, RK3399_GRF_SOC_CON6, con6 | con6_mask);
#endif
write_mask = (
RK3399_GRF_SOC_CON5_RMII_MODE |
RK3399_GRF_SOC_CON5_GMAC_PHY_INTF_SEL) << 16;
write_val = __SHIFTIN(1, RK3399_GRF_SOC_CON5_GMAC_PHY_INTF_SEL);
syscon_write_4(rk_sc->sc_syscon, RK3399_GRF_SOC_CON5,
write_mask | write_val);
if (set_delay) {
write_mask = (
RK3399_GRF_SOC_CON6_GMAC_TXCLK_DLY_ENA |
RK3399_GRF_SOC_CON6_GMAC_RXCLK_DLY_ENA |
RK3399_GRF_SOC_CON6_GMAC_CLK_RX_DL_CFG |
RK3399_GRF_SOC_CON6_GMAC_CLK_TX_DL_CFG) << 16;
write_val =
(tx_delay ? RK3399_GRF_SOC_CON6_GMAC_TXCLK_DLY_ENA : 0) |
(rx_delay ? RK3399_GRF_SOC_CON6_GMAC_RXCLK_DLY_ENA : 0) |
__SHIFTIN(rx_delay, RK3399_GRF_SOC_CON6_GMAC_CLK_RX_DL_CFG) |
__SHIFTIN(tx_delay, RK3399_GRF_SOC_CON6_GMAC_CLK_TX_DL_CFG);
syscon_write_4(rk_sc->sc_syscon, RK3399_GRF_SOC_CON6,
write_mask | write_val);
}
syscon_unlock(rk_sc->sc_syscon);
}
@ -339,6 +352,11 @@ rk_gmac_attach(device_t parent, device_t self, void *aux)
bus_addr_t addr;
bus_size_t size;
u_int tx_delay, rx_delay;
#ifdef notyet
bool set_delay = true;
#else
bool set_delay = false;
#endif
if (fdtbus_get_reg(phandle, 0, &addr, &size) != 0) {
aprint_error(": couldn't get registers\n");
@ -353,11 +371,15 @@ rk_gmac_attach(device_t parent, device_t self, void *aux)
return;
}
if (of_getprop_uint32(phandle, "tx_delay", &tx_delay) != 0)
if (of_getprop_uint32(phandle, "tx_delay", &tx_delay) != 0) {
tx_delay = RK_GMAC_TXDLY_DEFAULT;
set_delay = false;
}
if (of_getprop_uint32(phandle, "rx_delay", &rx_delay) != 0)
if (of_getprop_uint32(phandle, "rx_delay", &rx_delay) != 0) {
rx_delay = RK_GMAC_RXDLY_DEFAULT;
set_delay = false;
}
sc->sc_dev = self;
sc->sc_bst = faa->faa_bst;
@ -395,7 +417,8 @@ rk_gmac_attach(device_t parent, device_t self, void *aux)
switch (rk_sc->sc_type) {
case GMAC_RK3328:
if (strcmp(phy_mode, "rgmii") == 0) {
rk3328_gmac_set_mode_rgmii(sc, tx_delay, rx_delay);
rk3328_gmac_set_mode_rgmii(sc, tx_delay, rx_delay,
set_delay);
sc->sc_set_speed = rk3328_gmac_set_speed_rgmii;
} else {
@ -405,7 +428,8 @@ rk_gmac_attach(device_t parent, device_t self, void *aux)
break;
case GMAC_RK3399:
if (strcmp(phy_mode, "rgmii") == 0) {
rk3399_gmac_set_mode_rgmii(sc, tx_delay, rx_delay);
rk3399_gmac_set_mode_rgmii(sc, tx_delay, rx_delay,
set_delay);
sc->sc_set_speed = rk3399_gmac_set_speed_rgmii;
} else {