99 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  * Copyright (c) 2004 Arnaud Patard <arnaud.patard@rtp-net.org>
 | |
|  *
 | |
|  * Inspired by pxafb.h
 | |
| */
 | |
| 
 | |
| #ifndef __ASM_PLAT_FB_S3C2410_H
 | |
| #define __ASM_PLAT_FB_S3C2410_H __FILE__
 | |
| 
 | |
| #include <linux/compiler_types.h>
 | |
| 
 | |
| struct s3c2410fb_hw {
 | |
| 	unsigned long	lcdcon1;
 | |
| 	unsigned long	lcdcon2;
 | |
| 	unsigned long	lcdcon3;
 | |
| 	unsigned long	lcdcon4;
 | |
| 	unsigned long	lcdcon5;
 | |
| };
 | |
| 
 | |
| /* LCD description */
 | |
| struct s3c2410fb_display {
 | |
| 	/* LCD type */
 | |
| 	unsigned type;
 | |
| #define S3C2410_LCDCON1_DSCAN4	   (0<<5)
 | |
| #define S3C2410_LCDCON1_STN4	   (1<<5)
 | |
| #define S3C2410_LCDCON1_STN8	   (2<<5)
 | |
| #define S3C2410_LCDCON1_TFT	   (3<<5)
 | |
| 
 | |
| #define S3C2410_LCDCON1_TFT1BPP	   (8<<1)
 | |
| #define S3C2410_LCDCON1_TFT2BPP	   (9<<1)
 | |
| #define S3C2410_LCDCON1_TFT4BPP	   (10<<1)
 | |
| #define S3C2410_LCDCON1_TFT8BPP	   (11<<1)
 | |
| #define S3C2410_LCDCON1_TFT16BPP   (12<<1)
 | |
| #define S3C2410_LCDCON1_TFT24BPP   (13<<1)
 | |
| 
 | |
| 	/* Screen size */
 | |
| 	unsigned short width;
 | |
| 	unsigned short height;
 | |
| 
 | |
| 	/* Screen info */
 | |
| 	unsigned short xres;
 | |
| 	unsigned short yres;
 | |
| 	unsigned short bpp;
 | |
| 
 | |
| 	unsigned pixclock;		/* pixclock in picoseconds */
 | |
| 	unsigned short left_margin;  /* value in pixels (TFT) or HCLKs (STN) */
 | |
| 	unsigned short right_margin; /* value in pixels (TFT) or HCLKs (STN) */
 | |
| 	unsigned short hsync_len;    /* value in pixels (TFT) or HCLKs (STN) */
 | |
| 	unsigned short upper_margin;	/* value in lines (TFT) or 0 (STN) */
 | |
| 	unsigned short lower_margin;	/* value in lines (TFT) or 0 (STN) */
 | |
| 	unsigned short vsync_len;	/* value in lines (TFT) or 0 (STN) */
 | |
| 
 | |
| 	/* lcd configuration registers */
 | |
| 	unsigned long	lcdcon5;
 | |
| #define S3C2410_LCDCON5_BPP24BL	    (1<<12)
 | |
| #define S3C2410_LCDCON5_FRM565	    (1<<11)
 | |
| #define S3C2410_LCDCON5_INVVCLK	    (1<<10)
 | |
| #define S3C2410_LCDCON5_INVVLINE    (1<<9)
 | |
| #define S3C2410_LCDCON5_INVVFRAME   (1<<8)
 | |
| #define S3C2410_LCDCON5_INVVD	    (1<<7)
 | |
| #define S3C2410_LCDCON5_INVVDEN	    (1<<6)
 | |
| #define S3C2410_LCDCON5_INVPWREN    (1<<5)
 | |
| #define S3C2410_LCDCON5_INVLEND	    (1<<4)
 | |
| #define S3C2410_LCDCON5_PWREN	    (1<<3)
 | |
| #define S3C2410_LCDCON5_ENLEND	    (1<<2)
 | |
| #define S3C2410_LCDCON5_BSWP	    (1<<1)
 | |
| #define S3C2410_LCDCON5_HWSWP	    (1<<0)
 | |
| };
 | |
| 
 | |
| struct s3c2410fb_mach_info {
 | |
| 
 | |
| 	struct s3c2410fb_display *displays;	/* attached displays info */
 | |
| 	unsigned num_displays;			/* number of defined displays */
 | |
| 	unsigned default_display;
 | |
| 
 | |
| 	/* GPIOs */
 | |
| 
 | |
| 	unsigned long	gpcup;
 | |
| 	unsigned long	gpcup_mask;
 | |
| 	unsigned long	gpccon;
 | |
| 	unsigned long	gpccon_mask;
 | |
| 	unsigned long	gpdup;
 | |
| 	unsigned long	gpdup_mask;
 | |
| 	unsigned long	gpdcon;
 | |
| 	unsigned long	gpdcon_mask;
 | |
| 
 | |
| 	void __iomem *  gpccon_reg;
 | |
| 	void __iomem *  gpcup_reg;
 | |
| 	void __iomem *  gpdcon_reg;
 | |
| 	void __iomem *  gpdup_reg;
 | |
| 
 | |
| 	/* lpc3600 control register */
 | |
| 	unsigned long	lpcsel;
 | |
| };
 | |
| 
 | |
| extern void s3c24xx_fb_set_platdata(struct s3c2410fb_mach_info *);
 | |
| 
 | |
| #endif /* __ASM_PLAT_FB_S3C2410_H */
 |