xref: /rk3399_rockchip-uboot/include/lcd.h (revision 904672ee489280cf26793e0a590505a2659dae09)
1fe8c2806Swdenk /*
28655b6f8Swdenk  * MPC823 and PXA LCD Controller
3fe8c2806Swdenk  *
4fe8c2806Swdenk  * Modeled after video interface by Paolo Scaffardi
5fe8c2806Swdenk  *
6fe8c2806Swdenk  *
7fe8c2806Swdenk  * (C) Copyright 2001
8fe8c2806Swdenk  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
9fe8c2806Swdenk  *
101a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
11fe8c2806Swdenk  */
12fe8c2806Swdenk 
13fe8c2806Swdenk #ifndef _LCD_H_
14fe8c2806Swdenk #define _LCD_H_
15*904672eeSNikita Kiryanov #include <lcd_console.h>
16fe8c2806Swdenk 
178655b6f8Swdenk extern char lcd_is_enabled;
188655b6f8Swdenk 
198655b6f8Swdenk extern int lcd_line_length;
208655b6f8Swdenk 
216111722aSAlessandro Rubini extern struct vidinfo panel_info;
226111722aSAlessandro Rubini 
236b035141SJeroen Hofstee void lcd_ctrl_init(void *lcdbase);
246b035141SJeroen Hofstee void lcd_enable(void);
256111722aSAlessandro Rubini 
266111722aSAlessandro Rubini /* setcolreg used in 8bpp/16bpp; initcolregs used in monochrome */
276b035141SJeroen Hofstee void lcd_setcolreg(ushort regno, ushort red, ushort green, ushort blue);
286b035141SJeroen Hofstee void lcd_initcolregs(void);
296111722aSAlessandro Rubini 
306111722aSAlessandro Rubini /* gunzip_bmp used if CONFIG_VIDEO_BMP_GZIP */
31f7ef9d61SPiotr Wilczek struct bmp_image *gunzip_bmp(unsigned long addr, unsigned long *lenp,
32f7ef9d61SPiotr Wilczek 			     void **alloc_addr);
336b035141SJeroen Hofstee int bmp_display(ulong addr, int x, int y);
348655b6f8Swdenk 
359a8efc46SSimon Glass /**
369a8efc46SSimon Glass  * Set whether we need to flush the dcache when changing the LCD image. This
379a8efc46SSimon Glass  * defaults to off.
389a8efc46SSimon Glass  *
399a8efc46SSimon Glass  * @param flush		non-zero to flush cache after update, 0 to skip
409a8efc46SSimon Glass  */
419a8efc46SSimon Glass void lcd_set_flush_dcache(int flush);
429a8efc46SSimon Glass 
438655b6f8Swdenk #if defined CONFIG_MPC823
448655b6f8Swdenk /*
458655b6f8Swdenk  * LCD controller stucture for MPC823 CPU
468655b6f8Swdenk  */
478655b6f8Swdenk typedef struct vidinfo {
488655b6f8Swdenk 	ushort	vl_col;		/* Number of columns (i.e. 640) */
498655b6f8Swdenk 	ushort	vl_row;		/* Number of rows (i.e. 480) */
508655b6f8Swdenk 	ushort	vl_width;	/* Width of display area in millimeters */
518655b6f8Swdenk 	ushort	vl_height;	/* Height of display area in millimeters */
528655b6f8Swdenk 
538655b6f8Swdenk 	/* LCD configuration register */
548655b6f8Swdenk 	u_char	vl_clkp;	/* Clock polarity */
558655b6f8Swdenk 	u_char	vl_oep;		/* Output Enable polarity */
568655b6f8Swdenk 	u_char	vl_hsp;		/* Horizontal Sync polarity */
578655b6f8Swdenk 	u_char	vl_vsp;		/* Vertical Sync polarity */
588655b6f8Swdenk 	u_char	vl_dp;		/* Data polarity */
598655b6f8Swdenk 	u_char	vl_bpix;	/* Bits per pixel, 0 = 1, 1 = 2, 2 = 4, 3 = 8 */
608655b6f8Swdenk 	u_char	vl_lbw;		/* LCD Bus width, 0 = 4, 1 = 8 */
618655b6f8Swdenk 	u_char	vl_splt;	/* Split display, 0 = single-scan, 1 = dual-scan */
628655b6f8Swdenk 	u_char	vl_clor;	/* Color, 0 = mono, 1 = color */
638655b6f8Swdenk 	u_char	vl_tft;		/* 0 = passive, 1 = TFT */
648655b6f8Swdenk 
658655b6f8Swdenk 	/* Horizontal control register. Timing from data sheet */
668655b6f8Swdenk 	ushort	vl_wbl;		/* Wait between lines */
678655b6f8Swdenk 
688655b6f8Swdenk 	/* Vertical control register */
698655b6f8Swdenk 	u_char	vl_vpw;		/* Vertical sync pulse width */
708655b6f8Swdenk 	u_char	vl_lcdac;	/* LCD AC timing */
718655b6f8Swdenk 	u_char	vl_wbf;		/* Wait between frames */
728655b6f8Swdenk } vidinfo_t;
738655b6f8Swdenk 
74abc20abaSMarek Vasut #elif defined(CONFIG_CPU_PXA25X) || defined(CONFIG_CPU_PXA27X) || \
75abc20abaSMarek Vasut 	defined CONFIG_CPU_MONAHANS
768655b6f8Swdenk /*
778655b6f8Swdenk  * PXA LCD DMA descriptor
788655b6f8Swdenk  */
798655b6f8Swdenk struct pxafb_dma_descriptor {
808655b6f8Swdenk 	u_long	fdadr;		/* Frame descriptor address register */
818655b6f8Swdenk 	u_long	fsadr;		/* Frame source address register */
828655b6f8Swdenk 	u_long	fidr;		/* Frame ID register */
838655b6f8Swdenk 	u_long	ldcmd;		/* Command register */
848655b6f8Swdenk };
858655b6f8Swdenk 
868655b6f8Swdenk /*
878655b6f8Swdenk  * PXA LCD info
888655b6f8Swdenk  */
898655b6f8Swdenk struct pxafb_info {
908655b6f8Swdenk 
918655b6f8Swdenk 	/* Misc registers */
928655b6f8Swdenk 	u_long	reg_lccr3;
938655b6f8Swdenk 	u_long	reg_lccr2;
948655b6f8Swdenk 	u_long	reg_lccr1;
958655b6f8Swdenk 	u_long	reg_lccr0;
968655b6f8Swdenk 	u_long	fdadr0;
978655b6f8Swdenk 	u_long	fdadr1;
988655b6f8Swdenk 
998655b6f8Swdenk 	/* DMA descriptors */
1008655b6f8Swdenk 	struct	pxafb_dma_descriptor *	dmadesc_fblow;
1018655b6f8Swdenk 	struct	pxafb_dma_descriptor *	dmadesc_fbhigh;
1028655b6f8Swdenk 	struct	pxafb_dma_descriptor *	dmadesc_palette;
1038655b6f8Swdenk 
1048655b6f8Swdenk 	u_long	screen;		/* physical address of frame buffer */
1058655b6f8Swdenk 	u_long	palette;	/* physical address of palette memory */
1068655b6f8Swdenk 	u_int	palette_size;
1078655b6f8Swdenk };
1088655b6f8Swdenk 
1098655b6f8Swdenk /*
1108655b6f8Swdenk  * LCD controller stucture for PXA CPU
1118655b6f8Swdenk  */
1128655b6f8Swdenk typedef struct vidinfo {
1138655b6f8Swdenk 	ushort	vl_col;		/* Number of columns (i.e. 640) */
1148655b6f8Swdenk 	ushort	vl_row;		/* Number of rows (i.e. 480) */
1158655b6f8Swdenk 	ushort	vl_width;	/* Width of display area in millimeters */
1168655b6f8Swdenk 	ushort	vl_height;	/* Height of display area in millimeters */
1178655b6f8Swdenk 
1188655b6f8Swdenk 	/* LCD configuration register */
1198655b6f8Swdenk 	u_char	vl_clkp;	/* Clock polarity */
1208655b6f8Swdenk 	u_char	vl_oep;		/* Output Enable polarity */
1218655b6f8Swdenk 	u_char	vl_hsp;		/* Horizontal Sync polarity */
1228655b6f8Swdenk 	u_char	vl_vsp;		/* Vertical Sync polarity */
1238655b6f8Swdenk 	u_char	vl_dp;		/* Data polarity */
1248655b6f8Swdenk 	u_char	vl_bpix;	/* Bits per pixel, 0 = 1, 1 = 2, 2 = 4, 3 = 8, 4 = 16 */
1258655b6f8Swdenk 	u_char	vl_lbw;		/* LCD Bus width, 0 = 4, 1 = 8 */
1268655b6f8Swdenk 	u_char	vl_splt;	/* Split display, 0 = single-scan, 1 = dual-scan */
1278655b6f8Swdenk 	u_char	vl_clor;	/* Color, 0 = mono, 1 = color */
1288655b6f8Swdenk 	u_char	vl_tft;		/* 0 = passive, 1 = TFT */
1298655b6f8Swdenk 
1308655b6f8Swdenk 	/* Horizontal control register. Timing from data sheet */
1318655b6f8Swdenk 	ushort	vl_hpw;		/* Horz sync pulse width */
1328655b6f8Swdenk 	u_char	vl_blw;		/* Wait before of line */
1338655b6f8Swdenk 	u_char	vl_elw;		/* Wait end of line */
1348655b6f8Swdenk 
1358655b6f8Swdenk 	/* Vertical control register. */
1368655b6f8Swdenk 	u_char	vl_vpw;		/* Vertical sync pulse width */
1378655b6f8Swdenk 	u_char	vl_bfw;		/* Wait before of frame */
1388655b6f8Swdenk 	u_char	vl_efw;		/* Wait end of frame */
1398655b6f8Swdenk 
1408655b6f8Swdenk 	/* PXA LCD controller params */
1418655b6f8Swdenk 	struct	pxafb_info pxa;
1428655b6f8Swdenk } vidinfo_t;
1438655b6f8Swdenk 
144f6b690e6SBo Shen #elif defined(CONFIG_ATMEL_LCD) || defined(CONFIG_ATMEL_HLCD)
14539cf4804SStelian Pop 
14639cf4804SStelian Pop typedef struct vidinfo {
14778459123SMarek Vasut 	ushort vl_col;		/* Number of columns (i.e. 640) */
14878459123SMarek Vasut 	ushort vl_row;		/* Number of rows (i.e. 480) */
14939cf4804SStelian Pop 	u_long vl_clk;	/* pixel clock in ps    */
15039cf4804SStelian Pop 
15139cf4804SStelian Pop 	/* LCD configuration register */
15239cf4804SStelian Pop 	u_long vl_sync;		/* Horizontal / vertical sync */
15339cf4804SStelian Pop 	u_long vl_bpix;		/* Bits per pixel, 0 = 1, 1 = 2, 2 = 4, 3 = 8, 4 = 16 */
15439cf4804SStelian Pop 	u_long vl_tft;		/* 0 = passive, 1 = TFT */
155cdfcedbfSAlexander Stein 	u_long vl_cont_pol_low;	/* contrast polarity is low */
156f6b690e6SBo Shen 	u_long vl_clk_pol;	/* clock polarity */
15739cf4804SStelian Pop 
15839cf4804SStelian Pop 	/* Horizontal control register. */
15939cf4804SStelian Pop 	u_long vl_hsync_len;	/* Length of horizontal sync */
16039cf4804SStelian Pop 	u_long vl_left_margin;	/* Time from sync to picture */
16139cf4804SStelian Pop 	u_long vl_right_margin;	/* Time from picture to sync */
16239cf4804SStelian Pop 
16339cf4804SStelian Pop 	/* Vertical control register. */
16439cf4804SStelian Pop 	u_long vl_vsync_len;	/* Length of vertical sync */
16539cf4804SStelian Pop 	u_long vl_upper_margin;	/* Time from sync to picture */
16639cf4804SStelian Pop 	u_long vl_lower_margin;	/* Time from picture to sync */
16739cf4804SStelian Pop 
16839cf4804SStelian Pop 	u_long	mmio;		/* Memory mapped registers */
16939cf4804SStelian Pop } vidinfo_t;
17039cf4804SStelian Pop 
171559a05ccSDonghwa Lee #elif defined(CONFIG_EXYNOS_FB)
172559a05ccSDonghwa Lee 
173559a05ccSDonghwa Lee enum {
174559a05ccSDonghwa Lee 	FIMD_RGB_INTERFACE = 1,
175559a05ccSDonghwa Lee 	FIMD_CPU_INTERFACE = 2,
176559a05ccSDonghwa Lee };
177559a05ccSDonghwa Lee 
17890464971SDonghwa Lee enum exynos_fb_rgb_mode_t {
17990464971SDonghwa Lee 	MODE_RGB_P = 0,
18090464971SDonghwa Lee 	MODE_BGR_P = 1,
18190464971SDonghwa Lee 	MODE_RGB_S = 2,
18290464971SDonghwa Lee 	MODE_BGR_S = 3,
18390464971SDonghwa Lee };
18490464971SDonghwa Lee 
185559a05ccSDonghwa Lee typedef struct vidinfo {
186559a05ccSDonghwa Lee 	ushort vl_col;		/* Number of columns (i.e. 640) */
187559a05ccSDonghwa Lee 	ushort vl_row;		/* Number of rows (i.e. 480) */
188559a05ccSDonghwa Lee 	ushort vl_width;	/* Width of display area in millimeters */
189559a05ccSDonghwa Lee 	ushort vl_height;	/* Height of display area in millimeters */
190559a05ccSDonghwa Lee 
191559a05ccSDonghwa Lee 	/* LCD configuration register */
192559a05ccSDonghwa Lee 	u_char vl_freq;		/* Frequency */
193559a05ccSDonghwa Lee 	u_char vl_clkp;		/* Clock polarity */
194559a05ccSDonghwa Lee 	u_char vl_oep;		/* Output Enable polarity */
195559a05ccSDonghwa Lee 	u_char vl_hsp;		/* Horizontal Sync polarity */
196559a05ccSDonghwa Lee 	u_char vl_vsp;		/* Vertical Sync polarity */
197559a05ccSDonghwa Lee 	u_char vl_dp;		/* Data polarity */
198559a05ccSDonghwa Lee 	u_char vl_bpix;		/* Bits per pixel */
199559a05ccSDonghwa Lee 
200559a05ccSDonghwa Lee 	/* Horizontal control register. Timing from data sheet */
201559a05ccSDonghwa Lee 	u_char vl_hspw;		/* Horz sync pulse width */
202559a05ccSDonghwa Lee 	u_char vl_hfpd;		/* Wait before of line */
203559a05ccSDonghwa Lee 	u_char vl_hbpd;		/* Wait end of line */
204559a05ccSDonghwa Lee 
205559a05ccSDonghwa Lee 	/* Vertical control register. */
206559a05ccSDonghwa Lee 	u_char	vl_vspw;	/* Vertical sync pulse width */
207559a05ccSDonghwa Lee 	u_char	vl_vfpd;	/* Wait before of frame */
208559a05ccSDonghwa Lee 	u_char	vl_vbpd;	/* Wait end of frame */
209559a05ccSDonghwa Lee 	u_char  vl_cmd_allow_len; /* Wait end of frame */
210559a05ccSDonghwa Lee 
211559a05ccSDonghwa Lee 	unsigned int win_id;
212559a05ccSDonghwa Lee 	unsigned int init_delay;
213559a05ccSDonghwa Lee 	unsigned int power_on_delay;
214559a05ccSDonghwa Lee 	unsigned int reset_delay;
215559a05ccSDonghwa Lee 	unsigned int interface_mode;
216559a05ccSDonghwa Lee 	unsigned int mipi_enabled;
2175addfcfcSDonghwa Lee 	unsigned int dp_enabled;
218559a05ccSDonghwa Lee 	unsigned int cs_setup;
219559a05ccSDonghwa Lee 	unsigned int wr_setup;
220559a05ccSDonghwa Lee 	unsigned int wr_act;
221559a05ccSDonghwa Lee 	unsigned int wr_hold;
22290464971SDonghwa Lee 	unsigned int logo_on;
22390464971SDonghwa Lee 	unsigned int logo_width;
22490464971SDonghwa Lee 	unsigned int logo_height;
225903afe18SPrzemyslaw Marczak 	int logo_x_offset;
226903afe18SPrzemyslaw Marczak 	int logo_y_offset;
22790464971SDonghwa Lee 	unsigned long logo_addr;
22890464971SDonghwa Lee 	unsigned int rgb_mode;
22990464971SDonghwa Lee 	unsigned int resolution;
230559a05ccSDonghwa Lee 
231559a05ccSDonghwa Lee 	/* parent clock name(MPLL, EPLL or VPLL) */
232559a05ccSDonghwa Lee 	unsigned int pclk_name;
233559a05ccSDonghwa Lee 	/* ratio value for source clock from parent clock. */
234559a05ccSDonghwa Lee 	unsigned int sclk_div;
235559a05ccSDonghwa Lee 
236559a05ccSDonghwa Lee 	unsigned int dual_lcd_enabled;
237559a05ccSDonghwa Lee } vidinfo_t;
238559a05ccSDonghwa Lee 
239559a05ccSDonghwa Lee void init_panel_info(vidinfo_t *vid);
240559a05ccSDonghwa Lee 
241b245e65eSGuennadi Liakhovetski #else
242b245e65eSGuennadi Liakhovetski 
243b245e65eSGuennadi Liakhovetski typedef struct vidinfo {
244b245e65eSGuennadi Liakhovetski 	ushort	vl_col;		/* Number of columns (i.e. 160) */
245b245e65eSGuennadi Liakhovetski 	ushort	vl_row;		/* Number of rows (i.e. 100) */
246b245e65eSGuennadi Liakhovetski 
247b245e65eSGuennadi Liakhovetski 	u_char	vl_bpix;	/* Bits per pixel, 0 = 1 */
248b245e65eSGuennadi Liakhovetski 
249b245e65eSGuennadi Liakhovetski 	ushort	*cmap;		/* Pointer to the colormap */
250b245e65eSGuennadi Liakhovetski 
251b245e65eSGuennadi Liakhovetski 	void	*priv;		/* Pointer to driver-specific data */
252b245e65eSGuennadi Liakhovetski } vidinfo_t;
253b245e65eSGuennadi Liakhovetski 
254ecfdcee5SNikita Kiryanov #endif /* CONFIG_MPC823, CONFIG_CPU_PXA25X, CONFIG_ATMEL_LCD */
2558655b6f8Swdenk 
25660e97419SAlessandro Rubini extern vidinfo_t panel_info;
25760e97419SAlessandro Rubini 
2588655b6f8Swdenk /* Video functions */
2598655b6f8Swdenk 
260fe8c2806Swdenk void	lcd_putc(const char c);
261fe8c2806Swdenk void	lcd_puts(const char *s);
262fe8c2806Swdenk void	lcd_printf(const char *fmt, ...);
26302110903SChe-Liang Chiou void	lcd_clear(void);
26402110903SChe-Liang Chiou int	lcd_display_bitmap(ulong bmp_image, int x, int y);
265fe8c2806Swdenk 
266395166cfSVadim Bendebury /**
267395166cfSVadim Bendebury  * Get the width of the LCD in pixels
268395166cfSVadim Bendebury  *
269395166cfSVadim Bendebury  * @return width of LCD in pixels
270395166cfSVadim Bendebury  */
271395166cfSVadim Bendebury int lcd_get_pixel_width(void);
272395166cfSVadim Bendebury 
273395166cfSVadim Bendebury /**
274395166cfSVadim Bendebury  * Get the height of the LCD in pixels
275395166cfSVadim Bendebury  *
276395166cfSVadim Bendebury  * @return height of LCD in pixels
277395166cfSVadim Bendebury  */
278395166cfSVadim Bendebury int lcd_get_pixel_height(void);
279395166cfSVadim Bendebury 
280395166cfSVadim Bendebury /**
281395166cfSVadim Bendebury  * Get the number of text lines/rows on the LCD
282395166cfSVadim Bendebury  *
283395166cfSVadim Bendebury  * @return number of rows
284395166cfSVadim Bendebury  */
285395166cfSVadim Bendebury int lcd_get_screen_rows(void);
286395166cfSVadim Bendebury 
287395166cfSVadim Bendebury /**
288395166cfSVadim Bendebury  * Get the number of text columns on the LCD
289395166cfSVadim Bendebury  *
290395166cfSVadim Bendebury  * @return number of columns
291395166cfSVadim Bendebury  */
292395166cfSVadim Bendebury int lcd_get_screen_columns(void);
293395166cfSVadim Bendebury 
294395166cfSVadim Bendebury /**
2954d03634eSNikita Kiryanov  * Get the background color of the LCD
2964d03634eSNikita Kiryanov  *
2974d03634eSNikita Kiryanov  * @return background color value
2984d03634eSNikita Kiryanov  */
2994d03634eSNikita Kiryanov int lcd_getbgcolor(void);
3004d03634eSNikita Kiryanov 
3014d03634eSNikita Kiryanov /**
3024d03634eSNikita Kiryanov  * Get the foreground color of the LCD
3034d03634eSNikita Kiryanov  *
3044d03634eSNikita Kiryanov  * @return foreground color value
3054d03634eSNikita Kiryanov  */
3064d03634eSNikita Kiryanov int lcd_getfgcolor(void);
3074d03634eSNikita Kiryanov 
3084d03634eSNikita Kiryanov /**
309395166cfSVadim Bendebury  * Set the position of the text cursor
310395166cfSVadim Bendebury  *
311395166cfSVadim Bendebury  * @param col	Column to place cursor (0 = left side)
312395166cfSVadim Bendebury  * @param row	Row to place cursor (0 = top line)
313395166cfSVadim Bendebury  */
314395166cfSVadim Bendebury void lcd_position_cursor(unsigned col, unsigned row);
315395166cfSVadim Bendebury 
3166b59e03eSHaavard Skinnemoen /* Allow boards to customize the information displayed */
3176b59e03eSHaavard Skinnemoen void lcd_show_board_info(void);
3188655b6f8Swdenk 
319676d319eSSimon Glass /* Return the size of the LCD frame buffer, and the line length */
320676d319eSSimon Glass int lcd_get_size(int *line_length);
321676d319eSSimon Glass 
3226a195d2dSStephen Warren int lcd_dt_simplefb_add_node(void *blob);
3236a195d2dSStephen Warren int lcd_dt_simplefb_enable_existing_node(void *blob);
3246a195d2dSStephen Warren 
3257d95f2a3SSimon Glass /* Update the LCD / flush the cache */
3267d95f2a3SSimon Glass void lcd_sync(void);
3277d95f2a3SSimon Glass 
3288655b6f8Swdenk /************************************************************************/
3298655b6f8Swdenk /* ** BITMAP DISPLAY SUPPORT						*/
3308655b6f8Swdenk /************************************************************************/
331639221c7SJon Loeliger #if defined(CONFIG_CMD_BMP) || defined(CONFIG_SPLASH_SCREEN)
3328655b6f8Swdenk # include <bmp_layout.h>
3338655b6f8Swdenk # include <asm/byteorder.h>
334639221c7SJon Loeliger #endif
3358655b6f8Swdenk 
3368655b6f8Swdenk /*
3378655b6f8Swdenk  *  Information about displays we are using. This is for configuring
3388655b6f8Swdenk  *  the LCD controller and memory allocation. Someone has to know what
3398655b6f8Swdenk  *  is connected, as we can't autodetect anything.
3408655b6f8Swdenk  */
3416d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HIGH	0	/* Pins are active high			*/
3426d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOW	1	/* Pins are active low			*/
3438655b6f8Swdenk 
3448655b6f8Swdenk #define LCD_MONOCHROME	0
3458655b6f8Swdenk #define LCD_COLOR2	1
3468655b6f8Swdenk #define LCD_COLOR4	2
3478655b6f8Swdenk #define LCD_COLOR8	3
3488655b6f8Swdenk #define LCD_COLOR16	4
34957d76a89SHannes Petermaier #define LCD_COLOR32	5
3508655b6f8Swdenk /*----------------------------------------------------------------------*/
35188804d19Swdenk #if defined(CONFIG_LCD_INFO_BELOW_LOGO)
3528655b6f8Swdenk # define LCD_INFO_X		0
3538655b6f8Swdenk # define LCD_INFO_Y		(BMP_LOGO_HEIGHT + VIDEO_FONT_HEIGHT)
3548655b6f8Swdenk #elif defined(CONFIG_LCD_LOGO)
3558655b6f8Swdenk # define LCD_INFO_X		(BMP_LOGO_WIDTH + 4 * VIDEO_FONT_WIDTH)
3566b035141SJeroen Hofstee # define LCD_INFO_Y		VIDEO_FONT_HEIGHT
3578655b6f8Swdenk #else
3586b035141SJeroen Hofstee # define LCD_INFO_X		VIDEO_FONT_WIDTH
3596b035141SJeroen Hofstee # define LCD_INFO_Y		VIDEO_FONT_HEIGHT
3608655b6f8Swdenk #endif
3618655b6f8Swdenk 
3628655b6f8Swdenk /* Default to 8bpp if bit depth not specified */
3638655b6f8Swdenk #ifndef LCD_BPP
3648655b6f8Swdenk # define LCD_BPP			LCD_COLOR8
3658655b6f8Swdenk #endif
3668655b6f8Swdenk #ifndef LCD_DF
3678655b6f8Swdenk # define LCD_DF			1
3688655b6f8Swdenk #endif
3698655b6f8Swdenk 
3708655b6f8Swdenk /* Calculate nr. of bits per pixel  and nr. of colors */
3718655b6f8Swdenk #define NBITS(bit_code)		(1 << (bit_code))
3728655b6f8Swdenk #define NCOLORS(bit_code)	(1 << NBITS(bit_code))
3738655b6f8Swdenk 
3748655b6f8Swdenk /************************************************************************/
3758655b6f8Swdenk /* ** CONSOLE CONSTANTS							*/
3768655b6f8Swdenk /************************************************************************/
377f4469f50SNikita Kiryanov #if LCD_BPP == LCD_COLOR8
3788655b6f8Swdenk 
3798655b6f8Swdenk /*
3808655b6f8Swdenk  * 8bpp color definitions
3818655b6f8Swdenk  */
3828655b6f8Swdenk # define CONSOLE_COLOR_BLACK	0
3838655b6f8Swdenk # define CONSOLE_COLOR_RED	1
3848655b6f8Swdenk # define CONSOLE_COLOR_GREEN	2
3858655b6f8Swdenk # define CONSOLE_COLOR_YELLOW	3
3868655b6f8Swdenk # define CONSOLE_COLOR_BLUE	4
3878655b6f8Swdenk # define CONSOLE_COLOR_MAGENTA	5
3888655b6f8Swdenk # define CONSOLE_COLOR_CYAN	6
3898655b6f8Swdenk # define CONSOLE_COLOR_GREY	14
3908655b6f8Swdenk # define CONSOLE_COLOR_WHITE	15	/* Must remain last / highest	*/
3918655b6f8Swdenk 
39257d76a89SHannes Petermaier #elif LCD_BPP == LCD_COLOR32
39357d76a89SHannes Petermaier /*
39457d76a89SHannes Petermaier  * 32bpp color definitions
39557d76a89SHannes Petermaier  */
39657d76a89SHannes Petermaier # define CONSOLE_COLOR_RED	0x00ff0000
39757d76a89SHannes Petermaier # define CONSOLE_COLOR_GREEN	0x0000ff00
39857d76a89SHannes Petermaier # define CONSOLE_COLOR_YELLOW	0x00ffff00
39957d76a89SHannes Petermaier # define CONSOLE_COLOR_BLUE	0x000000ff
40057d76a89SHannes Petermaier # define CONSOLE_COLOR_MAGENTA	0x00ff00ff
40157d76a89SHannes Petermaier # define CONSOLE_COLOR_CYAN	0x0000ffff
40257d76a89SHannes Petermaier # define CONSOLE_COLOR_GREY	0x00aaaaaa
40357d76a89SHannes Petermaier # define CONSOLE_COLOR_BLACK	0x00000000
40457d76a89SHannes Petermaier # define CONSOLE_COLOR_WHITE	0x00ffffff	/* Must remain last / highest*/
40557d76a89SHannes Petermaier # define NBYTES(bit_code)	(NBITS(bit_code) >> 3)
40657d76a89SHannes Petermaier 
4078655b6f8Swdenk #else
4088655b6f8Swdenk 
4098655b6f8Swdenk /*
4108655b6f8Swdenk  * 16bpp color definitions
4118655b6f8Swdenk  */
4128655b6f8Swdenk # define CONSOLE_COLOR_BLACK	0x0000
4138655b6f8Swdenk # define CONSOLE_COLOR_WHITE	0xffff	/* Must remain last / highest	*/
4148655b6f8Swdenk 
4158655b6f8Swdenk #endif /* color definitions */
4168655b6f8Swdenk 
4178655b6f8Swdenk /************************************************************************/
4188655b6f8Swdenk #ifndef PAGE_SIZE
4198655b6f8Swdenk # define PAGE_SIZE	4096
4208655b6f8Swdenk #endif
4218655b6f8Swdenk 
4228655b6f8Swdenk /************************************************************************/
4238655b6f8Swdenk 
4248655b6f8Swdenk #endif	/* _LCD_H_ */
425