151 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  Support for the w100 frame buffer.
 | |
|  *
 | |
|  *  Copyright (c) 2004-2005 Richard Purdie
 | |
|  *  Copyright (c) 2005 Ian Molton
 | |
|  *
 | |
|  *  This program is free software; you can redistribute it and/or modify
 | |
|  *  it under the terms of the GNU General Public License version 2 as
 | |
|  *  published by the Free Software Foundation.
 | |
|  */
 | |
| 
 | |
| #define W100_GPIO_PORT_A	0
 | |
| #define W100_GPIO_PORT_B	1
 | |
| 
 | |
| #define CLK_SRC_XTAL  0
 | |
| #define CLK_SRC_PLL   1
 | |
| 
 | |
| struct w100fb_par;
 | |
| 
 | |
| unsigned long w100fb_gpio_read(int port);
 | |
| void w100fb_gpio_write(int port, unsigned long value);
 | |
| unsigned long w100fb_get_hsynclen(struct device *dev);
 | |
| 
 | |
| /* LCD Specific Routines and Config */
 | |
| struct w100_tg_info {
 | |
| 	void (*change)(struct w100fb_par*);
 | |
| 	void (*suspend)(struct w100fb_par*);
 | |
| 	void (*resume)(struct w100fb_par*);
 | |
| };
 | |
| 
 | |
| /* General Platform Specific w100 Register Values */
 | |
| struct w100_gen_regs {
 | |
| 	unsigned long lcd_format;
 | |
| 	unsigned long lcdd_cntl1;
 | |
| 	unsigned long lcdd_cntl2;
 | |
| 	unsigned long genlcd_cntl1;
 | |
| 	unsigned long genlcd_cntl2;
 | |
| 	unsigned long genlcd_cntl3;
 | |
| };
 | |
| 
 | |
| struct w100_gpio_regs {
 | |
| 	unsigned long init_data1;
 | |
| 	unsigned long init_data2;
 | |
| 	unsigned long gpio_dir1;
 | |
| 	unsigned long gpio_oe1;
 | |
| 	unsigned long gpio_dir2;
 | |
| 	unsigned long gpio_oe2;
 | |
| };
 | |
| 
 | |
| /* Optional External Memory Configuration */
 | |
| struct w100_mem_info {
 | |
| 	unsigned long ext_cntl;
 | |
| 	unsigned long sdram_mode_reg;
 | |
| 	unsigned long ext_timing_cntl;
 | |
| 	unsigned long io_cntl;
 | |
| 	unsigned int size;
 | |
| };
 | |
| 
 | |
| struct w100_bm_mem_info {
 | |
| 	unsigned long ext_mem_bw;
 | |
| 	unsigned long offset;
 | |
| 	unsigned long ext_timing_ctl;
 | |
| 	unsigned long ext_cntl;
 | |
| 	unsigned long mode_reg;
 | |
| 	unsigned long io_cntl;
 | |
| 	unsigned long config;
 | |
| };
 | |
| 
 | |
| /* LCD Mode definition */
 | |
| struct w100_mode {
 | |
| 	unsigned int xres;
 | |
| 	unsigned int yres;
 | |
| 	unsigned short left_margin;
 | |
| 	unsigned short right_margin;
 | |
| 	unsigned short upper_margin;
 | |
| 	unsigned short lower_margin;
 | |
| 	unsigned long crtc_ss;
 | |
| 	unsigned long crtc_ls;
 | |
| 	unsigned long crtc_gs;
 | |
| 	unsigned long crtc_vpos_gs;
 | |
| 	unsigned long crtc_rev;
 | |
| 	unsigned long crtc_dclk;
 | |
| 	unsigned long crtc_gclk;
 | |
| 	unsigned long crtc_goe;
 | |
| 	unsigned long crtc_ps1_active;
 | |
| 	char pll_freq;
 | |
| 	char fast_pll_freq;
 | |
| 	int sysclk_src;
 | |
| 	int sysclk_divider;
 | |
| 	int pixclk_src;
 | |
| 	int pixclk_divider;
 | |
| 	int pixclk_divider_rotated;
 | |
| };
 | |
| 
 | |
| struct w100_pll_info {
 | |
| 	uint16_t freq;  /* desired Fout for PLL (Mhz) */
 | |
| 	uint8_t M;      /* input divider */
 | |
| 	uint8_t N_int;  /* VCO multiplier */
 | |
| 	uint8_t N_fac;  /* VCO multiplier fractional part */
 | |
| 	uint8_t tfgoal;
 | |
| 	uint8_t lock_time;
 | |
| };
 | |
| 
 | |
| /* Initial Video mode orientation flags */
 | |
| #define INIT_MODE_ROTATED  0x1
 | |
| #define INIT_MODE_FLIPPED  0x2
 | |
| 
 | |
| /*
 | |
|  * This structure describes the machine which we are running on.
 | |
|  * It is set by machine specific code and used in the probe routine
 | |
|  * of drivers/video/w100fb.c
 | |
|  */
 | |
| struct w100fb_mach_info {
 | |
| 	/* General Platform Specific Registers */
 | |
| 	struct w100_gen_regs *regs;
 | |
| 	/* Table of modes the LCD is capable of */
 | |
| 	struct w100_mode *modelist;
 | |
| 	unsigned int num_modes;
 | |
| 	/* Hooks for any platform specific tg/lcd code (optional) */
 | |
| 	struct w100_tg_info *tg;
 | |
| 	/* External memory definition (if present) */
 | |
| 	struct w100_mem_info *mem;
 | |
| 	/* Additional External memory definition (if present) */
 | |
| 	struct w100_bm_mem_info *bm_mem;
 | |
| 	/* GPIO definitions (optional) */
 | |
| 	struct w100_gpio_regs *gpio;
 | |
| 	/* Initial Mode flags */
 | |
| 	unsigned int init_mode;
 | |
| 	/* Xtal Frequency */
 | |
| 	unsigned int xtal_freq;
 | |
| 	/* Enable Xtal input doubler (1 == enable) */
 | |
| 	unsigned int xtal_dbl;
 | |
| };
 | |
| 
 | |
| /* General frame buffer data structure */
 | |
| struct w100fb_par {
 | |
| 	unsigned int chip_id;
 | |
| 	unsigned int xres;
 | |
| 	unsigned int yres;
 | |
| 	unsigned int extmem_active;
 | |
| 	unsigned int flip;
 | |
| 	unsigned int blanked;
 | |
| 	unsigned int fastpll_mode;
 | |
| 	unsigned long hsync_len;
 | |
| 	struct w100_mode *mode;
 | |
| 	struct w100_pll_info *pll_table;
 | |
| 	struct w100fb_mach_info *mach;
 | |
| 	uint32_t *saved_intmem;
 | |
| 	uint32_t *saved_extmem;
 | |
| };
 | 
