提交 325253a6 编写于 作者: M Matthew Garrett 提交者: Richard Purdie

backlight: Allow drivers to update the core, and generate events on changes

Certain hardware will send us events when the backlight brightness
changes. Add a function to update the value in the core, and
additionally send a uevent so that userspace can pop up appropriate
UI. The uevents are flagged depending on whether the update originated
in the kernel or from userspace, making it easier to only display UI
at the appropriate time.
Signed-off-by: NMatthew Garrett <mjg@redhat.com>
Signed-off-by: NRichard Purdie <rpurdie@linux.intel.com>
上级 0f7e7273
...@@ -73,6 +73,26 @@ static inline void backlight_unregister_fb(struct backlight_device *bd) ...@@ -73,6 +73,26 @@ static inline void backlight_unregister_fb(struct backlight_device *bd)
} }
#endif /* CONFIG_FB */ #endif /* CONFIG_FB */
static void backlight_generate_event(struct backlight_device *bd,
enum backlight_update_reason reason)
{
char *envp[2];
switch (reason) {
case BACKLIGHT_UPDATE_SYSFS:
envp[0] = "SOURCE=sysfs";
break;
case BACKLIGHT_UPDATE_HOTKEY:
envp[0] = "SOURCE=hotkey";
break;
default:
envp[0] = "SOURCE=unknown";
break;
}
envp[1] = NULL;
kobject_uevent_env(&bd->dev.kobj, KOBJ_CHANGE, envp);
}
static ssize_t backlight_show_power(struct device *dev, static ssize_t backlight_show_power(struct device *dev,
struct device_attribute *attr,char *buf) struct device_attribute *attr,char *buf)
{ {
...@@ -142,6 +162,8 @@ static ssize_t backlight_store_brightness(struct device *dev, ...@@ -142,6 +162,8 @@ static ssize_t backlight_store_brightness(struct device *dev,
} }
mutex_unlock(&bd->ops_lock); mutex_unlock(&bd->ops_lock);
backlight_generate_event(bd, BACKLIGHT_UPDATE_SYSFS);
return rc; return rc;
} }
...@@ -213,6 +235,25 @@ static struct device_attribute bl_device_attributes[] = { ...@@ -213,6 +235,25 @@ static struct device_attribute bl_device_attributes[] = {
__ATTR_NULL, __ATTR_NULL,
}; };
/**
* backlight_force_update - tell the backlight subsystem that hardware state
* has changed
* @bd: the backlight device to update
*
* Updates the internal state of the backlight in response to a hardware event,
* and generate a uevent to notify userspace
*/
void backlight_force_update(struct backlight_device *bd,
enum backlight_update_reason reason)
{
mutex_lock(&bd->ops_lock);
if (bd->ops && bd->ops->get_brightness)
bd->props.brightness = bd->ops->get_brightness(bd);
mutex_unlock(&bd->ops_lock);
backlight_generate_event(bd, reason);
}
EXPORT_SYMBOL(backlight_force_update);
/** /**
* backlight_device_register - create and register a new object of * backlight_device_register - create and register a new object of
* backlight_device class. * backlight_device class.
......
...@@ -27,6 +27,11 @@ ...@@ -27,6 +27,11 @@
* Any other use of the locks below is probably wrong. * Any other use of the locks below is probably wrong.
*/ */
enum backlight_update_reason {
BACKLIGHT_UPDATE_HOTKEY,
BACKLIGHT_UPDATE_SYSFS,
};
struct backlight_device; struct backlight_device;
struct fb_info; struct fb_info;
...@@ -100,6 +105,8 @@ static inline void backlight_update_status(struct backlight_device *bd) ...@@ -100,6 +105,8 @@ static inline void backlight_update_status(struct backlight_device *bd)
extern struct backlight_device *backlight_device_register(const char *name, extern struct backlight_device *backlight_device_register(const char *name,
struct device *dev, void *devdata, struct backlight_ops *ops); struct device *dev, void *devdata, struct backlight_ops *ops);
extern void backlight_device_unregister(struct backlight_device *bd); extern void backlight_device_unregister(struct backlight_device *bd);
extern void backlight_force_update(struct backlight_device *bd,
enum backlight_update_reason reason);
#define to_backlight_device(obj) container_of(obj, struct backlight_device, dev) #define to_backlight_device(obj) container_of(obj, struct backlight_device, dev)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册