vga_switcheroo.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /*
  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. #ifndef _LINUX_VGA_SWITCHEROO_H_
  10. #define _LINUX_VGA_SWITCHEROO_H_
  11. #include <linux/fb.h>
  12. struct pci_dev;
  13. enum vga_switcheroo_state {
  14. VGA_SWITCHEROO_OFF,
  15. VGA_SWITCHEROO_ON,
  16. /* below are referred only from vga_switcheroo_get_client_state() */
  17. VGA_SWITCHEROO_INIT,
  18. VGA_SWITCHEROO_NOT_FOUND,
  19. };
  20. enum vga_switcheroo_client_id {
  21. VGA_SWITCHEROO_IGD,
  22. VGA_SWITCHEROO_DIS,
  23. VGA_SWITCHEROO_MAX_CLIENTS,
  24. };
  25. struct vga_switcheroo_handler {
  26. int (*switchto)(enum vga_switcheroo_client_id id);
  27. int (*power_state)(enum vga_switcheroo_client_id id,
  28. enum vga_switcheroo_state state);
  29. int (*init)(void);
  30. int (*get_client_id)(struct pci_dev *pdev);
  31. };
  32. struct vga_switcheroo_client_ops {
  33. void (*set_gpu_state)(struct pci_dev *dev, enum vga_switcheroo_state);
  34. void (*reprobe)(struct pci_dev *dev);
  35. bool (*can_switch)(struct pci_dev *dev);
  36. };
  37. #if defined(CONFIG_VGA_SWITCHEROO)
  38. void vga_switcheroo_unregister_client(struct pci_dev *dev);
  39. int vga_switcheroo_register_client(struct pci_dev *dev,
  40. const struct vga_switcheroo_client_ops *ops,
  41. bool driver_power_control);
  42. int vga_switcheroo_register_audio_client(struct pci_dev *pdev,
  43. const struct vga_switcheroo_client_ops *ops,
  44. int id, bool active);
  45. void vga_switcheroo_client_fb_set(struct pci_dev *dev,
  46. struct fb_info *info);
  47. int vga_switcheroo_register_handler(struct vga_switcheroo_handler *handler);
  48. void vga_switcheroo_unregister_handler(void);
  49. int vga_switcheroo_process_delayed_switch(void);
  50. int vga_switcheroo_get_client_state(struct pci_dev *dev);
  51. void vga_switcheroo_set_dynamic_switch(struct pci_dev *pdev, enum vga_switcheroo_state dynamic);
  52. int vga_switcheroo_init_domain_pm_ops(struct device *dev, struct dev_pm_domain *domain);
  53. void vga_switcheroo_fini_domain_pm_ops(struct device *dev);
  54. int vga_switcheroo_init_domain_pm_optimus_hdmi_audio(struct device *dev, struct dev_pm_domain *domain);
  55. #else
  56. static inline void vga_switcheroo_unregister_client(struct pci_dev *dev) {}
  57. static inline int vga_switcheroo_register_client(struct pci_dev *dev,
  58. const struct vga_switcheroo_client_ops *ops, bool driver_power_control) { return 0; }
  59. static inline void vga_switcheroo_client_fb_set(struct pci_dev *dev, struct fb_info *info) {}
  60. static inline int vga_switcheroo_register_handler(struct vga_switcheroo_handler *handler) { return 0; }
  61. static inline int vga_switcheroo_register_audio_client(struct pci_dev *pdev,
  62. const struct vga_switcheroo_client_ops *ops,
  63. int id, bool active) { return 0; }
  64. static inline void vga_switcheroo_unregister_handler(void) {}
  65. static inline int vga_switcheroo_process_delayed_switch(void) { return 0; }
  66. static inline int vga_switcheroo_get_client_state(struct pci_dev *dev) { return VGA_SWITCHEROO_ON; }
  67. static inline void vga_switcheroo_set_dynamic_switch(struct pci_dev *pdev, enum vga_switcheroo_state dynamic) {}
  68. static inline int vga_switcheroo_init_domain_pm_ops(struct device *dev, struct dev_pm_domain *domain) { return -EINVAL; }
  69. static inline void vga_switcheroo_fini_domain_pm_ops(struct device *dev) {}
  70. static inline int vga_switcheroo_init_domain_pm_optimus_hdmi_audio(struct device *dev, struct dev_pm_domain *domain) { return -EINVAL; }
  71. #endif
  72. #endif /* _LINUX_VGA_SWITCHEROO_H_ */