summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatt Wagner <mwagner@nvidia.com>2011-07-22 00:13:08 -0700
committerVarun Colbert <vcolbert@nvidia.com>2011-08-09 15:38:23 -0700
commitc6b3cd0903bb29bca54daa83c183d6f20ee6bc90 (patch)
tree5e1c861e614b5512705a84af700a7273b200667b
parent066831b4f514ca4395e5a4ee15390d9f256a5f99 (diff)
video: backlight: tegra: add callback to tegra_pwm_backlight
tegra-pwm-backlight now has a notify function that enables the brightness to be passed back to the boardfile where it is modified. Bug 854820 Change-Id: I1425d801f77987485b58c3cbedae464b5db88444 Reviewed-on: http://git-master/r/42639 Reviewed-by: Varun Colbert <vcolbert@nvidia.com> Tested-by: Varun Colbert <vcolbert@nvidia.com>
-rw-r--r--drivers/video/backlight/tegra_pwm_bl.c5
-rw-r--r--include/linux/tegra_pwm_bl.h1
2 files changed, 6 insertions, 0 deletions
diff --git a/drivers/video/backlight/tegra_pwm_bl.c b/drivers/video/backlight/tegra_pwm_bl.c
index 4331e8ef626a..93f4645128a0 100644
--- a/drivers/video/backlight/tegra_pwm_bl.c
+++ b/drivers/video/backlight/tegra_pwm_bl.c
@@ -25,6 +25,7 @@
struct tegra_pwm_bl_data {
struct device *dev;
int which_dc;
+ int (*notify)(struct device *, int brightness);
struct tegra_dc_pwm_params params;
};
@@ -41,6 +42,9 @@ static int tegra_pwm_backlight_update_status(struct backlight_device *bl)
if (bl->props.fb_blank != FB_BLANK_UNBLANK)
brightness = 0;
+ if (tbl->notify)
+ brightness = tbl->notify(tbl->dev, brightness);
+
if (brightness > max)
dev_err(&bl->dev, "Invalid brightness value: %d max: %d\n",
brightness, max);
@@ -95,6 +99,7 @@ static int tegra_pwm_backlight_probe(struct platform_device *pdev)
tbl->dev = &pdev->dev;
tbl->which_dc = data->which_dc;
+ tbl->notify = data->notify;
tbl->params.which_pwm = data->which_pwm;
tbl->params.gpio_conf_to_sfio = data->gpio_conf_to_sfio;
tbl->params.switch_to_sfio = data->switch_to_sfio;
diff --git a/include/linux/tegra_pwm_bl.h b/include/linux/tegra_pwm_bl.h
index ee924842bf84..68fecb522cfc 100644
--- a/include/linux/tegra_pwm_bl.h
+++ b/include/linux/tegra_pwm_bl.h
@@ -22,6 +22,7 @@ struct platform_tegra_pwm_backlight_data {
unsigned int period;
unsigned int clk_div;
unsigned int clk_select;
+ int (*notify)(struct device *dev, int brightness);
};
#endif /* TERGA_PWM_BL_H */