blob: a705941527d16051a9c422509e86f2816521b4e3 [file] [log] [blame]
Inki Dae1c248b72011-10-04 19:19:01 +09001/* exynos_drm_crtc.h
2 *
3 * Copyright (c) 2011 Samsung Electronics Co., Ltd.
4 * Authors:
5 * Inki Dae <inki.dae@samsung.com>
6 * Joonyoung Shim <jy0922.shim@samsung.com>
7 * Seung-Woo Kim <sw0312.kim@samsung.com>
8 *
Inki Daed81aecb2012-12-18 02:30:17 +09009 * This program is free software; you can redistribute it and/or modify it
10 * under the terms of the GNU General Public License as published by the
11 * Free Software Foundation; either version 2 of the License, or (at your
12 * option) any later version.
Inki Dae1c248b72011-10-04 19:19:01 +090013 */
14
15#ifndef _EXYNOS_DRM_CRTC_H_
16#define _EXYNOS_DRM_CRTC_H_
17
Gustavo Padovancc2d8612014-11-13 17:24:06 +090018#include "exynos_drm_drv.h"
Sean Paul080be03d2014-02-19 21:02:55 +090019
Gustavo Padovan5d1741a2014-11-05 19:51:35 -020020int exynos_drm_crtc_create(struct exynos_drm_manager *manager, int pipe,
21 enum exynos_drm_output_type type);
Sean Paul080be03d2014-02-19 21:02:55 +090022int exynos_drm_crtc_enable_vblank(struct drm_device *dev, int pipe);
23void exynos_drm_crtc_disable_vblank(struct drm_device *dev, int pipe);
24void exynos_drm_crtc_finish_pageflip(struct drm_device *dev, int pipe);
25void exynos_drm_crtc_complete_scanout(struct drm_framebuffer *fb);
26
27void exynos_drm_crtc_plane_mode_set(struct drm_crtc *crtc,
Gustavo Padovan8837dee2014-11-03 18:13:27 -020028 struct exynos_drm_plane *plane);
Sean Paul080be03d2014-02-19 21:02:55 +090029void exynos_drm_crtc_plane_commit(struct drm_crtc *crtc, int zpos);
30void exynos_drm_crtc_plane_enable(struct drm_crtc *crtc, int zpos);
31void exynos_drm_crtc_plane_disable(struct drm_crtc *crtc, int zpos);
Inki Dae1c248b72011-10-04 19:19:01 +090032
Inki Daef37cd5e2014-05-09 14:25:20 +090033/* This function gets pipe value to crtc device matched with out_type. */
34int exynos_drm_crtc_get_pipe_from_type(struct drm_device *drm_dev,
35 unsigned int out_type);
36
YoungJun Cho5595d4d2014-07-17 18:01:19 +090037/*
38 * This function calls the crtc device(manager)'s te_handler() callback
39 * to trigger to transfer video image at the tearing effect synchronization
40 * signal.
41 */
42void exynos_drm_crtc_te_handler(struct drm_crtc *crtc);
43
Inki Dae1c248b72011-10-04 19:19:01 +090044#endif