xref: /linux/drivers/gpu/drm/xe/display/xe_display.h (revision 7f71507851fc7764b36a3221839607d3a45c2025)
1 /* SPDX-License-Identifier: MIT */
2 /*
3  * Copyright © 2023 Intel Corporation
4  */
5 
6 #ifndef _XE_DISPLAY_H_
7 #define _XE_DISPLAY_H_
8 
9 #include "xe_device.h"
10 
11 struct drm_driver;
12 
13 #if IS_ENABLED(CONFIG_DRM_XE_DISPLAY)
14 
15 bool xe_display_driver_probe_defer(struct pci_dev *pdev);
16 void xe_display_driver_set_hooks(struct drm_driver *driver);
17 void xe_display_driver_remove(struct xe_device *xe);
18 
19 int xe_display_create(struct xe_device *xe);
20 
21 int xe_display_probe(struct xe_device *xe);
22 
23 int xe_display_init_nommio(struct xe_device *xe);
24 int xe_display_init_noirq(struct xe_device *xe);
25 int xe_display_init_noaccel(struct xe_device *xe);
26 int xe_display_init(struct xe_device *xe);
27 void xe_display_fini(struct xe_device *xe);
28 
29 void xe_display_register(struct xe_device *xe);
30 void xe_display_unregister(struct xe_device *xe);
31 
32 void xe_display_irq_handler(struct xe_device *xe, u32 master_ctl);
33 void xe_display_irq_enable(struct xe_device *xe, u32 gu_misc_iir);
34 void xe_display_irq_reset(struct xe_device *xe);
35 void xe_display_irq_postinstall(struct xe_device *xe, struct xe_gt *gt);
36 
37 void xe_display_pm_suspend(struct xe_device *xe);
38 void xe_display_pm_shutdown(struct xe_device *xe);
39 void xe_display_pm_suspend_late(struct xe_device *xe);
40 void xe_display_pm_shutdown_late(struct xe_device *xe);
41 void xe_display_pm_resume_early(struct xe_device *xe);
42 void xe_display_pm_resume(struct xe_device *xe);
43 void xe_display_pm_runtime_suspend(struct xe_device *xe);
44 void xe_display_pm_runtime_resume(struct xe_device *xe);
45 
46 #else
47 
48 static inline int xe_display_driver_probe_defer(struct pci_dev *pdev) { return 0; }
49 static inline void xe_display_driver_set_hooks(struct drm_driver *driver) { }
50 static inline void xe_display_driver_remove(struct xe_device *xe) {}
51 
52 static inline int xe_display_create(struct xe_device *xe) { return 0; }
53 
54 static inline int xe_display_probe(struct xe_device *xe) { return 0; }
55 
56 static inline int xe_display_init_nommio(struct xe_device *xe) { return 0; }
57 static inline int xe_display_init_noirq(struct xe_device *xe) { return 0; }
58 static inline int xe_display_init_noaccel(struct xe_device *xe) { return 0; }
59 static inline int xe_display_init(struct xe_device *xe) { return 0; }
60 static inline void xe_display_fini(struct xe_device *xe) {}
61 
62 static inline void xe_display_register(struct xe_device *xe) {}
63 static inline void xe_display_unregister(struct xe_device *xe) {}
64 
65 static inline void xe_display_irq_handler(struct xe_device *xe, u32 master_ctl) {}
66 static inline void xe_display_irq_enable(struct xe_device *xe, u32 gu_misc_iir) {}
67 static inline void xe_display_irq_reset(struct xe_device *xe) {}
68 static inline void xe_display_irq_postinstall(struct xe_device *xe, struct xe_gt *gt) {}
69 
70 static inline void xe_display_pm_suspend(struct xe_device *xe) {}
71 static inline void xe_display_pm_shutdown(struct xe_device *xe) {}
72 static inline void xe_display_pm_suspend_late(struct xe_device *xe) {}
73 static inline void xe_display_pm_shutdown_late(struct xe_device *xe) {}
74 static inline void xe_display_pm_resume_early(struct xe_device *xe) {}
75 static inline void xe_display_pm_resume(struct xe_device *xe) {}
76 static inline void xe_display_pm_runtime_suspend(struct xe_device *xe) {}
77 static inline void xe_display_pm_runtime_resume(struct xe_device *xe) {}
78 
79 #endif /* CONFIG_DRM_XE_DISPLAY */
80 #endif /* _XE_DISPLAY_H_ */
81