blob: f87d4abda6f7b5ca0f69712a887acd065f252d69 [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 Padovan93bca242015-01-18 18:16:23 +090020struct exynos_drm_crtc *exynos_drm_crtc_create(struct drm_device *drm_dev,
Krzysztof Kozlowskif3aaf762015-05-07 09:04:45 +090021 struct drm_plane *plane,
22 int pipe,
23 enum exynos_drm_output_type type,
24 const struct exynos_drm_crtc_ops *ops,
25 void *context);
Sean Paul080be03d2014-02-19 21:02:55 +090026int exynos_drm_crtc_enable_vblank(struct drm_device *dev, int pipe);
27void exynos_drm_crtc_disable_vblank(struct drm_device *dev, int pipe);
Gustavo Padovanc4533662015-08-15 13:26:18 -030028void exynos_drm_crtc_wait_pending_update(struct exynos_drm_crtc *exynos_crtc);
Gustavo Padovan822f6df2015-08-15 13:26:14 -030029void exynos_drm_crtc_finish_update(struct exynos_drm_crtc *exynos_crtc,
30 struct exynos_drm_plane *exynos_plane);
Sean Paul080be03d2014-02-19 21:02:55 +090031void exynos_drm_crtc_complete_scanout(struct drm_framebuffer *fb);
32
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,
Gustavo Padovancf67cc92015-08-11 17:38:06 +090035 enum exynos_drm_output_type out_type);
Inki Daef37cd5e2014-05-09 14:25:20 +090036
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