Skip to content

Commit

Permalink
net: phy: support 'active-high' property for PHY LEDs
Browse files Browse the repository at this point in the history
In addition to 'active-low' and 'inactive-high-impedance' also
support 'active-high' property for PHY LED pin configuration.
As only either 'active-high' or 'active-low' can be set at the
same time, WARN and return an error in case both are set.

Signed-off-by: Daniel Golle <daniel@makrotopia.org>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Link: https://patch.msgid.link/91598487773d768f254d5faf06cf65b13e972f0e.1728558223.git.daniel@makrotopia.org
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
  • Loading branch information
Daniel Golle authored and Paolo Abeni committed Oct 15, 2024
1 parent 9c5ad7b commit a274465
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 2 deletions.
6 changes: 6 additions & 0 deletions drivers/net/phy/phy_device.c
Original file line number Diff line number Diff line change
Expand Up @@ -3358,11 +3358,17 @@ static int of_phy_led(struct phy_device *phydev,
if (index > U8_MAX)
return -EINVAL;

if (of_property_read_bool(led, "active-high"))
set_bit(PHY_LED_ACTIVE_HIGH, &modes);
if (of_property_read_bool(led, "active-low"))
set_bit(PHY_LED_ACTIVE_LOW, &modes);
if (of_property_read_bool(led, "inactive-high-impedance"))
set_bit(PHY_LED_INACTIVE_HIGH_IMPEDANCE, &modes);

if (WARN_ON(modes & BIT(PHY_LED_ACTIVE_LOW) &&
modes & BIT(PHY_LED_ACTIVE_HIGH)))
return -EINVAL;

if (modes) {
/* Return error if asked to set polarity modes but not supported */
if (!phydev->drv->led_polarity_set)
Expand Down
5 changes: 3 additions & 2 deletions include/linux/phy.h
Original file line number Diff line number Diff line change
Expand Up @@ -877,8 +877,9 @@ struct phy_plca_status {

/* Modes for PHY LED configuration */
enum phy_led_modes {
PHY_LED_ACTIVE_LOW = 0,
PHY_LED_INACTIVE_HIGH_IMPEDANCE = 1,
PHY_LED_ACTIVE_HIGH = 0,
PHY_LED_ACTIVE_LOW = 1,
PHY_LED_INACTIVE_HIGH_IMPEDANCE = 2,

/* keep it last */
__PHY_LED_MODES_NUM,
Expand Down

0 comments on commit a274465

Please sign in to comment.