blob: 808dad29607a17790c0bf9b69ba5493e021e3bfd [file] [log] [blame]
Inki Dae1c248b72011-10-04 19:19:01 +09001/* exynos_drm.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 *
9 * Permission is hereby granted, free of charge, to any person obtaining a
10 * copy of this software and associated documentation files (the "Software"),
11 * to deal in the Software without restriction, including without limitation
12 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
13 * and/or sell copies of the Software, and to permit persons to whom the
14 * Software is furnished to do so, subject to the following conditions:
15 *
16 * The above copyright notice and this permission notice (including the next
17 * paragraph) shall be included in all copies or substantial portions of the
18 * Software.
19 *
20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
23 * VA LINUX SYSTEMS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
24 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
25 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
26 * OTHER DEALINGS IN THE SOFTWARE.
27 */
Inki Dae1c248b72011-10-04 19:19:01 +090028#ifndef _EXYNOS_DRM_H_
29#define _EXYNOS_DRM_H_
30
David Howells718dced2012-10-04 18:21:50 +010031#include <uapi/drm/exynos_drm.h>
Joonyoung Shimd7f16422012-05-17 20:06:32 +090032
Inki Dae1c248b72011-10-04 19:19:01 +090033/**
Eun-Chul Kim607c50d2012-02-14 15:59:46 +090034 * A structure for lcd panel information.
Inki Dae1c248b72011-10-04 19:19:01 +090035 *
36 * @timing: default video mode for initializing
Eun-Chul Kim607c50d2012-02-14 15:59:46 +090037 * @width_mm: physical size of lcd width.
38 * @height_mm: physical size of lcd height.
39 */
40struct exynos_drm_panel_info {
41 struct fb_videomode timing;
42 u32 width_mm;
43 u32 height_mm;
44};
45
46/**
47 * Platform Specific Structure for DRM based FIMD.
48 *
49 * @panel: default panel info for initializing
Inki Dae1c248b72011-10-04 19:19:01 +090050 * @default_win: default window layer number to be used for UI.
51 * @bpp: default bit per pixel.
52 */
53struct exynos_drm_fimd_pdata {
Eun-Chul Kim607c50d2012-02-14 15:59:46 +090054 struct exynos_drm_panel_info panel;
Inki Dae1c248b72011-10-04 19:19:01 +090055 u32 vidcon0;
56 u32 vidcon1;
57 unsigned int default_win;
58 unsigned int bpp;
59};
60
Seung-Woo Kimd8408322011-12-21 17:39:39 +090061/**
62 * Platform Specific Structure for DRM based HDMI.
63 *
64 * @hdmi_dev: device point to specific hdmi driver.
65 * @mixer_dev: device point to specific mixer driver.
66 *
67 * this structure is used for common hdmi driver and each device object
68 * would be used to access specific device driver(hdmi or mixer driver)
69 */
70struct exynos_drm_common_hdmi_pd {
71 struct device *hdmi_dev;
72 struct device *mixer_dev;
73};
74
75/**
76 * Platform Specific Structure for DRM based HDMI core.
77 *
Joonyoung Shim3ecd70b2012-03-16 18:47:03 +090078 * @is_v13: set if hdmi version 13 is.
Joonyoung Shim7ecd34e2012-04-23 19:35:47 +090079 * @cfg_hpd: function pointer to configure hdmi hotplug detection pin
80 * @get_hpd: function pointer to get value of hdmi hotplug detection pin
Seung-Woo Kimd8408322011-12-21 17:39:39 +090081 */
82struct exynos_drm_hdmi_pdata {
Joonyoung Shim7ecd34e2012-04-23 19:35:47 +090083 bool is_v13;
84 void (*cfg_hpd)(bool external);
85 int (*get_hpd)(void);
Seung-Woo Kimd8408322011-12-21 17:39:39 +090086};
87
Eunchul Kim16102ed2012-12-14 17:58:55 +090088/**
89 * Platform Specific Structure for DRM based IPP.
90 *
91 * @inv_pclk: if set 1. invert pixel clock
92 * @inv_vsync: if set 1. invert vsync signal for wb
93 * @inv_href: if set 1. invert href signal
94 * @inv_hsync: if set 1. invert hsync signal for wb
95 */
96struct exynos_drm_ipp_pol {
97 unsigned int inv_pclk;
98 unsigned int inv_vsync;
99 unsigned int inv_href;
100 unsigned int inv_hsync;
101};
102
103/**
104 * Platform Specific Structure for DRM based FIMC.
105 *
106 * @pol: current hardware block polarity settings.
107 * @clk_rate: current hardware clock rate.
108 */
109struct exynos_drm_fimc_pdata {
110 struct exynos_drm_ipp_pol pol;
111 int clk_rate;
112};
113
Kamil Debski265da782012-02-15 10:23:33 +0900114#endif /* _EXYNOS_DRM_H_ */