net: phy: split devices_in_package
We have two competing requirements for the devices_in_package field. We want to use it as a bit array indicating which MMDs are present, but we also want to know if the Clause 22 registers are present. Since "devices in package" is a term used in the 802.3 specification, keep this as the as-specified values read from the PHY, and introduce a new member "mmds_present" to indicate which MMDs are actually present in the PHY, derived from the "devices in package" value. Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
5ba33cf483
commit
320ed3bf90
@@ -709,9 +709,6 @@ static int get_phy_c45_devs_in_pkg(struct mii_bus *bus, int addr, int dev_addr,
|
||||
return -EIO;
|
||||
*devices_in_package |= phy_reg;
|
||||
|
||||
/* Bit 0 doesn't represent a device, it indicates c22 regs presence */
|
||||
*devices_in_package &= ~BIT(0);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -789,6 +786,8 @@ static int get_phy_c45_ids(struct mii_bus *bus, int addr,
|
||||
}
|
||||
|
||||
c45_ids->devices_in_package = devs_in_pkg;
|
||||
/* Bit 0 doesn't represent a device, it indicates c22 regs presence */
|
||||
c45_ids->mmds_present = devs_in_pkg & ~BIT(0);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -857,6 +856,7 @@ struct phy_device *get_phy_device(struct mii_bus *bus, int addr, bool is_c45)
|
||||
int r;
|
||||
|
||||
c45_ids.devices_in_package = 0;
|
||||
c45_ids.mmds_present = 0;
|
||||
memset(c45_ids.device_ids, 0xff, sizeof(c45_ids.device_ids));
|
||||
|
||||
if (is_c45)
|
||||
|
Reference in New Issue
Block a user