blob: cb65fa14acfcd28eeff9587e4a88c822e898d733 [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 *
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 */
Inki Dae1c248b72011-10-04 19:19:01 +090014#ifndef _EXYNOS_DRM_H_
15#define _EXYNOS_DRM_H_
16
David Howells718dced2012-10-04 18:21:50 +010017#include <uapi/drm/exynos_drm.h>
Andrzej Hajda111e6052013-08-21 16:22:01 +020018#include <video/videomode.h>
Joonyoung Shimd7f16422012-05-17 20:06:32 +090019
Inki Dae1c248b72011-10-04 19:19:01 +090020/**
Eun-Chul Kim607c50d2012-02-14 15:59:46 +090021 * A structure for lcd panel information.
Inki Dae1c248b72011-10-04 19:19:01 +090022 *
23 * @timing: default video mode for initializing
Eun-Chul Kim607c50d2012-02-14 15:59:46 +090024 * @width_mm: physical size of lcd width.
25 * @height_mm: physical size of lcd height.
26 */
27struct exynos_drm_panel_info {
Andrzej Hajda111e6052013-08-21 16:22:01 +020028 struct videomode vm;
Eun-Chul Kim607c50d2012-02-14 15:59:46 +090029 u32 width_mm;
30 u32 height_mm;
31};
32
33/**
34 * Platform Specific Structure for DRM based FIMD.
35 *
36 * @panel: default panel info for initializing
Inki Dae1c248b72011-10-04 19:19:01 +090037 * @default_win: default window layer number to be used for UI.
38 * @bpp: default bit per pixel.
39 */
40struct exynos_drm_fimd_pdata {
Eun-Chul Kim607c50d2012-02-14 15:59:46 +090041 struct exynos_drm_panel_info panel;
Inki Dae1c248b72011-10-04 19:19:01 +090042 u32 vidcon0;
43 u32 vidcon1;
44 unsigned int default_win;
45 unsigned int bpp;
46};
47
Seung-Woo Kimd8408322011-12-21 17:39:39 +090048/**
49 * Platform Specific Structure for DRM based HDMI.
50 *
51 * @hdmi_dev: device point to specific hdmi driver.
52 * @mixer_dev: device point to specific mixer driver.
53 *
54 * this structure is used for common hdmi driver and each device object
55 * would be used to access specific device driver(hdmi or mixer driver)
56 */
57struct exynos_drm_common_hdmi_pd {
58 struct device *hdmi_dev;
59 struct device *mixer_dev;
60};
61
62/**
63 * Platform Specific Structure for DRM based HDMI core.
64 *
Joonyoung Shim3ecd70b2012-03-16 18:47:03 +090065 * @is_v13: set if hdmi version 13 is.
Joonyoung Shim7ecd34e2012-04-23 19:35:47 +090066 * @cfg_hpd: function pointer to configure hdmi hotplug detection pin
67 * @get_hpd: function pointer to get value of hdmi hotplug detection pin
Seung-Woo Kimd8408322011-12-21 17:39:39 +090068 */
69struct exynos_drm_hdmi_pdata {
Joonyoung Shim7ecd34e2012-04-23 19:35:47 +090070 bool is_v13;
71 void (*cfg_hpd)(bool external);
72 int (*get_hpd)(void);
Seung-Woo Kimd8408322011-12-21 17:39:39 +090073};
74
Eunchul Kim16102ed2012-12-14 17:58:55 +090075/**
76 * Platform Specific Structure for DRM based IPP.
77 *
78 * @inv_pclk: if set 1. invert pixel clock
79 * @inv_vsync: if set 1. invert vsync signal for wb
80 * @inv_href: if set 1. invert href signal
81 * @inv_hsync: if set 1. invert hsync signal for wb
82 */
83struct exynos_drm_ipp_pol {
84 unsigned int inv_pclk;
85 unsigned int inv_vsync;
86 unsigned int inv_href;
87 unsigned int inv_hsync;
88};
89
90/**
91 * Platform Specific Structure for DRM based FIMC.
92 *
93 * @pol: current hardware block polarity settings.
94 * @clk_rate: current hardware clock rate.
95 */
96struct exynos_drm_fimc_pdata {
97 struct exynos_drm_ipp_pol pol;
98 int clk_rate;
99};
100
Kamil Debski265da782012-02-15 10:23:33 +0900101#endif /* _EXYNOS_DRM_H_ */