mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-15 09:19:57 +00:00
d40756563c
Let's pick a bunch of useful phylink changes which allow us to keep drivers in sync with mainline Linux. Signed-off-by: Daniel Golle <daniel@makrotopia.org>
74 lines
2.4 KiB
Diff
74 lines
2.4 KiB
Diff
From 4e901018432e38eab35d2a352661ce4727795be1 Mon Sep 17 00:00:00 2001
|
|
From: Andrew Lunn <andrew@lunn.ch>
|
|
Date: Mon, 17 Apr 2023 17:17:30 +0200
|
|
Subject: [PATCH 8/9] net: phy: phy_device: Call into the PHY driver to set LED
|
|
blinking
|
|
|
|
Linux LEDs can be requested to perform hardware accelerated
|
|
blinking. Pass this to the PHY driver, if it implements the op.
|
|
|
|
Signed-off-by: Andrew Lunn <andrew@lunn.ch>
|
|
Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
|
|
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
|
|
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
---
|
|
drivers/net/phy/phy_device.c | 18 ++++++++++++++++++
|
|
include/linux/phy.h | 12 ++++++++++++
|
|
2 files changed, 30 insertions(+)
|
|
|
|
--- a/drivers/net/phy/phy_device.c
|
|
+++ b/drivers/net/phy/phy_device.c
|
|
@@ -3052,6 +3052,22 @@ static int phy_led_set_brightness(struct
|
|
return err;
|
|
}
|
|
|
|
+static int phy_led_blink_set(struct led_classdev *led_cdev,
|
|
+ unsigned long *delay_on,
|
|
+ unsigned long *delay_off)
|
|
+{
|
|
+ struct phy_led *phyled = to_phy_led(led_cdev);
|
|
+ struct phy_device *phydev = phyled->phydev;
|
|
+ int err;
|
|
+
|
|
+ mutex_lock(&phydev->lock);
|
|
+ err = phydev->drv->led_blink_set(phydev, phyled->index,
|
|
+ delay_on, delay_off);
|
|
+ mutex_unlock(&phydev->lock);
|
|
+
|
|
+ return err;
|
|
+}
|
|
+
|
|
static int of_phy_led(struct phy_device *phydev,
|
|
struct device_node *led)
|
|
{
|
|
@@ -3074,6 +3090,8 @@ static int of_phy_led(struct phy_device
|
|
|
|
if (phydev->drv->led_brightness_set)
|
|
cdev->brightness_set_blocking = phy_led_set_brightness;
|
|
+ if (phydev->drv->led_blink_set)
|
|
+ cdev->blink_set = phy_led_blink_set;
|
|
cdev->max_brightness = 1;
|
|
init_data.devicename = dev_name(&phydev->mdio.dev);
|
|
init_data.fwnode = of_fwnode_handle(led);
|
|
--- a/include/linux/phy.h
|
|
+++ b/include/linux/phy.h
|
|
@@ -1014,6 +1014,18 @@ struct phy_driver {
|
|
*/
|
|
int (*led_brightness_set)(struct phy_device *dev,
|
|
u8 index, enum led_brightness value);
|
|
+
|
|
+ /**
|
|
+ * @led_blink_set: Set a PHY LED brightness. Index indicates
|
|
+ * which of the PHYs led should be configured to blink. Delays
|
|
+ * are in milliseconds and if both are zero then a sensible
|
|
+ * default should be chosen. The call should adjust the
|
|
+ * timings in that case and if it can't match the values
|
|
+ * specified exactly.
|
|
+ */
|
|
+ int (*led_blink_set)(struct phy_device *dev, u8 index,
|
|
+ unsigned long *delay_on,
|
|
+ unsigned long *delay_off);
|
|
};
|
|
#define to_phy_driver(d) container_of(to_mdio_common_driver(d), \
|
|
struct phy_driver, mdiodrv)
|