mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-03-21 06:31:31 +00:00
NET: QE: UEC: Make uec_miiphy_read() and uec_miiphy_write() use the devname arg.
The current uec_miiphy_read and uec_miiphy_write hardcode access devlist[0] This patch makes these function use the devname argument that is passed in to allow access to the phy registers of other devices in devlist[]. Signed-of-by: Richard Retanubun <RichardRetanubun@RugggedCom.com> Signed-off-by: Ben Warren <biggerbadderben@gmail.com>
This commit is contained in:
parent
44dcb73320
commit
0115b19537
1 changed files with 43 additions and 3 deletions
|
@ -685,6 +685,31 @@ static void phy_change(struct eth_device *dev)
|
||||||
#if defined(CONFIG_MII) || defined(CONFIG_CMD_MII) \
|
#if defined(CONFIG_MII) || defined(CONFIG_CMD_MII) \
|
||||||
&& !defined(BITBANGMII)
|
&& !defined(BITBANGMII)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Find a device index from the devlist by name
|
||||||
|
*
|
||||||
|
* Returns:
|
||||||
|
* The index where the device is located, -1 on error
|
||||||
|
*/
|
||||||
|
static int uec_miiphy_find_dev_by_name(char *devname)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < MAXCONTROLLERS; i++) {
|
||||||
|
if (strncmp(devname, devlist[i]->name, strlen(devname)) == 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If device cannot be found, returns -1 */
|
||||||
|
if (i == MAXCONTROLLERS) {
|
||||||
|
debug ("%s: device %s not found in devlist\n", __FUNCTION__, devname);
|
||||||
|
i = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Read a MII PHY register.
|
* Read a MII PHY register.
|
||||||
*
|
*
|
||||||
|
@ -694,8 +719,16 @@ static void phy_change(struct eth_device *dev)
|
||||||
static int uec_miiphy_read(char *devname, unsigned char addr,
|
static int uec_miiphy_read(char *devname, unsigned char addr,
|
||||||
unsigned char reg, unsigned short *value)
|
unsigned char reg, unsigned short *value)
|
||||||
{
|
{
|
||||||
*value = uec_read_phy_reg(devlist[0], addr, reg);
|
int devindex = 0;
|
||||||
|
|
||||||
|
if (devname == NULL || value == NULL) {
|
||||||
|
debug("%s: NULL pointer given\n", __FUNCTION__);
|
||||||
|
} else {
|
||||||
|
devindex = uec_miiphy_find_dev_by_name(devname);
|
||||||
|
if (devindex >= 0) {
|
||||||
|
*value = uec_read_phy_reg(devlist[devindex], addr, reg);
|
||||||
|
}
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -708,11 +741,18 @@ static int uec_miiphy_read(char *devname, unsigned char addr,
|
||||||
static int uec_miiphy_write(char *devname, unsigned char addr,
|
static int uec_miiphy_write(char *devname, unsigned char addr,
|
||||||
unsigned char reg, unsigned short value)
|
unsigned char reg, unsigned short value)
|
||||||
{
|
{
|
||||||
uec_write_phy_reg(devlist[0], addr, reg, value);
|
int devindex = 0;
|
||||||
|
|
||||||
|
if (devname == NULL) {
|
||||||
|
debug("%s: NULL pointer given\n", __FUNCTION__);
|
||||||
|
} else {
|
||||||
|
devindex = uec_miiphy_find_dev_by_name(devname);
|
||||||
|
if (devindex >= 0) {
|
||||||
|
uec_write_phy_reg(devlist[devindex], addr, reg, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int uec_set_mac_address(uec_private_t *uec, u8 *mac_addr)
|
static int uec_set_mac_address(uec_private_t *uec, u8 *mac_addr)
|
||||||
|
|
Loading…
Add table
Reference in a new issue