Blame view

kernel/linux-rt-4.4.41/arch/arm/plat-samsung/include/plat/fb-s3c2410.h 1.85 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
  /* arch/arm/plat-samsung/include/plat/fb-s3c2410.h
   *
   * Copyright (c) 2004 Arnaud Patard <arnaud.patard@rtp-net.org>
   *
   * Inspired by pxafb.h
   *
   * 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.
  */
  
  #ifndef __ASM_PLAT_FB_S3C2410_H
  #define __ASM_PLAT_FB_S3C2410_H __FILE__
  
  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;
  
  	/* 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;
  };
  
  struct s3c2410fb_mach_info {
  
  	struct s3c2410fb_display *displays;	/* attached diplays 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;
  
  	/* lpc3600 control register */
  	unsigned long	lpcsel;
  };
  
  extern void __init s3c24xx_fb_set_platdata(struct s3c2410fb_mach_info *);
  
  #endif /* __ASM_PLAT_FB_S3C2410_H */