backlight.h 3.9 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6 7 8 9 10 11
/*
 * Backlight Lowlevel Control Abstraction
 *
 * Copyright (C) 2003,2004 Hewlett-Packard Company
 *
 */

#ifndef _LINUX_BACKLIGHT_H
#define _LINUX_BACKLIGHT_H

#include <linux/device.h>
12
#include <linux/mutex.h>
L
Linus Torvalds 已提交
13 14
#include <linux/notifier.h>

15 16
/* Notes on locking:
 *
17 18
 * backlight_device->ops_lock is an internal backlight lock protecting the
 * ops pointer and no code outside the core should need to touch it.
19 20 21 22 23 24 25 26 27 28 29
 *
 * Access to update_status() is serialised by the update_lock mutex since
 * most drivers seem to need this and historically get it wrong.
 *
 * Most drivers don't need locking on their get_brightness() method.
 * If yours does, you need to implement it in the driver. You can use the
 * update_lock mutex if appropriate.
 *
 * Any other use of the locks below is probably wrong.
 */

30 31 32 33 34
enum backlight_update_reason {
	BACKLIGHT_UPDATE_HOTKEY,
	BACKLIGHT_UPDATE_SYSFS,
};

L
Linus Torvalds 已提交
35 36 37
struct backlight_device;
struct fb_info;

38
struct backlight_ops {
39
	const unsigned int options;
40 41 42

#define BL_CORE_SUSPENDRESUME	(1 << 0)

43
	/* Notify the backlight driver some property has changed */
44
	int (* const update_status)(struct backlight_device *);
45 46
	/* Return the current backlight brightness (accounting for power,
	   fb_blank etc.) */
47
	int (* const get_brightness)(struct backlight_device *);
L
Linus Torvalds 已提交
48 49
	/* Check if given framebuffer device is the one bound to this backlight;
	   return 0 if not, !=0 if it is. If NULL, backlight always matches the fb. */
50
	int (* const check_fb)(struct fb_info *);
51
};
52

53 54
/* This structure defines all the properties of a backlight */
struct backlight_properties {
55 56 57 58 59 60 61 62
	/* Current User requested brightness (0 - max_brightness) */
	int brightness;
	/* Maximal value for brightness (read-only) */
	int max_brightness;
	/* Current FB Power mode (0: full on, 1..3: power saving
	   modes; 4: full off), see FB_BLANK_XXX */
	int power;
	/* FB Blanking active? (values as for power) */
63
	/* Due to be removed, please use (state & BL_CORE_FBBLANK) */
64
	int fb_blank;
65 66 67 68 69 70 71 72 73 74 75
	/* Flags used to signal drivers of state changes */
	/* Upper 4 bits are reserved for driver internal use */
	unsigned int state;

#define BL_CORE_SUSPENDED	(1 << 0)	/* backlight is suspended */
#define BL_CORE_FBBLANK		(1 << 1)	/* backlight is under an fb blank event */
#define BL_CORE_DRIVER4		(1 << 28)	/* reserved for driver specific use */
#define BL_CORE_DRIVER3		(1 << 29)	/* reserved for driver specific use */
#define BL_CORE_DRIVER2		(1 << 30)	/* reserved for driver specific use */
#define BL_CORE_DRIVER1		(1 << 31)	/* reserved for driver specific use */

L
Linus Torvalds 已提交
76 77 78
};

struct backlight_device {
79 80 81
	/* Backlight properties */
	struct backlight_properties props;

82 83
	/* Serialise access to update_status method */
	struct mutex update_lock;
84 85 86 87 88

	/* This protects the 'ops' field. If 'ops' is NULL, the driver that
	   registered this device has been unloaded, and if class_get_devdata()
	   points to something in the body of that driver, it is also invalid. */
	struct mutex ops_lock;
89
	const struct backlight_ops *ops;
90

L
Linus Torvalds 已提交
91 92
	/* The framebuffer notifier block */
	struct notifier_block fb_notif;
93 94

	struct device dev;
L
Linus Torvalds 已提交
95 96
};

97 98 99
static inline void backlight_update_status(struct backlight_device *bd)
{
	mutex_lock(&bd->update_lock);
100 101
	if (bd->ops && bd->ops->update_status)
		bd->ops->update_status(bd);
102 103 104
	mutex_unlock(&bd->update_lock);
}

L
Linus Torvalds 已提交
105
extern struct backlight_device *backlight_device_register(const char *name,
106
	struct device *dev, void *devdata, const struct backlight_ops *ops);
L
Linus Torvalds 已提交
107
extern void backlight_device_unregister(struct backlight_device *bd);
108 109
extern void backlight_force_update(struct backlight_device *bd,
				   enum backlight_update_reason reason);
L
Linus Torvalds 已提交
110

111 112 113 114 115 116
#define to_backlight_device(obj) container_of(obj, struct backlight_device, dev)

static inline void * bl_get_data(struct backlight_device *bl_dev)
{
	return dev_get_drvdata(&bl_dev->dev);
}
L
Linus Torvalds 已提交
117

118 119 120 121 122 123 124 125 126
struct generic_bl_info {
	const char *name;
	int max_intensity;
	int default_intensity;
	int limit_mask;
	void (*set_bl_intensity)(int intensity);
	void (*kick_battery)(void);
};

L
Linus Torvalds 已提交
127
#endif