root/include/video/w100fb.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


   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 };

/* [<][>][^][v][top][bottom][index][help] */