Re: [PATCH V2] net: phy: Add sysfs attribute for PHY c45 identifiers.
From: Andrew Lunn
Date: Tue Jun 13 2023 - 12:19:28 EST
> +#define DEVICE_ATTR_C45_ID(i) \
> +static ssize_t \
> +phy_c45_id##i##_show(struct device *dev, \
> + struct device_attribute *attr, char *buf) \
> +{ \
> + struct phy_device *phydev = to_phy_device(dev); \
> +\
> + if (!phydev->is_c45) \
> + return 0; \
> +\
> + return sprintf(buf, "0x%.8lx\n", \
> + (unsigned long)phydev->c45_ids.device_ids[i]); \
> +} \
That is not the most efficient implementation.
You can have one generic
static ssize_t phy_c45_id_show(struct device *dev, char *buf, int i)
{
struct phy_device *phydev = to_phy_device(dev);
if (!phydev->is_c45)
return 0;
return sprintf(buf, "0x%.8lx\n",
(unsigned long)phydev->c45_ids.device_ids[i]);
}
And then your macros becomes
#define DEVICE_ATTR_C45_ID(i) \
static ssize_t \
phy_c45_id##i##_show(struct device *dev, \
struct device_attribute *attr, char *buf) \
{ \
return phy_c45_id_show(dev, buf, i); \
}
Andrew
---
pw-bot: cr