4 #include <mach/regs-gpio.h>
6 /* Different hardware revisions, passed in ATAG_REVISION by u-boot */
7 #define GTA02v1_SYSTEM_REV 0x00000310
8 #define GTA02v2_SYSTEM_REV 0x00000320
9 #define GTA02v3_SYSTEM_REV 0x00000330
10 #define GTA02v4_SYSTEM_REV 0x00000340
11 #define GTA02v5_SYSTEM_REV 0x00000350
12 /* since A7 is basically same as A6, we use A6 PCB ID */
13 #define GTA02v6_SYSTEM_REV 0x00000360
15 #define GTA02_GPIO_n3DL_GSM S3C2410_GPA(13) /* v1 + v2 + v3 only */
17 #define GTA02_GPIO_PWR_LED1 S3C2410_GPB(0)
18 #define GTA02_GPIO_PWR_LED2 S3C2410_GPB(1)
19 #define GTA02_GPIO_AUX_LED S3C2410_GPB(2)
20 #define GTA02_GPIO_VIBRATOR_ON S3C2410_GPB(3)
21 #define GTA02_GPIO_MODEM_RST S3C2410_GPB(5)
22 #define GTA02_GPIO_BT_EN S3C2410_GPB(6)
23 #define GTA02_GPIO_MODEM_ON S3C2410_GPB(7)
24 #define GTA02_GPIO_EXTINT8 S3C2410_GPB(8)
25 #define GTA02_GPIO_USB_PULLUP S3C2410_GPB(9)
27 #define GTA02_GPIO_PIO5 S3C2410_GPC(5) /* v3 + v4 only */
29 #define GTA02v3_GPIO_nG1_CS S3C2410_GPD(12) /* v3 + v4 only */
30 #define GTA02v3_GPIO_nG2_CS S3C2410_GPD(13) /* v3 + v4 only */
31 #define GTA02v5_GPIO_HDQ S3C2410_GPD(14) /* v5 + */
33 #define GTA02_GPIO_nG1_INT S3C2410_GPF(0)
34 #define GTA02_GPIO_IO1 S3C2410_GPF(1)
35 #define GTA02_GPIO_PIO_2 S3C2410_GPF(2) /* v2 + v3 + v4 only */
36 #define GTA02_GPIO_JACK_INSERT S3C2410_GPF(4)
37 #define GTA02_GPIO_WLAN_GPIO1 S3C2410_GPF(5) /* v2 + v3 + v4 only */
38 #define GTA02_GPIO_AUX_KEY S3C2410_GPF(6)
39 #define GTA02_GPIO_HOLD_KEY S3C2410_GPF(7)
41 #define GTA02_GPIO_3D_IRQ S3C2410_GPG(4)
42 #define GTA02v2_GPIO_nG2_INT S3C2410_GPG(8) /* v2 + v3 + v4 only */
43 #define GTA02v3_GPIO_nUSB_OC S3C2410_GPG(9) /* v3 + v4 only */
44 #define GTA02v3_GPIO_nUSB_FLT S3C2410_GPG(10) /* v3 + v4 only */
45 #define GTA02v3_GPIO_nGSM_OC S3C2410_GPG(11) /* v3 + v4 only */
47 #define GTA02_GPIO_AMP_SHUT S3C2410_GPJ(1) /* v2 + v3 + v4 only */
48 #define GTA02v1_GPIO_WLAN_GPIO10 S3C2410_GPJ(2)
49 #define GTA02_GPIO_HP_IN S3C2410_GPJ(2) /* v2 + v3 + v4 only */
50 #define GTA02_GPIO_INT0 S3C2410_GPJ(3) /* v2 + v3 + v4 only */
51 #define GTA02_GPIO_nGSM_EN S3C2410_GPJ(4)
52 #define GTA02_GPIO_3D_RESET S3C2410_GPJ(5)
53 #define GTA02_GPIO_nDL_GSM S3C2410_GPJ(6) /* v4 + v5 only */
54 #define GTA02_GPIO_WLAN_GPIO0 S3C2410_GPJ(7)
55 #define GTA02v1_GPIO_BAT_ID S3C2410_GPJ(8)
56 #define GTA02_GPIO_KEEPACT S3C2410_GPJ(8)
57 #define GTA02v1_GPIO_HP_IN S3C2410_GPJ(10)
58 #define GTA02_CHIP_PWD S3C2410_GPJ(11) /* v2 + v3 + v4 only */
59 #define GTA02_GPIO_nWLAN_RESET S3C2410_GPJ(12) /* v2 + v3 + v4 only */
61 #define GTA02_IRQ_GSENSOR_1 IRQ_EINT0
62 #define GTA02_IRQ_MODEM IRQ_EINT1
63 #define GTA02_IRQ_PIO_2 IRQ_EINT2 /* v2 + v3 + v4 only */
64 #define GTA02_IRQ_nJACK_INSERT IRQ_EINT4
65 #define GTA02_IRQ_WLAN_GPIO1 IRQ_EINT5
66 #define GTA02_IRQ_AUX IRQ_EINT6
67 #define GTA02_IRQ_nHOLD IRQ_EINT7
68 #define GTA02_IRQ_PCF50633 IRQ_EINT9
69 #define GTA02_IRQ_3D IRQ_EINT12
70 #define GTA02_IRQ_GSENSOR_2 IRQ_EINT16 /* v2 + v3 + v4 only */
71 #define GTA02v3_IRQ_nUSB_OC IRQ_EINT17 /* v3 + v4 only */
72 #define GTA02v3_IRQ_nUSB_FLT IRQ_EINT18 /* v3 + v4 only */
73 #define GTA02v3_IRQ_nGSM_OC IRQ_EINT19 /* v3 + v4 only */
75 /* returns 00 000 on GTA02 A5 and earlier, A6 returns 01 001 */
76 #define GTA02_PCB_ID1_0 S3C2410_GPC(13)
77 #define GTA02_PCB_ID1_1 S3C2410_GPC(15)
78 #define GTA02_PCB_ID1_2 S3C2410_GPD(0)
79 #define GTA02_PCB_ID2_0 S3C2410_GPD(3)
80 #define GTA02_PCB_ID2_1 S3C2410_GPD(4)
82 int gta02_get_pcb_revision(void);