blob: 502073a53dd320b115925a654ef7dabdbd49872e [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
Ozan Çağlayand3decf32012-06-14 15:02:35 +030010#ifndef _LINUX_VGA_SWITCHEROO_H_
11#define _LINUX_VGA_SWITCHEROO_H_
12
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100013#include <linux/fb.h>
14
Randy Dunlapf8fee8f2012-06-15 12:46:17 -070015struct pci_dev;
16
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100017enum vga_switcheroo_state {
18 VGA_SWITCHEROO_OFF,
19 VGA_SWITCHEROO_ON,
Takashi Iwaic8e9cf72012-06-07 12:15:15 +020020 /* below are referred only from vga_switcheroo_get_client_state() */
21 VGA_SWITCHEROO_INIT,
22 VGA_SWITCHEROO_NOT_FOUND,
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100023};
24
25enum vga_switcheroo_client_id {
26 VGA_SWITCHEROO_IGD,
27 VGA_SWITCHEROO_DIS,
28 VGA_SWITCHEROO_MAX_CLIENTS,
29};
30
31struct vga_switcheroo_handler {
32 int (*switchto)(enum vga_switcheroo_client_id id);
33 int (*power_state)(enum vga_switcheroo_client_id id,
34 enum vga_switcheroo_state state);
35 int (*init)(void);
36 int (*get_client_id)(struct pci_dev *pdev);
37};
38
Takashi Iwai26ec6852012-05-11 07:51:17 +020039struct vga_switcheroo_client_ops {
40 void (*set_gpu_state)(struct pci_dev *dev, enum vga_switcheroo_state);
41 void (*reprobe)(struct pci_dev *dev);
42 bool (*can_switch)(struct pci_dev *dev);
43};
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100044
45#if defined(CONFIG_VGA_SWITCHEROO)
46void vga_switcheroo_unregister_client(struct pci_dev *dev);
47int vga_switcheroo_register_client(struct pci_dev *dev,
Dave Airlie0d697042012-09-10 12:28:36 +100048 const struct vga_switcheroo_client_ops *ops,
49 bool driver_power_control);
Takashi Iwai3e9e63d2012-04-26 14:29:48 +020050int vga_switcheroo_register_audio_client(struct pci_dev *pdev,
51 const struct vga_switcheroo_client_ops *ops,
52 int id, bool active);
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100053
54void vga_switcheroo_client_fb_set(struct pci_dev *dev,
55 struct fb_info *info);
56
57int vga_switcheroo_register_handler(struct vga_switcheroo_handler *handler);
58void vga_switcheroo_unregister_handler(void);
59
60int vga_switcheroo_process_delayed_switch(void);
61
Takashi Iwaic8e9cf72012-06-07 12:15:15 +020062int vga_switcheroo_get_client_state(struct pci_dev *dev);
63
Dave Airlie0d697042012-09-10 12:28:36 +100064void vga_switcheroo_set_dynamic_switch(struct pci_dev *pdev, enum vga_switcheroo_state dynamic);
65
66int vga_switcheroo_init_domain_pm_ops(struct device *dev, struct dev_pm_domain *domain);
67int vga_switcheroo_init_domain_pm_optimus_hdmi_audio(struct device *dev, struct dev_pm_domain *domain);
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100068#else
69
70static inline void vga_switcheroo_unregister_client(struct pci_dev *dev) {}
71static inline int vga_switcheroo_register_client(struct pci_dev *dev,
Dave Airlie0d697042012-09-10 12:28:36 +100072 const struct vga_switcheroo_client_ops *ops, bool driver_power_control) { return 0; }
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100073static inline void vga_switcheroo_client_fb_set(struct pci_dev *dev, struct fb_info *info) {}
74static inline int vga_switcheroo_register_handler(struct vga_switcheroo_handler *handler) { return 0; }
Takashi Iwai3e9e63d2012-04-26 14:29:48 +020075static inline int vga_switcheroo_register_audio_client(struct pci_dev *pdev,
76 const struct vga_switcheroo_client_ops *ops,
77 int id, bool active) { return 0; }
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100078static inline void vga_switcheroo_unregister_handler(void) {}
79static inline int vga_switcheroo_process_delayed_switch(void) { return 0; }
Takashi Iwai505cff02012-06-08 12:49:17 +020080static inline int vga_switcheroo_get_client_state(struct pci_dev *dev) { return VGA_SWITCHEROO_ON; }
Takashi Iwaic8e9cf72012-06-07 12:15:15 +020081
Dave Airlie0d697042012-09-10 12:28:36 +100082static inline void vga_switcheroo_set_dynamic_switch(struct pci_dev *pdev, enum vga_switcheroo_state dynamic) {}
83
84static inline int vga_switcheroo_init_domain_pm_ops(struct device *dev, struct dev_pm_domain *domain) { return -EINVAL; }
85static inline int vga_switcheroo_init_domain_pm_optimus_hdmi_audio(struct device *dev, struct dev_pm_domain *domain) { return -EINVAL; }
Dave Airlie6a9ee8a2010-02-01 15:38:10 +100086
87#endif
Ozan Çağlayand3decf32012-06-14 15:02:35 +030088#endif /* _LINUX_VGA_SWITCHEROO_H_ */