1 /* SPDX-License-Identifier: MIT */
2 /*
3 * Copyright © 2023 Intel Corporation
4 */
5
6 #ifndef __INTEL_DP_TUNNEL_H__
7 #define __INTEL_DP_TUNNEL_H__
8
9 #include <linux/errno.h>
10 #include <linux/types.h>
11
12 struct drm_connector_state;
13 struct drm_modeset_acquire_ctx;
14 struct intel_atomic_state;
15 struct intel_connector;
16 struct intel_crtc;
17 struct intel_crtc_state;
18 struct intel_display;
19 struct intel_dp;
20 struct intel_encoder;
21 struct intel_link_bw_limits;
22
23 #if (IS_ENABLED(CONFIG_DRM_I915_DP_TUNNEL) && defined(I915)) || \
24 (IS_ENABLED(CONFIG_DRM_XE_DP_TUNNEL) && !defined(I915))
25
26 int intel_dp_tunnel_detect(struct intel_dp *intel_dp, struct drm_modeset_acquire_ctx *ctx);
27 void intel_dp_tunnel_disconnect(struct intel_dp *intel_dp);
28 void intel_dp_tunnel_destroy(struct intel_dp *intel_dp);
29 void intel_dp_tunnel_resume(struct intel_dp *intel_dp,
30 const struct intel_crtc_state *crtc_state,
31 bool dpcd_updated);
32 void intel_dp_tunnel_suspend(struct intel_dp *intel_dp);
33
34 bool intel_dp_tunnel_bw_alloc_is_enabled(struct intel_dp *intel_dp);
35
36 void
37 intel_dp_tunnel_atomic_cleanup_inherited_state(struct intel_atomic_state *state);
38
39 int intel_dp_tunnel_atomic_compute_stream_bw(struct intel_atomic_state *state,
40 struct intel_dp *intel_dp,
41 const struct intel_connector *connector,
42 struct intel_crtc_state *crtc_state);
43 void intel_dp_tunnel_atomic_clear_stream_bw(struct intel_atomic_state *state,
44 struct intel_crtc_state *crtc_state);
45
46 int intel_dp_tunnel_atomic_add_state_for_crtc(struct intel_atomic_state *state,
47 struct intel_crtc *crtc);
48 int intel_dp_tunnel_atomic_check_link(struct intel_atomic_state *state,
49 struct intel_link_bw_limits *limits);
50 int intel_dp_tunnel_atomic_check_state(struct intel_atomic_state *state,
51 struct intel_dp *intel_dp,
52 struct intel_connector *connector);
53
54 void intel_dp_tunnel_atomic_alloc_bw(struct intel_atomic_state *state);
55
56 int intel_dp_tunnel_mgr_init(struct intel_display *display);
57 void intel_dp_tunnel_mgr_cleanup(struct intel_display *display);
58
59 #else
60
61 static inline int
intel_dp_tunnel_detect(struct intel_dp * intel_dp,struct drm_modeset_acquire_ctx * ctx)62 intel_dp_tunnel_detect(struct intel_dp *intel_dp, struct drm_modeset_acquire_ctx *ctx)
63 {
64 return -EOPNOTSUPP;
65 }
66
intel_dp_tunnel_disconnect(struct intel_dp * intel_dp)67 static inline void intel_dp_tunnel_disconnect(struct intel_dp *intel_dp) {}
intel_dp_tunnel_destroy(struct intel_dp * intel_dp)68 static inline void intel_dp_tunnel_destroy(struct intel_dp *intel_dp) {}
intel_dp_tunnel_resume(struct intel_dp * intel_dp,const struct intel_crtc_state * crtc_state,bool dpcd_updated)69 static inline void intel_dp_tunnel_resume(struct intel_dp *intel_dp,
70 const struct intel_crtc_state *crtc_state,
71 bool dpcd_updated) {}
intel_dp_tunnel_suspend(struct intel_dp * intel_dp)72 static inline void intel_dp_tunnel_suspend(struct intel_dp *intel_dp) {}
73
intel_dp_tunnel_bw_alloc_is_enabled(struct intel_dp * intel_dp)74 static inline bool intel_dp_tunnel_bw_alloc_is_enabled(struct intel_dp *intel_dp)
75 {
76 return false;
77 }
78
79 static inline void
intel_dp_tunnel_atomic_cleanup_inherited_state(struct intel_atomic_state * state)80 intel_dp_tunnel_atomic_cleanup_inherited_state(struct intel_atomic_state *state) {}
81
82 static inline int
intel_dp_tunnel_atomic_compute_stream_bw(struct intel_atomic_state * state,struct intel_dp * intel_dp,const struct intel_connector * connector,struct intel_crtc_state * crtc_state)83 intel_dp_tunnel_atomic_compute_stream_bw(struct intel_atomic_state *state,
84 struct intel_dp *intel_dp,
85 const struct intel_connector *connector,
86 struct intel_crtc_state *crtc_state)
87 {
88 return 0;
89 }
90
91 static inline void
intel_dp_tunnel_atomic_clear_stream_bw(struct intel_atomic_state * state,struct intel_crtc_state * crtc_state)92 intel_dp_tunnel_atomic_clear_stream_bw(struct intel_atomic_state *state,
93 struct intel_crtc_state *crtc_state) {}
94
95 static inline int
intel_dp_tunnel_atomic_add_state_for_crtc(struct intel_atomic_state * state,struct intel_crtc * crtc)96 intel_dp_tunnel_atomic_add_state_for_crtc(struct intel_atomic_state *state,
97 struct intel_crtc *crtc)
98 {
99 return 0;
100 }
101
102 static inline int
intel_dp_tunnel_atomic_check_link(struct intel_atomic_state * state,struct intel_link_bw_limits * limits)103 intel_dp_tunnel_atomic_check_link(struct intel_atomic_state *state,
104 struct intel_link_bw_limits *limits)
105 {
106 return 0;
107 }
108
109 static inline int
intel_dp_tunnel_atomic_check_state(struct intel_atomic_state * state,struct intel_dp * intel_dp,struct intel_connector * connector)110 intel_dp_tunnel_atomic_check_state(struct intel_atomic_state *state,
111 struct intel_dp *intel_dp,
112 struct intel_connector *connector)
113 {
114 return 0;
115 }
116
117 static inline int
intel_dp_tunnel_atomic_alloc_bw(struct intel_atomic_state * state)118 intel_dp_tunnel_atomic_alloc_bw(struct intel_atomic_state *state)
119 {
120 return 0;
121 }
122
123 static inline int
intel_dp_tunnel_mgr_init(struct intel_display * display)124 intel_dp_tunnel_mgr_init(struct intel_display *display)
125 {
126 return 0;
127 }
128
intel_dp_tunnel_mgr_cleanup(struct intel_display * display)129 static inline void intel_dp_tunnel_mgr_cleanup(struct intel_display *display) {}
130
131 #endif /* CONFIG_DRM_I915_DP_TUNNEL || CONFIG_DRM_XE_DP_TUNNEL */
132
133 #endif /* __INTEL_DP_TUNNEL_H__ */
134