blob: 60da41fe9dc2b4a7d0496c01ead943b0b75c9c3e [file] [log] [blame]
Dave Airlie6a9ee8a2010-02-01 15:38:10 +10001/*
2 * Copyright (c) 2010 Red Hat Inc.
3 * Author : Dave Airlie <airlied@redhat.com>
4 *
5 * Licensed under GPLv2
6 *
7 * vga_switcheroo.h - Support for laptop with dual GPU using one set of outputs
8 */
9
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100010#include <linux/fb.h>
11
12enum vga_switcheroo_state {
13 VGA_SWITCHEROO_OFF,
14 VGA_SWITCHEROO_ON,
Takashi Iwaic8e9cf72012-06-07 12:15:15 +020015 /* below are referred only from vga_switcheroo_get_client_state() */
16 VGA_SWITCHEROO_INIT,
17 VGA_SWITCHEROO_NOT_FOUND,
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100018};
19
20enum vga_switcheroo_client_id {
21 VGA_SWITCHEROO_IGD,
22 VGA_SWITCHEROO_DIS,
23 VGA_SWITCHEROO_MAX_CLIENTS,
24};
25
26struct vga_switcheroo_handler {
27 int (*switchto)(enum vga_switcheroo_client_id id);
28 int (*power_state)(enum vga_switcheroo_client_id id,
29 enum vga_switcheroo_state state);
30 int (*init)(void);
31 int (*get_client_id)(struct pci_dev *pdev);
32};
33
Takashi Iwai26ec6852012-05-11 07:51:17 +020034struct vga_switcheroo_client_ops {
35 void (*set_gpu_state)(struct pci_dev *dev, enum vga_switcheroo_state);
36 void (*reprobe)(struct pci_dev *dev);
37 bool (*can_switch)(struct pci_dev *dev);
38};
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100039
40#if defined(CONFIG_VGA_SWITCHEROO)
41void vga_switcheroo_unregister_client(struct pci_dev *dev);
42int vga_switcheroo_register_client(struct pci_dev *dev,
Takashi Iwai26ec6852012-05-11 07:51:17 +020043 const struct vga_switcheroo_client_ops *ops);
Takashi Iwai3e9e63d2012-04-26 14:29:48 +020044int vga_switcheroo_register_audio_client(struct pci_dev *pdev,
45 const struct vga_switcheroo_client_ops *ops,
46 int id, bool active);
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100047
48void vga_switcheroo_client_fb_set(struct pci_dev *dev,
49 struct fb_info *info);
50
51int vga_switcheroo_register_handler(struct vga_switcheroo_handler *handler);
52void vga_switcheroo_unregister_handler(void);
53
54int vga_switcheroo_process_delayed_switch(void);
55
Takashi Iwaic8e9cf72012-06-07 12:15:15 +020056int vga_switcheroo_get_client_state(struct pci_dev *dev);
57
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100058#else
59
60static inline void vga_switcheroo_unregister_client(struct pci_dev *dev) {}
61static inline int vga_switcheroo_register_client(struct pci_dev *dev,
Takashi Iwai26ec6852012-05-11 07:51:17 +020062 const struct vga_switcheroo_client_ops *ops) { return 0; }
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100063static inline void vga_switcheroo_client_fb_set(struct pci_dev *dev, struct fb_info *info) {}
64static inline int vga_switcheroo_register_handler(struct vga_switcheroo_handler *handler) { return 0; }
Takashi Iwai3e9e63d2012-04-26 14:29:48 +020065static inline int vga_switcheroo_register_audio_client(struct pci_dev *pdev,
66 const struct vga_switcheroo_client_ops *ops,
67 int id, bool active) { return 0; }
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100068static inline void vga_switcheroo_unregister_handler(void) {}
69static inline int vga_switcheroo_process_delayed_switch(void) { return 0; }
Takashi Iwai505cff02012-06-08 12:49:17 +020070static inline int vga_switcheroo_get_client_state(struct pci_dev *dev) { return VGA_SWITCHEROO_ON; }
Takashi Iwaic8e9cf72012-06-07 12:15:15 +020071
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100072
73#endif