d14b272bc6
Add the ability to have pxafb use only certain fixed video modes (selected on a per platform basis). This is useful on production hardware such as the Zaurus cxx00 models where the valid modes are known in advance and any other modes could result in hardware damage. Following this, add support for the cxx00 QVGA mode. Mode information is passed to the lcd_power call to allowing the panel drivers to configure the display hardware accordingly (corgi_lcd already contains the functionality for the cxx00 panel). This mirrors the setup already used by w100fb. Signed-off-by: Richard Purdie <rpurdie@rpsys.net> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
80 lines
2.2 KiB
C
80 lines
2.2 KiB
C
/*
|
|
* linux/include/asm-arm/arch-pxa/pxafb.h
|
|
*
|
|
* Support for the xscale frame buffer.
|
|
*
|
|
* Author: Jean-Frederic Clere
|
|
* Created: Sep 22, 2003
|
|
* Copyright: jfclere@sinix.net
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#include <linux/fb.h>
|
|
|
|
/*
|
|
* This structure describes the machine which we are running on.
|
|
* It is set in linux/arch/arm/mach-pxa/machine_name.c and used in the probe routine
|
|
* of linux/drivers/video/pxafb.c
|
|
*/
|
|
struct pxafb_mode_info {
|
|
u_long pixclock;
|
|
|
|
u_short xres;
|
|
u_short yres;
|
|
|
|
u_char bpp;
|
|
u_char hsync_len;
|
|
u_char left_margin;
|
|
u_char right_margin;
|
|
|
|
u_char vsync_len;
|
|
u_char upper_margin;
|
|
u_char lower_margin;
|
|
u_char sync;
|
|
|
|
u_int cmap_greyscale:1,
|
|
unused:31;
|
|
};
|
|
|
|
struct pxafb_mach_info {
|
|
struct pxafb_mode_info *modes;
|
|
unsigned int num_modes;
|
|
|
|
u_int fixed_modes:1,
|
|
cmap_inverse:1,
|
|
cmap_static:1,
|
|
unused:29;
|
|
|
|
/* The following should be defined in LCCR0
|
|
* LCCR0_Act or LCCR0_Pas Active or Passive
|
|
* LCCR0_Sngl or LCCR0_Dual Single/Dual panel
|
|
* LCCR0_Mono or LCCR0_Color Mono/Color
|
|
* LCCR0_4PixMono or LCCR0_8PixMono (in mono single mode)
|
|
* LCCR0_DMADel(Tcpu) (optional) DMA request delay
|
|
*
|
|
* The following should not be defined in LCCR0:
|
|
* LCCR0_OUM, LCCR0_BM, LCCR0_QDM, LCCR0_DIS, LCCR0_EFM
|
|
* LCCR0_IUM, LCCR0_SFM, LCCR0_LDM, LCCR0_ENB
|
|
*/
|
|
u_int lccr0;
|
|
/* The following should be defined in LCCR3
|
|
* LCCR3_OutEnH or LCCR3_OutEnL Output enable polarity
|
|
* LCCR3_PixRsEdg or LCCR3_PixFlEdg Pixel clock edge type
|
|
* LCCR3_Acb(X) AB Bias pin frequency
|
|
* LCCR3_DPC (optional) Double Pixel Clock mode (untested)
|
|
*
|
|
* The following should not be defined in LCCR3
|
|
* LCCR3_HSP, LCCR3_VSP, LCCR0_Pcd(x), LCCR3_Bpp
|
|
*/
|
|
u_int lccr3;
|
|
|
|
void (*pxafb_backlight_power)(int);
|
|
void (*pxafb_lcd_power)(int, struct fb_var_screeninfo *);
|
|
|
|
};
|
|
void set_pxa_fb_info(struct pxafb_mach_info *hard_pxa_fb_info);
|
|
void set_pxa_fb_parent(struct device *parent_dev);
|
|
unsigned long pxafb_get_hsync_time(struct device *dev);
|