blob: a01f197e6ac1560d1200b0f8d4e1b843b1891fd2 [file] [log] [blame]
Guennadi Liakhovetski9fd04fe2010-05-23 14:00:43 +00001/*
2 * Public SH-mobile MIPI DSI header
3 *
4 * Copyright (C) 2010 Guennadi Liakhovetski <g.liakhovetski@gmx.de>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 */
10#ifndef VIDEO_SH_MIPI_DSI_H
11#define VIDEO_SH_MIPI_DSI_H
12
13enum sh_mipi_dsi_data_fmt {
14 MIPI_RGB888,
15 MIPI_RGB565,
16 MIPI_RGB666_LP,
17 MIPI_RGB666,
18 MIPI_BGR888,
19 MIPI_BGR565,
20 MIPI_BGR666_LP,
21 MIPI_BGR666,
22 MIPI_YUYV,
23 MIPI_UYVY,
24 MIPI_YUV420_L,
25 MIPI_YUV420,
26};
27
Guennadi Liakhovetski38f3a872010-12-29 08:12:22 +000028#define SH_MIPI_DSI_HSABM (1 << 0)
Kuninori Morimoto32ba95c2011-11-08 20:34:01 -080029#define SH_MIPI_DSI_HBPBM (1 << 1)
Kuninori Morimotof7b0af62011-11-08 20:34:24 -080030#define SH_MIPI_DSI_HFPBM (1 << 2)
Kuninori Morimotod07a9d22011-11-08 20:34:33 -080031#define SH_MIPI_DSI_BL2E (1 << 3)
Kuninori Morimotof832906a2011-11-08 20:34:55 -080032#define SH_MIPI_DSI_VSEE (1 << 4)
33#define SH_MIPI_DSI_HSEE (1 << 5)
34#define SH_MIPI_DSI_HSAE (1 << 6)
35
Kuninori Morimotoa2e62972011-11-08 20:35:27 -080036#define SH_MIPI_DSI_HSbyteCLK (1 << 24)
37#define SH_MIPI_DSI_HS6divCLK (1 << 25)
38#define SH_MIPI_DSI_HS4divCLK (1 << 26)
39
Kuninori Morimotof832906a2011-11-08 20:34:55 -080040#define SH_MIPI_DSI_SYNC_PULSES_MODE (SH_MIPI_DSI_VSEE | \
41 SH_MIPI_DSI_HSEE | \
42 SH_MIPI_DSI_HSAE)
43#define SH_MIPI_DSI_SYNC_EVENTS_MODE (0)
44#define SH_MIPI_DSI_SYNC_BURST_MODE (SH_MIPI_DSI_BL2E)
Guennadi Liakhovetski38f3a872010-12-29 08:12:22 +000045
Guennadi Liakhovetski9fd04fe2010-05-23 14:00:43 +000046struct sh_mipi_dsi_info {
47 enum sh_mipi_dsi_data_fmt data_format;
Laurent Pinchart50b1a742012-08-14 12:17:55 +020048 int channel;
Kuninori Morimoto26c3d7a2011-11-08 20:34:43 -080049 int lane;
Guennadi Liakhovetski38f3a872010-12-29 08:12:22 +000050 unsigned long flags;
51 u32 clksrc;
Kuninori Morimoto8f9c60f2012-03-20 18:34:10 -070052 u32 phyctrl; /* for extra setting */
Guennadi Liakhovetski38f3a872010-12-29 08:12:22 +000053 unsigned int vsynw_offset;
Kuninori Morimoto5e474312011-11-08 20:35:14 -080054 int (*set_dot_clock)(struct platform_device *pdev,
55 void __iomem *base,
56 int enable);
Guennadi Liakhovetski9fd04fe2010-05-23 14:00:43 +000057};
58
59#endif