blob: a614654d8598e0ad4418cc9a57f50cbe2dce0d2f [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * Support for the w100 frame buffer.
4 *
Richard Purdieaac51f02005-09-06 15:19:03 -07005 * Copyright (c) 2004-2005 Richard Purdie
6 * Copyright (c) 2005 Ian Molton
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 */
8
Richard Purdieaac51f02005-09-06 15:19:03 -07009#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);
Richard Purdie513b6e12005-09-13 01:25:33 -070019unsigned long w100fb_get_hsynclen(struct device *dev);
Richard Purdieaac51f02005-09-06 15:19:03 -070020
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
Linus Torvalds1da177e2005-04-16 15:20:36 -0700105/*
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 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110struct w100fb_mach_info {
Richard Purdieaac51f02005-09-06 15:19:03 -0700111 /* 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;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700147};