Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __DRM_OF_H__
3#define __DRM_OF_H__
4
5#include <linux/of_graph.h>
6#if IS_ENABLED(CONFIG_OF) && IS_ENABLED(CONFIG_DRM_PANEL_BRIDGE)
7#include <drm/drm_bridge.h>
8#endif
9
10struct component_master_ops;
11struct component_match;
12struct device;
13struct drm_device;
14struct drm_encoder;
15struct drm_panel;
16struct drm_bridge;
17struct device_node;
18
19#ifdef CONFIG_OF
20uint32_t drm_of_crtc_port_mask(struct drm_device *dev,
21 struct device_node *port);
22uint32_t drm_of_find_possible_crtcs(struct drm_device *dev,
23 struct device_node *port);
24void drm_of_component_match_add(struct device *master,
25 struct component_match **matchptr,
26 int (*compare)(struct device *, void *),
27 struct device_node *node);
28int drm_of_component_probe(struct device *dev,
29 int (*compare_of)(struct device *, void *),
30 const struct component_master_ops *m_ops);
31int drm_of_encoder_active_endpoint(struct device_node *node,
32 struct drm_encoder *encoder,
33 struct of_endpoint *endpoint);
34int drm_of_find_panel_or_bridge(const struct device_node *np,
35 int port, int endpoint,
36 struct drm_panel **panel,
37 struct drm_bridge **bridge);
38#else
39static inline uint32_t drm_of_crtc_port_mask(struct drm_device *dev,
40 struct device_node *port)
41{
42 return 0;
43}
44
45static inline uint32_t drm_of_find_possible_crtcs(struct drm_device *dev,
46 struct device_node *port)
47{
48 return 0;
49}
50
51static inline void
52drm_of_component_match_add(struct device *master,
53 struct component_match **matchptr,
54 int (*compare)(struct device *, void *),
55 struct device_node *node)
56{
57}
58
59static inline int
60drm_of_component_probe(struct device *dev,
61 int (*compare_of)(struct device *, void *),
62 const struct component_master_ops *m_ops)
63{
64 return -EINVAL;
65}
66
67static inline int drm_of_encoder_active_endpoint(struct device_node *node,
68 struct drm_encoder *encoder,
69 struct of_endpoint *endpoint)
70{
71 return -EINVAL;
72}
73static inline int drm_of_find_panel_or_bridge(const struct device_node *np,
74 int port, int endpoint,
75 struct drm_panel **panel,
76 struct drm_bridge **bridge)
77{
78 return -EINVAL;
79}
80#endif
81
82/*
83 * drm_of_panel_bridge_remove - remove panel bridge
84 * @np: device tree node containing panel bridge output ports
85 *
86 * Remove the panel bridge of a given DT node's port and endpoint number
87 *
88 * Returns zero if successful, or one of the standard error codes if it fails.
89 */
90static inline int drm_of_panel_bridge_remove(const struct device_node *np,
91 int port, int endpoint)
92{
93#if IS_ENABLED(CONFIG_OF) && IS_ENABLED(CONFIG_DRM_PANEL_BRIDGE)
94 struct drm_bridge *bridge;
95 struct device_node *remote;
96
97 remote = of_graph_get_remote_node(np, port, endpoint);
98 if (!remote)
99 return -ENODEV;
100
101 bridge = of_drm_find_bridge(remote);
102 drm_panel_bridge_remove(bridge);
103
104 return 0;
105#else
106 return -EINVAL;
107#endif
108}
109
110static inline int drm_of_encoder_active_endpoint_id(struct device_node *node,
111 struct drm_encoder *encoder)
112{
113 struct of_endpoint endpoint;
114 int ret = drm_of_encoder_active_endpoint(node, encoder,
115 &endpoint);
116
117 return ret ?: endpoint.id;
118}
119
120static inline int drm_of_encoder_active_port_id(struct device_node *node,
121 struct drm_encoder *encoder)
122{
123 struct of_endpoint endpoint;
124 int ret = drm_of_encoder_active_endpoint(node, encoder,
125 &endpoint);
126
127 return ret ?: endpoint.port;
128}
129
130#endif /* __DRM_OF_H__ */
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __DRM_OF_H__
3#define __DRM_OF_H__
4
5#include <linux/err.h>
6#include <linux/of_graph.h>
7#if IS_ENABLED(CONFIG_OF) && IS_ENABLED(CONFIG_DRM_PANEL_BRIDGE)
8#include <drm/drm_bridge.h>
9#endif
10
11struct component_master_ops;
12struct component_match;
13struct device;
14struct drm_device;
15struct drm_encoder;
16struct drm_panel;
17struct drm_bridge;
18struct device_node;
19struct mipi_dsi_device_info;
20struct mipi_dsi_host;
21
22/**
23 * enum drm_lvds_dual_link_pixels - Pixel order of an LVDS dual-link connection
24 * @DRM_LVDS_DUAL_LINK_EVEN_ODD_PIXELS: Even pixels are expected to be generated
25 * from the first port, odd pixels from the second port
26 * @DRM_LVDS_DUAL_LINK_ODD_EVEN_PIXELS: Odd pixels are expected to be generated
27 * from the first port, even pixels from the second port
28 */
29enum drm_lvds_dual_link_pixels {
30 DRM_LVDS_DUAL_LINK_EVEN_ODD_PIXELS = 0,
31 DRM_LVDS_DUAL_LINK_ODD_EVEN_PIXELS = 1,
32};
33
34#ifdef CONFIG_OF
35uint32_t drm_of_crtc_port_mask(struct drm_device *dev,
36 struct device_node *port);
37uint32_t drm_of_find_possible_crtcs(struct drm_device *dev,
38 struct device_node *port);
39void drm_of_component_match_add(struct device *master,
40 struct component_match **matchptr,
41 int (*compare)(struct device *, void *),
42 struct device_node *node);
43int drm_of_component_probe(struct device *dev,
44 int (*compare_of)(struct device *, void *),
45 const struct component_master_ops *m_ops);
46int drm_of_encoder_active_endpoint(struct device_node *node,
47 struct drm_encoder *encoder,
48 struct of_endpoint *endpoint);
49int drm_of_find_panel_or_bridge(const struct device_node *np,
50 int port, int endpoint,
51 struct drm_panel **panel,
52 struct drm_bridge **bridge);
53int drm_of_lvds_get_dual_link_pixel_order(const struct device_node *port1,
54 const struct device_node *port2);
55int drm_of_lvds_get_dual_link_pixel_order_sink(struct device_node *port1,
56 struct device_node *port2);
57int drm_of_lvds_get_data_mapping(const struct device_node *port);
58int drm_of_get_data_lanes_count(const struct device_node *endpoint,
59 const unsigned int min, const unsigned int max);
60int drm_of_get_data_lanes_count_ep(const struct device_node *port,
61 int port_reg, int reg,
62 const unsigned int min,
63 const unsigned int max);
64#else
65static inline uint32_t drm_of_crtc_port_mask(struct drm_device *dev,
66 struct device_node *port)
67{
68 return 0;
69}
70
71static inline uint32_t drm_of_find_possible_crtcs(struct drm_device *dev,
72 struct device_node *port)
73{
74 return 0;
75}
76
77static inline void
78drm_of_component_match_add(struct device *master,
79 struct component_match **matchptr,
80 int (*compare)(struct device *, void *),
81 struct device_node *node)
82{
83}
84
85static inline int
86drm_of_component_probe(struct device *dev,
87 int (*compare_of)(struct device *, void *),
88 const struct component_master_ops *m_ops)
89{
90 return -EINVAL;
91}
92
93static inline int drm_of_encoder_active_endpoint(struct device_node *node,
94 struct drm_encoder *encoder,
95 struct of_endpoint *endpoint)
96{
97 return -EINVAL;
98}
99static inline int drm_of_find_panel_or_bridge(const struct device_node *np,
100 int port, int endpoint,
101 struct drm_panel **panel,
102 struct drm_bridge **bridge)
103{
104 return -EINVAL;
105}
106
107static inline int
108drm_of_lvds_get_dual_link_pixel_order(const struct device_node *port1,
109 const struct device_node *port2)
110{
111 return -EINVAL;
112}
113
114static inline int
115drm_of_lvds_get_dual_link_pixel_order_sink(struct device_node *port1,
116 struct device_node *port2)
117{
118 return -EINVAL;
119}
120
121static inline int
122drm_of_lvds_get_data_mapping(const struct device_node *port)
123{
124 return -EINVAL;
125}
126
127static inline int
128drm_of_get_data_lanes_count(const struct device_node *endpoint,
129 const unsigned int min, const unsigned int max)
130{
131 return -EINVAL;
132}
133
134static inline int
135drm_of_get_data_lanes_count_ep(const struct device_node *port,
136 int port_reg, int reg,
137 const unsigned int min,
138 const unsigned int max)
139{
140 return -EINVAL;
141}
142#endif
143
144#if IS_ENABLED(CONFIG_OF) && IS_ENABLED(CONFIG_DRM_MIPI_DSI)
145struct mipi_dsi_host *drm_of_get_dsi_bus(struct device *dev);
146#else
147static inline struct
148mipi_dsi_host *drm_of_get_dsi_bus(struct device *dev)
149{
150 return ERR_PTR(-EINVAL);
151}
152#endif /* CONFIG_OF && CONFIG_DRM_MIPI_DSI */
153
154/*
155 * drm_of_panel_bridge_remove - remove panel bridge
156 * @np: device tree node containing panel bridge output ports
157 *
158 * Remove the panel bridge of a given DT node's port and endpoint number
159 *
160 * Returns zero if successful, or one of the standard error codes if it fails.
161 */
162static inline int drm_of_panel_bridge_remove(const struct device_node *np,
163 int port, int endpoint)
164{
165#if IS_ENABLED(CONFIG_OF) && IS_ENABLED(CONFIG_DRM_PANEL_BRIDGE)
166 struct drm_bridge *bridge;
167 struct device_node *remote;
168
169 remote = of_graph_get_remote_node(np, port, endpoint);
170 if (!remote)
171 return -ENODEV;
172
173 bridge = of_drm_find_bridge(remote);
174 drm_panel_bridge_remove(bridge);
175
176 return 0;
177#else
178 return -EINVAL;
179#endif
180}
181
182static inline int drm_of_encoder_active_endpoint_id(struct device_node *node,
183 struct drm_encoder *encoder)
184{
185 struct of_endpoint endpoint;
186 int ret = drm_of_encoder_active_endpoint(node, encoder,
187 &endpoint);
188
189 return ret ?: endpoint.id;
190}
191
192static inline int drm_of_encoder_active_port_id(struct device_node *node,
193 struct drm_encoder *encoder)
194{
195 struct of_endpoint endpoint;
196 int ret = drm_of_encoder_active_endpoint(node, encoder,
197 &endpoint);
198
199 return ret ?: endpoint.port;
200}
201
202#endif /* __DRM_OF_H__ */