blob: 5a91cb16c8fa53d4b84dcbcf332605c78483d171 [file] [log] [blame]
Sascha Hauere692da42012-09-21 10:07:47 +02001#ifndef _IMX_DRM_H_
2#define _IMX_DRM_H_
3
Russell Kinge7d62312013-11-03 15:38:09 +00004struct device_node;
Philipp Zabeleeb14ec2013-04-08 18:04:32 +02005struct drm_crtc;
6struct drm_connector;
7struct drm_device;
Russell King8a51a332013-11-03 13:28:24 +00008struct drm_display_mode;
Philipp Zabeleeb14ec2013-04-08 18:04:32 +02009struct drm_encoder;
Sascha Hauere692da42012-09-21 10:07:47 +020010struct drm_fbdev_cma;
Philipp Zabeleeb14ec2013-04-08 18:04:32 +020011struct drm_framebuffer;
Philipp Zabel43895592015-11-06 11:08:02 +010012struct drm_plane;
Russell Kinge7d62312013-11-03 15:38:09 +000013struct imx_drm_crtc;
Philipp Zabeleeb14ec2013-04-08 18:04:32 +020014struct platform_device;
Sascha Hauere692da42012-09-21 10:07:47 +020015
Philipp Zabel49f98bc2016-07-06 14:49:24 +020016struct imx_crtc_state {
17 struct drm_crtc_state base;
Liu Ying032003c2016-07-08 17:40:58 +080018 u32 bus_format;
19 u32 bus_flags;
20 int di_hsync_pin;
21 int di_vsync_pin;
22};
23
Philipp Zabel49f98bc2016-07-06 14:49:24 +020024static inline struct imx_crtc_state *to_imx_crtc_state(struct drm_crtc_state *s)
25{
26 return container_of(s, struct imx_crtc_state, base);
27}
Liu Ying032003c2016-07-08 17:40:58 +080028
Sascha Hauere692da42012-09-21 10:07:47 +020029struct imx_drm_crtc_helper_funcs {
30 int (*enable_vblank)(struct drm_crtc *crtc);
31 void (*disable_vblank)(struct drm_crtc *crtc);
Sascha Hauere692da42012-09-21 10:07:47 +020032 const struct drm_crtc_helper_funcs *crtc_helper_funcs;
33 const struct drm_crtc_funcs *crtc_funcs;
34};
35
Russell King32266b42013-11-03 12:26:23 +000036int imx_drm_add_crtc(struct drm_device *drm, struct drm_crtc *crtc,
Philipp Zabel43895592015-11-06 11:08:02 +010037 struct imx_drm_crtc **new_crtc, struct drm_plane *primary_plane,
Sascha Hauere692da42012-09-21 10:07:47 +020038 const struct imx_drm_crtc_helper_funcs *imx_helper_funcs,
Philipp Zabel655b43c2014-03-05 10:20:52 +010039 struct device_node *port);
Sascha Hauere692da42012-09-21 10:07:47 +020040int imx_drm_remove_crtc(struct imx_drm_crtc *);
41int imx_drm_init_drm(struct platform_device *pdev,
42 int preferred_bpp);
43int imx_drm_exit_drm(void);
44
Sascha Hauere692da42012-09-21 10:07:47 +020045void imx_drm_mode_config_init(struct drm_device *drm);
46
47struct drm_gem_cma_object *imx_drm_fb_get_obj(struct drm_framebuffer *fb);
48
Russell King9e2d4102013-11-03 14:04:47 +000049int imx_drm_encoder_parse_of(struct drm_device *drm,
50 struct drm_encoder *encoder, struct device_node *np);
Sascha Hauere692da42012-09-21 10:07:47 +020051
Russell King8a51a332013-11-03 13:28:24 +000052void imx_drm_connector_destroy(struct drm_connector *connector);
53void imx_drm_encoder_destroy(struct drm_encoder *encoder);
Russell Kingbaa68c42013-11-09 11:20:55 +000054
Sascha Hauere692da42012-09-21 10:07:47 +020055#endif /* _IMX_DRM_H_ */