提交 c673a2b4 编写于 作者: M Mika Westerberg 提交者: Rafael J. Wysocki

leds: leds-gpio: Convert gpio_blink_set() to use GPIO descriptors

Commit 21f2aae91e902aad ("leds: leds-gpio: Add support for GPIO
descriptors") already converted most of the driver to use GPIO descriptors.
What is still missing is the platform specific hook gpio_blink_set() and
board files which pass legacy GPIO numbers to this driver in platform data.

In this patch we handle the former and convert gpio_blink_set() to take
GPIO descriptor instead. In order to do this we convert the existing four
users to accept GPIO descriptor and translate it to legacy GPIO number in
the platform code. This effectively "pushes" legacy GPIO number usage from
the driver to platforms.

Also add comment to the remaining block describing that it is legacy code
path and we are getting rid of it eventually.
Suggested-by: NLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: NMika Westerberg <mika.westerberg@linux.intel.com>
Acked-by: NAndrew Lunn <andrew@lunn.ch>
Reviewed-by: NLinus Walleij <linus.walleij@linaro.org>
Acked-by: NAlexandre Courbot <acourbot@nvidia.com>
Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
上级 e36d453e
...@@ -41,7 +41,7 @@ static void h1940bt_enable(int on) ...@@ -41,7 +41,7 @@ static void h1940bt_enable(int on)
mdelay(10); mdelay(10);
gpio_set_value(S3C2410_GPH(1), 0); gpio_set_value(S3C2410_GPH(1), 0);
h1940_led_blink_set(-EINVAL, GPIO_LED_BLINK, NULL, NULL); h1940_led_blink_set(NULL, GPIO_LED_BLINK, NULL, NULL);
} }
else { else {
gpio_set_value(S3C2410_GPH(1), 1); gpio_set_value(S3C2410_GPH(1), 1);
...@@ -50,7 +50,7 @@ static void h1940bt_enable(int on) ...@@ -50,7 +50,7 @@ static void h1940bt_enable(int on)
mdelay(10); mdelay(10);
gpio_set_value(H1940_LATCH_BLUETOOTH_POWER, 0); gpio_set_value(H1940_LATCH_BLUETOOTH_POWER, 0);
h1940_led_blink_set(-EINVAL, GPIO_LED_NO_BLINK_LOW, NULL, NULL); h1940_led_blink_set(NULL, GPIO_LED_NO_BLINK_LOW, NULL, NULL);
} }
} }
......
...@@ -19,8 +19,10 @@ ...@@ -19,8 +19,10 @@
#define H1940_SUSPEND_RESUMEAT (0x30081000) #define H1940_SUSPEND_RESUMEAT (0x30081000)
#define H1940_SUSPEND_CHECK (0x30080000) #define H1940_SUSPEND_CHECK (0x30080000)
struct gpio_desc;
extern void h1940_pm_return(void); extern void h1940_pm_return(void);
extern int h1940_led_blink_set(unsigned gpio, int state, extern int h1940_led_blink_set(struct gpio_desc *desc, int state,
unsigned long *delay_on, unsigned long *delay_on,
unsigned long *delay_off); unsigned long *delay_off);
......
...@@ -359,10 +359,11 @@ static struct platform_device h1940_battery = { ...@@ -359,10 +359,11 @@ static struct platform_device h1940_battery = {
static DEFINE_SPINLOCK(h1940_blink_spin); static DEFINE_SPINLOCK(h1940_blink_spin);
int h1940_led_blink_set(unsigned gpio, int state, int h1940_led_blink_set(struct gpio_desc *desc, int state,
unsigned long *delay_on, unsigned long *delay_off) unsigned long *delay_on, unsigned long *delay_off)
{ {
int blink_gpio, check_gpio1, check_gpio2; int blink_gpio, check_gpio1, check_gpio2;
int gpio = desc ? desc_to_gpio(desc) : -EINVAL;
switch (gpio) { switch (gpio) {
case H1940_LATCH_LED_GREEN: case H1940_LATCH_LED_GREEN:
......
...@@ -250,9 +250,10 @@ static void rx1950_disable_charger(void) ...@@ -250,9 +250,10 @@ static void rx1950_disable_charger(void)
static DEFINE_SPINLOCK(rx1950_blink_spin); static DEFINE_SPINLOCK(rx1950_blink_spin);
static int rx1950_led_blink_set(unsigned gpio, int state, static int rx1950_led_blink_set(struct gpio_desc *desc, int state,
unsigned long *delay_on, unsigned long *delay_off) unsigned long *delay_on, unsigned long *delay_off)
{ {
int gpio = desc_to_gpio(desc);
int blink_gpio, check_gpio; int blink_gpio, check_gpio;
switch (gpio) { switch (gpio) {
......
...@@ -306,9 +306,10 @@ EXPORT_SYMBOL(orion_gpio_set_blink); ...@@ -306,9 +306,10 @@ EXPORT_SYMBOL(orion_gpio_set_blink);
#define ORION_BLINK_HALF_PERIOD 100 /* ms */ #define ORION_BLINK_HALF_PERIOD 100 /* ms */
int orion_gpio_led_blink_set(unsigned gpio, int state, int orion_gpio_led_blink_set(struct gpio_desc *desc, int state,
unsigned long *delay_on, unsigned long *delay_off) unsigned long *delay_on, unsigned long *delay_off)
{ {
unsigned gpio = desc_to_gpio(desc);
if (delay_on && delay_off && !*delay_on && !*delay_off) if (delay_on && delay_off && !*delay_on && !*delay_off)
*delay_on = *delay_off = ORION_BLINK_HALF_PERIOD; *delay_on = *delay_off = ORION_BLINK_HALF_PERIOD;
......
...@@ -14,12 +14,15 @@ ...@@ -14,12 +14,15 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/irqdomain.h> #include <linux/irqdomain.h>
struct gpio_desc;
/* /*
* Orion-specific GPIO API extensions. * Orion-specific GPIO API extensions.
*/ */
void orion_gpio_set_unused(unsigned pin); void orion_gpio_set_unused(unsigned pin);
void orion_gpio_set_blink(unsigned pin, int blink); void orion_gpio_set_blink(unsigned pin, int blink);
int orion_gpio_led_blink_set(unsigned gpio, int state, int orion_gpio_led_blink_set(struct gpio_desc *desc, int state,
unsigned long *delay_on, unsigned long *delay_off); unsigned long *delay_on, unsigned long *delay_off);
#define GPIO_INPUT_OK (1 << 0) #define GPIO_INPUT_OK (1 << 0)
......
...@@ -28,7 +28,7 @@ struct gpio_led_data { ...@@ -28,7 +28,7 @@ struct gpio_led_data {
u8 new_level; u8 new_level;
u8 can_sleep; u8 can_sleep;
u8 blinking; u8 blinking;
int (*platform_gpio_blink_set)(unsigned gpio, int state, int (*platform_gpio_blink_set)(struct gpio_desc *desc, int state,
unsigned long *delay_on, unsigned long *delay_off); unsigned long *delay_on, unsigned long *delay_off);
}; };
...@@ -38,13 +38,8 @@ static void gpio_led_work(struct work_struct *work) ...@@ -38,13 +38,8 @@ static void gpio_led_work(struct work_struct *work)
container_of(work, struct gpio_led_data, work); container_of(work, struct gpio_led_data, work);
if (led_dat->blinking) { if (led_dat->blinking) {
int gpio = desc_to_gpio(led_dat->gpiod); led_dat->platform_gpio_blink_set(led_dat->gpiod,
int level = led_dat->new_level; led_dat->new_level, NULL, NULL);
if (gpiod_is_active_low(led_dat->gpiod))
level = !level;
led_dat->platform_gpio_blink_set(gpio, level, NULL, NULL);
led_dat->blinking = 0; led_dat->blinking = 0;
} else } else
gpiod_set_value_cansleep(led_dat->gpiod, led_dat->new_level); gpiod_set_value_cansleep(led_dat->gpiod, led_dat->new_level);
...@@ -71,13 +66,8 @@ static void gpio_led_set(struct led_classdev *led_cdev, ...@@ -71,13 +66,8 @@ static void gpio_led_set(struct led_classdev *led_cdev,
schedule_work(&led_dat->work); schedule_work(&led_dat->work);
} else { } else {
if (led_dat->blinking) { if (led_dat->blinking) {
int gpio = desc_to_gpio(led_dat->gpiod); led_dat->platform_gpio_blink_set(led_dat->gpiod, level,
NULL, NULL);
if (gpiod_is_active_low(led_dat->gpiod))
level = !level;
led_dat->platform_gpio_blink_set(gpio, level, NULL,
NULL);
led_dat->blinking = 0; led_dat->blinking = 0;
} else } else
gpiod_set_value(led_dat->gpiod, level); gpiod_set_value(led_dat->gpiod, level);
...@@ -89,20 +79,25 @@ static int gpio_blink_set(struct led_classdev *led_cdev, ...@@ -89,20 +79,25 @@ static int gpio_blink_set(struct led_classdev *led_cdev,
{ {
struct gpio_led_data *led_dat = struct gpio_led_data *led_dat =
container_of(led_cdev, struct gpio_led_data, cdev); container_of(led_cdev, struct gpio_led_data, cdev);
int gpio = desc_to_gpio(led_dat->gpiod);
led_dat->blinking = 1; led_dat->blinking = 1;
return led_dat->platform_gpio_blink_set(gpio, GPIO_LED_BLINK, return led_dat->platform_gpio_blink_set(led_dat->gpiod, GPIO_LED_BLINK,
delay_on, delay_off); delay_on, delay_off);
} }
static int create_gpio_led(const struct gpio_led *template, static int create_gpio_led(const struct gpio_led *template,
struct gpio_led_data *led_dat, struct device *parent, struct gpio_led_data *led_dat, struct device *parent,
int (*blink_set)(unsigned, int, unsigned long *, unsigned long *)) int (*blink_set)(struct gpio_desc *, int, unsigned long *,
unsigned long *))
{ {
int ret, state; int ret, state;
if (!template->gpiod) { if (!template->gpiod) {
/*
* This is the legacy code path for platform code that
* still uses GPIO numbers. Ultimately we would like to get
* rid of this block completely.
*/
unsigned long flags = 0; unsigned long flags = 0;
/* skip leds that aren't available */ /* skip leds that aren't available */
......
...@@ -274,7 +274,7 @@ struct gpio_led_platform_data { ...@@ -274,7 +274,7 @@ struct gpio_led_platform_data {
#define GPIO_LED_NO_BLINK_LOW 0 /* No blink GPIO state low */ #define GPIO_LED_NO_BLINK_LOW 0 /* No blink GPIO state low */
#define GPIO_LED_NO_BLINK_HIGH 1 /* No blink GPIO state high */ #define GPIO_LED_NO_BLINK_HIGH 1 /* No blink GPIO state high */
#define GPIO_LED_BLINK 2 /* Please, blink */ #define GPIO_LED_BLINK 2 /* Please, blink */
int (*gpio_blink_set)(unsigned gpio, int state, int (*gpio_blink_set)(struct gpio_desc *desc, int state,
unsigned long *delay_on, unsigned long *delay_on,
unsigned long *delay_off); unsigned long *delay_off);
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册