blob: 9e7027d6c2f6de7a2b58bd5852165063c6625547 [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 Padovaneafd5402015-07-16 12:23:32 -030028void exynos_drm_crtc_finish_pageflip(struct exynos_drm_crtc *exynos_crtc);
Sean Paul080be03d2014-02-19 21:02:55 +090029void exynos_drm_crtc_complete_scanout(struct drm_framebuffer *fb);
30
Inki Daef37cd5e2014-05-09 14:25:20 +090031/* This function gets pipe value to crtc device matched with out_type. */
32int exynos_drm_crtc_get_pipe_from_type(struct drm_device *drm_dev,
Gustavo Padovancf67cc92015-08-11 17:38:06 +090033 enum exynos_drm_output_type out_type);
Inki Daef37cd5e2014-05-09 14:25:20 +090034
YoungJun Cho5595d4d2014-07-17 18:01:19 +090035/*
36 * This function calls the crtc device(manager)'s te_handler() callback
37 * to trigger to transfer video image at the tearing effect synchronization
38 * signal.
39 */
40void exynos_drm_crtc_te_handler(struct drm_crtc *crtc);
41
Inki Dae1c248b72011-10-04 19:19:01 +090042#endif