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