blob: bfe484da55d2c98506106321501fa74a7551ecd1 [file] [log] [blame]
Matthew Garrett74a365b2009-03-19 21:35:39 +00001#ifndef __ACPI_VIDEO_H
2#define __ACPI_VIDEO_H
3
Chris Wilsonb72512e2010-09-05 14:51:49 +01004#include <linux/errno.h> /* for ENODEV */
Hans de Goede90b066b2015-12-22 19:09:48 +01005#include <linux/types.h> /* for bool */
Chris Wilsonb72512e2010-09-05 14:51:49 +01006
Aaron Lu05950092016-04-27 20:45:04 +08007struct acpi_video_brightness_flags {
8 u8 _BCL_no_ac_battery_levels:1; /* no AC/Battery levels in _BCL */
9 u8 _BCL_reversed:1; /* _BCL package is in a reversed order */
10 u8 _BQC_use_index:1; /* _BQC returns an index value */
11};
12
13struct acpi_video_device_brightness {
14 int curr;
15 int count;
16 int *levels;
17 struct acpi_video_brightness_flags flags;
18};
19
Chris Wilsonb72512e2010-09-05 14:51:49 +010020struct acpi_device;
21
Matthew Garrettf5a3d0c2011-07-12 18:30:52 -040022#define ACPI_VIDEO_CLASS "video"
23
Matthew Garrette92a7162010-01-12 14:17:03 -050024#define ACPI_VIDEO_DISPLAY_CRT 1
25#define ACPI_VIDEO_DISPLAY_TV 2
26#define ACPI_VIDEO_DISPLAY_DVI 3
27#define ACPI_VIDEO_DISPLAY_LCD 4
28
29#define ACPI_VIDEO_DISPLAY_LEGACY_MONITOR 0x0100
30#define ACPI_VIDEO_DISPLAY_LEGACY_PANEL 0x0110
31#define ACPI_VIDEO_DISPLAY_LEGACY_TV 0x0200
32
Hans de Goedeeff4a752016-11-09 18:15:56 +010033#define ACPI_VIDEO_NOTIFY_SWITCH 0x80
34#define ACPI_VIDEO_NOTIFY_PROBE 0x81
35#define ACPI_VIDEO_NOTIFY_CYCLE 0x82
36#define ACPI_VIDEO_NOTIFY_NEXT_OUTPUT 0x83
37#define ACPI_VIDEO_NOTIFY_PREV_OUTPUT 0x84
38#define ACPI_VIDEO_NOTIFY_CYCLE_BRIGHTNESS 0x85
39#define ACPI_VIDEO_NOTIFY_INC_BRIGHTNESS 0x86
40#define ACPI_VIDEO_NOTIFY_DEC_BRIGHTNESS 0x87
41#define ACPI_VIDEO_NOTIFY_ZERO_BRIGHTNESS 0x88
42#define ACPI_VIDEO_NOTIFY_DISPLAY_OFF 0x89
43
Hans de Goede87521e12015-06-16 16:27:48 +020044enum acpi_backlight_type {
45 acpi_backlight_undef = -1,
46 acpi_backlight_none = 0,
47 acpi_backlight_video,
48 acpi_backlight_vendor,
49 acpi_backlight_native,
50};
51
Sudeep Hollabcb2b0b2015-09-14 16:01:55 +010052#if IS_ENABLED(CONFIG_ACPI_VIDEO)
Rafael J. Wysocki8e5c2b72013-07-25 21:43:39 +020053extern int acpi_video_register(void);
Zhao Yakui86e437f2009-06-16 11:23:13 +080054extern void acpi_video_unregister(void);
Matthew Garrette92a7162010-01-12 14:17:03 -050055extern int acpi_video_get_edid(struct acpi_device *device, int type,
56 int device_id, void **edid);
Hans de Goede87521e12015-06-16 16:27:48 +020057extern enum acpi_backlight_type acpi_video_get_backlight_type(void);
58extern void acpi_video_set_dmi_backlight_type(enum acpi_backlight_type type);
Hans de Goede382d1162016-01-14 09:41:47 +010059/*
60 * Note: The value returned by acpi_video_handles_brightness_key_presses()
61 * may change over time and should not be cached.
62 */
Hans de Goede90b066b2015-12-22 19:09:48 +010063extern bool acpi_video_handles_brightness_key_presses(void);
Aaron Lu05950092016-04-27 20:45:04 +080064extern int acpi_video_get_levels(struct acpi_device *device,
Aaron Lu9f9cd7e2016-05-21 15:30:46 +080065 struct acpi_video_device_brightness **dev_br,
66 int *pmax_level);
Matthew Garrett74a365b2009-03-19 21:35:39 +000067#else
Arvind Yadav03462232016-06-23 00:26:01 +053068static inline int acpi_video_register(void) { return -ENODEV; }
Zhao Yakui86e437f2009-06-16 11:23:13 +080069static inline void acpi_video_unregister(void) { return; }
Matthew Garrette92a7162010-01-12 14:17:03 -050070static inline int acpi_video_get_edid(struct acpi_device *device, int type,
71 int device_id, void **edid)
72{
73 return -ENODEV;
74}
Hans de Goede87521e12015-06-16 16:27:48 +020075static inline enum acpi_backlight_type acpi_video_get_backlight_type(void)
76{
77 return acpi_backlight_vendor;
78}
Borislav Petkoveddda192015-06-24 12:01:49 +020079static inline void acpi_video_set_dmi_backlight_type(enum acpi_backlight_type type)
Hans de Goede87521e12015-06-16 16:27:48 +020080{
81}
Hans de Goede90b066b2015-12-22 19:09:48 +010082static inline bool acpi_video_handles_brightness_key_presses(void)
83{
84 return false;
85}
Arnd Bergmanne4f35c12016-05-12 23:00:12 +020086static inline int acpi_video_get_levels(struct acpi_device *device,
Aaron Lu9f9cd7e2016-05-21 15:30:46 +080087 struct acpi_video_device_brightness **dev_br,
88 int *pmax_level)
Aaron Lu05950092016-04-27 20:45:04 +080089{
90 return -ENODEV;
91}
Matthew Garrett74a365b2009-03-19 21:35:39 +000092#endif
93
94#endif