summaryrefslogtreecommitdiff
path: root/drivers/video/backlight
diff options
context:
space:
mode:
authorSandor Yu <Sandor.yu@nxp.com>2019-01-08 17:42:10 +0530
committerDong Aisheng <aisheng.dong@nxp.com>2019-11-25 15:45:18 +0800
commit4fa439eff9be4603357c592145668405843ee088 (patch)
treeacbbe66af3a8fc239079d4aba842605180a9671f /drivers/video/backlight
parent219d54332a09e8d8741c1e1982f5eae56099de85 (diff)
MLK-12932-01: pwm backlight: Add fb name check feature
Add fb name check function pwm_backlight_check_fb_name(), pwm driver can banding to fb with fb name when driver working in device tree architecture. Signed-off-by: Sandor Yu <Sandor.yu@nxp.com> Signed-off-by: Vipul Kumar <vipul_kumar@mentor.com>
Diffstat (limited to 'drivers/video/backlight')
-rw-r--r--drivers/video/backlight/pwm_bl.c20
1 files changed, 19 insertions, 1 deletions
diff --git a/drivers/video/backlight/pwm_bl.c b/drivers/video/backlight/pwm_bl.c
index 746eebc411df..40ebb5feb7d7 100644
--- a/drivers/video/backlight/pwm_bl.c
+++ b/drivers/video/backlight/pwm_bl.c
@@ -38,6 +38,7 @@ struct pwm_bl_data {
int brightness);
int (*check_fb)(struct device *, struct fb_info *);
void (*exit)(struct device *);
+ char fb_id[16];
};
static void pwm_backlight_power_on(struct pwm_bl_data *pb)
@@ -222,6 +223,17 @@ int pwm_backlight_brightness_default(struct device *dev,
return 0;
}
+static int pwm_backlight_check_fb_name(struct device *dev, struct fb_info *info)
+{
+ struct backlight_device *bl = dev_get_drvdata(dev);
+ struct pwm_bl_data *pb = bl_get_data(bl);
+
+ if (strcmp(info->fix.id, pb->fb_id) == 0)
+ return true;
+
+ return false;
+}
+
static int pwm_backlight_parse_dt(struct device *dev,
struct platform_pwm_backlight_data *data)
{
@@ -234,12 +246,18 @@ static int pwm_backlight_parse_dt(struct device *dev,
int length;
u32 value;
int ret;
+ const char *names;
if (!node)
return -ENODEV;
memset(data, 0, sizeof(*data));
+ if (!of_property_read_string(node, "fb-names", &names)) {
+ strcpy(data->fb_id, names);
+ data->check_fb = &pwm_backlight_check_fb_name;
+ }
+
/*
* These values are optional and set as 0 by default, the out values
* are modified only if a valid u32 value can be decoded.
@@ -361,7 +379,6 @@ static int pwm_backlight_parse_dt(struct device *dev,
data->max_brightness--;
}
-
return 0;
}
@@ -484,6 +501,7 @@ static int pwm_backlight_probe(struct platform_device *pdev)
pb->enabled = false;
pb->post_pwm_on_delay = data->post_pwm_on_delay;
pb->pwm_off_delay = data->pwm_off_delay;
+ strcpy(pb->fb_id, data->fb_id);
pb->enable_gpio = devm_gpiod_get_optional(&pdev->dev, "enable",
GPIOD_ASIS);