1caab277bSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
2b5561412SLaurent Pinchart /*
3b5561412SLaurent Pinchart  * omap_crtc.h -- OMAP DRM CRTC
4b5561412SLaurent Pinchart  *
5b5561412SLaurent Pinchart  * Copyright (C) 2011 Texas Instruments
6b5561412SLaurent Pinchart  * Author: Rob Clark <rob@ti.com>
7b5561412SLaurent Pinchart  */
8b5561412SLaurent Pinchart 
9b5561412SLaurent Pinchart #ifndef __OMAPDRM_CRTC_H__
10b5561412SLaurent Pinchart #define __OMAPDRM_CRTC_H__
11b5561412SLaurent Pinchart 
12b5561412SLaurent Pinchart #include <linux/types.h>
13b5561412SLaurent Pinchart 
14b5561412SLaurent Pinchart enum omap_channel;
15b5561412SLaurent Pinchart 
16b5561412SLaurent Pinchart struct drm_crtc;
17b5561412SLaurent Pinchart struct drm_device;
18b5561412SLaurent Pinchart struct drm_plane;
1900b30e79SLaurent Pinchart struct omap_drm_pipeline;
20b5561412SLaurent Pinchart struct omap_dss_device;
21b5561412SLaurent Pinchart struct videomode;
22b5561412SLaurent Pinchart 
23b5561412SLaurent Pinchart struct videomode *omap_crtc_timings(struct drm_crtc *crtc);
24b5561412SLaurent Pinchart enum omap_channel omap_crtc_channel(struct drm_crtc *crtc);
2564cb8179SLaurent Pinchart void omap_crtc_pre_init(struct omap_drm_private *priv);
26845417b3SLaurent Pinchart void omap_crtc_pre_uninit(struct omap_drm_private *priv);
27b5561412SLaurent Pinchart struct drm_crtc *omap_crtc_init(struct drm_device *dev,
2800b30e79SLaurent Pinchart 				struct omap_drm_pipeline *pipe,
2900b30e79SLaurent Pinchart 				struct drm_plane *plane);
30b5561412SLaurent Pinchart int omap_crtc_wait_pending(struct drm_crtc *crtc);
31dfe9cfccSLaurent Pinchart void omap_crtc_error_irq(struct drm_crtc *crtc, u32 irqstatus);
32b5561412SLaurent Pinchart void omap_crtc_vblank_irq(struct drm_crtc *crtc);
33b5561412SLaurent Pinchart 
34b5561412SLaurent Pinchart #endif /* __OMAPDRM_CRTC_H__ */
35