blob: 08f8e5c406f4129535a63e94cc4769f3b4d00c7d [file] [log] [blame]
Stefan Boschb7719a72020-07-10 19:07:34 +02001/* SPDX-License-Identifier: GPL-2.0+
2 *
3 * Copyright (C) 2016 Nexell Co., Ltd.
4 *
5 * Author: junghyun, kim <jhkim@nexell.co.kr>
6 */
7
8#ifndef _S5PXX18_SOC_LVDS_H_
9#define _S5PXX18_SOC_LVDS_H_
10
11/*
12 * refter to s5pxx18_soc_disptop.h
13 *
14 * #define NUMBER_OF_LVDS_MODULE 1
15 * #define PHY_BASEADDR_LVDS_MODULE 0xC010A000
16 */
17#define PHY_BASEADDR_LVDS_LIST \
18 { PHY_BASEADDR_LVDS_MODULE }
19
20struct nx_lvds_register_set {
21 u32 lvdsctrl0;
22 u32 lvdsctrl1;
23 u32 lvdsctrl2;
24 u32 lvdsctrl3;
25 u32 lvdsctrl4;
26 u32 _reserved0[3];
27 u32 lvdsloc0;
28 u32 lvdsloc1;
29 u32 lvdsloc2;
30 u32 lvdsloc3;
31 u32 lvdsloc4;
32 u32 lvdsloc5;
33 u32 lvdsloc6;
34 u32 _reserved1;
35 u32 lvdslocmask0;
36 u32 lvdslocmask1;
37 u32 lvdslocpol0;
38 u32 lvdslocpol1;
39 u32 lvdstmode0;
40 u32 lvdstmode1;
41 u32 _reserved2[2];
42};
43
44int nx_lvds_initialize(void);
45u32 nx_lvds_get_number_of_module(void);
46u32 nx_lvds_get_size_of_register_set(void);
47void nx_lvds_set_base_address(u32 module_index, void *base_address);
48void *nx_lvds_get_base_address(u32 module_index);
49u32 nx_lvds_get_physical_address(u32 module_index);
50int nx_lvds_open_module(u32 module_index);
51int nx_lvds_close_module(u32 module_index);
52int nx_lvds_check_busy(u32 module_index);
53
54void nx_lvds_set_lvdsctrl0(u32 module_index, u32 regvalue);
55void nx_lvds_set_lvdsctrl1(u32 module_index, u32 regvalue);
56void nx_lvds_set_lvdsctrl2(u32 module_index, u32 regvalue);
57void nx_lvds_set_lvdsctrl3(u32 module_index, u32 regvalue);
58void nx_lvds_set_lvdsctrl4(u32 module_index, u32 regvalue);
59u32 nx_lvds_get_lvdsctrl0(u32 module_index);
60u32 nx_lvds_get_lvdsctrl1(u32 module_index);
61u32 nx_lvds_get_lvdsctrl2(u32 module_index);
62u32 nx_lvds_get_lvdsctrl3(u32 module_index);
63u32 nx_lvds_get_lvdsctrl4(u32 module_index);
64
65void nx_lvds_set_lvdstmode0(u32 module_index, u32 regvalue);
66void nx_lvds_set_lvdsloc0(u32 module_index, u32 regvalue);
67void nx_lvds_set_lvdsloc1(u32 module_index, u32 regvalue);
68void nx_lvds_set_lvdsloc2(u32 module_index, u32 regvalue);
69void nx_lvds_set_lvdsloc3(u32 module_index, u32 regvalue);
70void nx_lvds_set_lvdsloc4(u32 module_index, u32 regvalue);
71void nx_lvds_set_lvdsloc5(u32 module_index, u32 regvalue);
72void nx_lvds_set_lvdsloc6(u32 module_index, u32 regvalue);
73void nx_lvds_set_lvdslocmask0(u32 module_index, u32 regvalue);
74void nx_lvds_set_lvdslocmask1(u32 module_index, u32 regvalue);
75void nx_lvds_set_lvdslocpol0(u32 module_index, u32 regvalue);
76void nx_lvds_set_lvdslocpol1(u32 module_index, u32 regvalue);
77
78void nx_lvds_set_lvdslocpol1(u32 module_index, u32 regvalue);
79
80void nx_lvds_set_lvdsdummy(u32 module_index, u32 regvalue);
81u32 nx_lvds_get_lvdsdummy(u32 module_index);
82
83#endif