xref: /kernel/linux/linux-5.10/include/video/w100fb.h (revision 8c2ecf20)
1/* SPDX-License-Identifier: GPL-2.0-only */
2/*
3 *  Support for the w100 frame buffer.
4 *
5 *  Copyright (c) 2004-2005 Richard Purdie
6 *  Copyright (c) 2005 Ian Molton
7 */
8
9#define W100_GPIO_PORT_A	0
10#define W100_GPIO_PORT_B	1
11
12#define CLK_SRC_XTAL  0
13#define CLK_SRC_PLL   1
14
15struct w100fb_par;
16
17unsigned long w100fb_gpio_read(int port);
18void w100fb_gpio_write(int port, unsigned long value);
19unsigned long w100fb_get_hsynclen(struct device *dev);
20
21/* LCD Specific Routines and Config */
22struct w100_tg_info {
23	void (*change)(struct w100fb_par*);
24	void (*suspend)(struct w100fb_par*);
25	void (*resume)(struct w100fb_par*);
26};
27
28/* General Platform Specific w100 Register Values */
29struct w100_gen_regs {
30	unsigned long lcd_format;
31	unsigned long lcdd_cntl1;
32	unsigned long lcdd_cntl2;
33	unsigned long genlcd_cntl1;
34	unsigned long genlcd_cntl2;
35	unsigned long genlcd_cntl3;
36};
37
38struct w100_gpio_regs {
39	unsigned long init_data1;
40	unsigned long init_data2;
41	unsigned long gpio_dir1;
42	unsigned long gpio_oe1;
43	unsigned long gpio_dir2;
44	unsigned long gpio_oe2;
45};
46
47/* Optional External Memory Configuration */
48struct w100_mem_info {
49	unsigned long ext_cntl;
50	unsigned long sdram_mode_reg;
51	unsigned long ext_timing_cntl;
52	unsigned long io_cntl;
53	unsigned int size;
54};
55
56struct w100_bm_mem_info {
57	unsigned long ext_mem_bw;
58	unsigned long offset;
59	unsigned long ext_timing_ctl;
60	unsigned long ext_cntl;
61	unsigned long mode_reg;
62	unsigned long io_cntl;
63	unsigned long config;
64};
65
66/* LCD Mode definition */
67struct w100_mode {
68	unsigned int xres;
69	unsigned int yres;
70	unsigned short left_margin;
71	unsigned short right_margin;
72	unsigned short upper_margin;
73	unsigned short lower_margin;
74	unsigned long crtc_ss;
75	unsigned long crtc_ls;
76	unsigned long crtc_gs;
77	unsigned long crtc_vpos_gs;
78	unsigned long crtc_rev;
79	unsigned long crtc_dclk;
80	unsigned long crtc_gclk;
81	unsigned long crtc_goe;
82	unsigned long crtc_ps1_active;
83	char pll_freq;
84	char fast_pll_freq;
85	int sysclk_src;
86	int sysclk_divider;
87	int pixclk_src;
88	int pixclk_divider;
89	int pixclk_divider_rotated;
90};
91
92struct w100_pll_info {
93	uint16_t freq;  /* desired Fout for PLL (Mhz) */
94	uint8_t M;      /* input divider */
95	uint8_t N_int;  /* VCO multiplier */
96	uint8_t N_fac;  /* VCO multiplier fractional part */
97	uint8_t tfgoal;
98	uint8_t lock_time;
99};
100
101/* Initial Video mode orientation flags */
102#define INIT_MODE_ROTATED  0x1
103#define INIT_MODE_FLIPPED  0x2
104
105/*
106 * This structure describes the machine which we are running on.
107 * It is set by machine specific code and used in the probe routine
108 * of drivers/video/w100fb.c
109 */
110struct w100fb_mach_info {
111	/* General Platform Specific Registers */
112	struct w100_gen_regs *regs;
113	/* Table of modes the LCD is capable of */
114	struct w100_mode *modelist;
115	unsigned int num_modes;
116	/* Hooks for any platform specific tg/lcd code (optional) */
117	struct w100_tg_info *tg;
118	/* External memory definition (if present) */
119	struct w100_mem_info *mem;
120	/* Additional External memory definition (if present) */
121	struct w100_bm_mem_info *bm_mem;
122	/* GPIO definitions (optional) */
123	struct w100_gpio_regs *gpio;
124	/* Initial Mode flags */
125	unsigned int init_mode;
126	/* Xtal Frequency */
127	unsigned int xtal_freq;
128	/* Enable Xtal input doubler (1 == enable) */
129	unsigned int xtal_dbl;
130};
131
132/* General frame buffer data structure */
133struct w100fb_par {
134	unsigned int chip_id;
135	unsigned int xres;
136	unsigned int yres;
137	unsigned int extmem_active;
138	unsigned int flip;
139	unsigned int blanked;
140	unsigned int fastpll_mode;
141	unsigned long hsync_len;
142	struct w100_mode *mode;
143	struct w100_pll_info *pll_table;
144	struct w100fb_mach_info *mach;
145	uint32_t *saved_intmem;
146	uint32_t *saved_extmem;
147};
148