Convert from local code and constants for mac<->phy connection type to new
common fdt helper code.
This commit is contained in:
parent
23bb804c65
commit
580634b30b
@ -84,6 +84,7 @@ __FBSDID("$FreeBSD$");
|
|||||||
#include <dev/ofw/ofw_bus_subr.h>
|
#include <dev/ofw/ofw_bus_subr.h>
|
||||||
#include <dev/mii/mii.h>
|
#include <dev/mii/mii.h>
|
||||||
#include <dev/mii/miivar.h>
|
#include <dev/mii/miivar.h>
|
||||||
|
#include <dev/mii/mii_fdt.h>
|
||||||
#include "miibus_if.h"
|
#include "miibus_if.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -135,13 +136,6 @@ struct ffec_bufmap {
|
|||||||
bus_dmamap_t map;
|
bus_dmamap_t map;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
|
||||||
PHY_CONN_UNKNOWN,
|
|
||||||
PHY_CONN_MII,
|
|
||||||
PHY_CONN_RMII,
|
|
||||||
PHY_CONN_RGMII
|
|
||||||
};
|
|
||||||
|
|
||||||
struct ffec_softc {
|
struct ffec_softc {
|
||||||
device_t dev;
|
device_t dev;
|
||||||
device_t miibus;
|
device_t miibus;
|
||||||
@ -153,7 +147,7 @@ struct ffec_softc {
|
|||||||
struct resource *mem_res;
|
struct resource *mem_res;
|
||||||
void * intr_cookie;
|
void * intr_cookie;
|
||||||
struct callout ffec_callout;
|
struct callout ffec_callout;
|
||||||
uint8_t phy_conn_type;
|
mii_contype_t phy_conn_type;
|
||||||
uint8_t fectype;
|
uint8_t fectype;
|
||||||
boolean_t link_is_up;
|
boolean_t link_is_up;
|
||||||
boolean_t is_attached;
|
boolean_t is_attached;
|
||||||
@ -262,10 +256,10 @@ ffec_miigasket_setup(struct ffec_softc *sc)
|
|||||||
|
|
||||||
switch (sc->phy_conn_type)
|
switch (sc->phy_conn_type)
|
||||||
{
|
{
|
||||||
case PHY_CONN_MII:
|
case MII_CONTYPE_MII:
|
||||||
ifmode = 0;
|
ifmode = 0;
|
||||||
break;
|
break;
|
||||||
case PHY_CONN_RMII:
|
case MII_CONTYPE_RMII:
|
||||||
ifmode = FEC_MIIGSK_CFGR_IF_MODE_RMII;
|
ifmode = FEC_MIIGSK_CFGR_IF_MODE_RMII;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -377,14 +371,17 @@ ffec_miibus_statchg(device_t dev)
|
|||||||
|
|
||||||
rcr |= FEC_RCR_MII_MODE; /* Must always be on even for R[G]MII. */
|
rcr |= FEC_RCR_MII_MODE; /* Must always be on even for R[G]MII. */
|
||||||
switch (sc->phy_conn_type) {
|
switch (sc->phy_conn_type) {
|
||||||
case PHY_CONN_MII:
|
case MII_CONTYPE_RMII:
|
||||||
break;
|
|
||||||
case PHY_CONN_RMII:
|
|
||||||
rcr |= FEC_RCR_RMII_MODE;
|
rcr |= FEC_RCR_RMII_MODE;
|
||||||
break;
|
break;
|
||||||
case PHY_CONN_RGMII:
|
case MII_CONTYPE_RGMII:
|
||||||
|
case MII_CONTYPE_RGMII_ID:
|
||||||
|
case MII_CONTYPE_RGMII_RXID:
|
||||||
|
case MII_CONTYPE_RGMII_TXID:
|
||||||
rcr |= FEC_RCR_RGMII_EN;
|
rcr |= FEC_RCR_RGMII_EN;
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (IFM_SUBTYPE(mii->mii_media_active)) {
|
switch (IFM_SUBTYPE(mii->mii_media_active)) {
|
||||||
@ -1440,7 +1437,6 @@ ffec_attach(device_t dev)
|
|||||||
phandle_t ofw_node;
|
phandle_t ofw_node;
|
||||||
int error, phynum, rid;
|
int error, phynum, rid;
|
||||||
uint8_t eaddr[ETHER_ADDR_LEN];
|
uint8_t eaddr[ETHER_ADDR_LEN];
|
||||||
char phy_conn_name[32];
|
|
||||||
uint32_t idx, mscr;
|
uint32_t idx, mscr;
|
||||||
|
|
||||||
sc = device_get_softc(dev);
|
sc = device_get_softc(dev);
|
||||||
@ -1463,16 +1459,8 @@ ffec_attach(device_t dev)
|
|||||||
error = ENXIO;
|
error = ENXIO;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
if (OF_searchprop(ofw_node, "phy-mode",
|
sc->phy_conn_type = mii_fdt_get_contype(ofw_node);
|
||||||
phy_conn_name, sizeof(phy_conn_name)) != -1) {
|
if (sc->phy_conn_type == MII_CONTYPE_UNKNOWN) {
|
||||||
if (strcasecmp(phy_conn_name, "mii") == 0)
|
|
||||||
sc->phy_conn_type = PHY_CONN_MII;
|
|
||||||
else if (strcasecmp(phy_conn_name, "rmii") == 0)
|
|
||||||
sc->phy_conn_type = PHY_CONN_RMII;
|
|
||||||
else if (strcasecmp(phy_conn_name, "rgmii") == 0)
|
|
||||||
sc->phy_conn_type = PHY_CONN_RGMII;
|
|
||||||
}
|
|
||||||
if (sc->phy_conn_type == PHY_CONN_UNKNOWN) {
|
|
||||||
device_printf(sc->dev, "No valid 'phy-mode' "
|
device_printf(sc->dev, "No valid 'phy-mode' "
|
||||||
"property found in FDT data for device.\n");
|
"property found in FDT data for device.\n");
|
||||||
error = ENOATTR;
|
error = ENOATTR;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user