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 15 struct w100fb_par; 16 17 unsigned long w100fb_gpio_read(int port); 18 void w100fb_gpio_write(int port, unsigned long value); 19 unsigned long w100fb_get_hsynclen(struct device *dev); 20 21 /* LCD Specific Routines and Config */ 22 struct 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 */ 29 struct 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 38 struct 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 */ 48 struct 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 56 struct 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 */ 67 struct 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 92 struct 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 */ 110 struct 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 */ 133 struct 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