diff options
author | Jonathan Gray <jsg@cvs.openbsd.org> | 2016-07-09 04:25:45 +0000 |
---|---|---|
committer | Jonathan Gray <jsg@cvs.openbsd.org> | 2016-07-09 04:25:45 +0000 |
commit | 881335804aef9cdeadffcc0fb98e64b700f2d4f1 (patch) | |
tree | 0758a933ffc9dd0a4450bd2a4c31eb1f0de66ebe /sys/arch | |
parent | fce1c86b86a340e051b12a6ab998d1dd0e16b93d (diff) |
Use mac address and phy id from the fdt. Store settings for a second
port as well, though we still only handle a single port for now.
ok kettenis@
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/armv7/omap/if_cpsw.c | 71 |
1 files changed, 45 insertions, 26 deletions
diff --git a/sys/arch/armv7/omap/if_cpsw.c b/sys/arch/armv7/omap/if_cpsw.c index fd5c575af9e..8ec4d3e606e 100644 --- a/sys/arch/armv7/omap/if_cpsw.c +++ b/sys/arch/armv7/omap/if_cpsw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_cpsw.c,v 1.35 2016/06/26 09:06:35 jsg Exp $ */ +/* $OpenBSD: if_cpsw.c,v 1.36 2016/07/09 04:25:44 jsg Exp $ */ /* $NetBSD: if_cpsw.c,v 1.3 2013/04/17 14:36:34 bouyer Exp $ */ /* @@ -83,7 +83,6 @@ #include <dev/mii/miivar.h> #include <arch/armv7/armv7/armv7var.h> -#include <arch/armv7/omap/sitara_cm.h> #include <arch/armv7/omap/if_cpswreg.h> #include <dev/ofw/openfirm.h> @@ -119,6 +118,13 @@ struct cpsw_ring_data { struct mbuf *rx_mb[CPSW_NRXDESCS]; }; +struct cpsw_port_config { + uint8_t enaddr[ETHER_ADDR_LEN]; + int phy_id; + int rgmii; + int vlan; +}; + struct cpsw_softc { struct device sc_dev; bus_space_tag_t sc_bst; @@ -152,6 +158,8 @@ struct cpsw_softc { volatile bool sc_rxeoq; struct timeout sc_tick; int sc_active_port; + + struct cpsw_port_config sc_port_config[2]; }; #define DEVNAME(_sc) ((_sc)->sc_dev.dv_xname) @@ -180,7 +188,7 @@ int cpsw_rxintr(void *); int cpsw_txintr(void *); int cpsw_miscintr(void *); -void cpsw_get_mac_addr(struct cpsw_softc *); +void cpsw_get_port_config(struct cpsw_port_config *, int); struct cfattach cpsw_ca = { sizeof(struct cpsw_softc), @@ -270,27 +278,6 @@ cpsw_rxdesc_paddr(struct cpsw_softc * const sc, u_int x) return sc->sc_rxdescs_pa + sizeof(struct cpsw_cpdma_bd) * x; } -void -cpsw_get_mac_addr(struct cpsw_softc *sc) -{ - struct arpcom *ac = &sc->sc_ac; - u_int32_t mac_lo = 0, mac_hi = 0; - - sitara_cm_reg_read_4(OMAP2SCM_MAC_ID0_LO, &mac_lo); - sitara_cm_reg_read_4(OMAP2SCM_MAC_ID0_HI, &mac_hi); - - if ((mac_lo == 0) && (mac_hi == 0)) - printf("%s: invalid ethernet address\n", DEVNAME(sc)); - else { - ac->ac_enaddr[0] = (mac_hi >> 0) & 0xff; - ac->ac_enaddr[1] = (mac_hi >> 8) & 0xff; - ac->ac_enaddr[2] = (mac_hi >> 16) & 0xff; - ac->ac_enaddr[3] = (mac_hi >> 24) & 0xff; - ac->ac_enaddr[4] = (mac_lo >> 0) & 0xff; - ac->ac_enaddr[5] = (mac_lo >> 8) & 0xff; - } -} - static void cpsw_mdio_init(struct cpsw_softc *sc) { @@ -370,7 +357,9 @@ cpsw_attach(struct device *parent, struct device *self, void *aux) timeout_set(&sc->sc_tick, cpsw_tick, sc); - cpsw_get_mac_addr(sc); + cpsw_get_port_config(sc->sc_port_config, faa->fa_node); + memcpy(sc->sc_ac.ac_enaddr, sc->sc_port_config[0].enaddr, + ETHER_ADDR_LEN); sc->sc_rxthih = arm_intr_establish(intr[0], IPL_NET, cpsw_rxthintr, sc, DEVNAME(sc)); @@ -466,7 +455,7 @@ cpsw_attach(struct device *parent, struct device *self, void *aux) ifmedia_init(&sc->sc_mii.mii_media, 0, cpsw_mediachange, cpsw_mediastatus); mii_attach(self, &sc->sc_mii, 0xffffffff, - MII_PHY_ANY, MII_OFFSET_ANY, 0); + sc->sc_port_config[0].phy_id, MII_OFFSET_ANY, 0); if (LIST_FIRST(&sc->sc_mii.mii_phys) == NULL) { printf("no PHY found!\n"); ifmedia_add(&sc->sc_mii.mii_media, @@ -1283,3 +1272,33 @@ cpsw_miscintr(void *arg) return 1; } + +void +cpsw_get_port_config(struct cpsw_port_config *conf, int pnode) +{ + char mode[32]; + uint32_t phy_id[2]; + int node; + int port = 0; + + for (node = OF_child(pnode); node; node = OF_peer(node)) { + if (OF_getprop(node, "local-mac-address", conf[port].enaddr, + sizeof(conf[port].enaddr)) != sizeof(conf[port].enaddr)) + continue; + + conf[port].vlan = OF_getpropint(node, "dual_emac_res_vlan", 0); + + if (OF_getpropintarray(node, "phy_id", phy_id, + sizeof(phy_id)) == sizeof(phy_id)) + conf[port].phy_id = phy_id[1]; + + if (OF_getprop(node, "phy-mode", mode, sizeof(mode)) > 0 && + !strcmp(mode, "rgmii")) + conf[port].rgmii = 1; + else + conf[port].rgmii = 0; + + if (port == 0) + port = 1; + } +} |