diff options
author | Russell King <rmk@dyn-67.arm.linux.org.uk> | 2009-06-14 06:01:05 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2009-06-14 06:01:05 -0400 |
commit | 06099961002a813324d057a91695af7c72939da6 (patch) | |
tree | d55ee7a8833c95ee2afb6914bb8a2977cbb9fa31 /arch/arm/mach-stmp37xx | |
parent | 4c31791c3d9d38ac052dd5e2981df713d8f3dcc4 (diff) | |
parent | c11c22177ae2929598051a39e4655be4a42cb805 (diff) |
Merge branch 'stmp' into devel
Diffstat (limited to 'arch/arm/mach-stmp37xx')
31 files changed, 2330 insertions, 0 deletions
diff --git a/arch/arm/mach-stmp37xx/Makefile b/arch/arm/mach-stmp37xx/Makefile new file mode 100644 index 000000000000..57deffd09fbf --- /dev/null +++ b/arch/arm/mach-stmp37xx/Makefile | |||
@@ -0,0 +1,2 @@ | |||
1 | obj-$(CONFIG_ARCH_STMP37XX) += stmp37xx.o | ||
2 | obj-$(CONFIG_MACH_STMP37XX) += stmp37xx_devb.o | ||
diff --git a/arch/arm/mach-stmp37xx/Makefile.boot b/arch/arm/mach-stmp37xx/Makefile.boot new file mode 100644 index 000000000000..1568ad404d59 --- /dev/null +++ b/arch/arm/mach-stmp37xx/Makefile.boot | |||
@@ -0,0 +1,3 @@ | |||
1 | zreladdr-y := 0x40008000 | ||
2 | params_phys-y := 0x40000100 | ||
3 | initrd_phys-y := 0x40800000 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/entry-macro.S b/arch/arm/mach-stmp37xx/include/mach/entry-macro.S new file mode 100644 index 000000000000..fed2787b6c34 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/entry-macro.S | |||
@@ -0,0 +1,37 @@ | |||
1 | /* | ||
2 | * Low-level IRQ helper macros for Freescale STMP37XX | ||
3 | * | ||
4 | * Embedded Alley Solutions, Inc <source@embeddedalley.com> | ||
5 | * | ||
6 | * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved. | ||
7 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
8 | */ | ||
9 | |||
10 | /* | ||
11 | * The code contained herein is licensed under the GNU General Public | ||
12 | * License. You may obtain a copy of the GNU General Public License | ||
13 | * Version 2 or later at the following locations: | ||
14 | * | ||
15 | * http://www.opensource.org/licenses/gpl-license.html | ||
16 | * http://www.gnu.org/copyleft/gpl.html | ||
17 | */ | ||
18 | |||
19 | .macro disable_fiq | ||
20 | .endm | ||
21 | |||
22 | .macro get_irqnr_and_base, irqnr, irqstat, base, tmp | ||
23 | |||
24 | mov \base, #0xf0000000 @ vm address of IRQ controller | ||
25 | ldr \irqnr, [\base, #0x30] @ HW_ICOLL_STAT | ||
26 | cmp \irqnr, #0x3f | ||
27 | movne \irqstat, #0 @ Ack this IRQ | ||
28 | strne \irqstat, [\base, #0x00]@ HW_ICOLL_VECTOR | ||
29 | moveqs \irqnr, #0 @ Zero flag set for no IRQ | ||
30 | |||
31 | .endm | ||
32 | |||
33 | .macro get_irqnr_preamble, base, tmp | ||
34 | .endm | ||
35 | |||
36 | .macro arch_ret_to_user, tmp1, tmp2 | ||
37 | .endm | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/irqs.h b/arch/arm/mach-stmp37xx/include/mach/irqs.h new file mode 100644 index 000000000000..98f12938550d --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/irqs.h | |||
@@ -0,0 +1,99 @@ | |||
1 | /* | ||
2 | * Freescale STMP37XX interrupts | ||
3 | * | ||
4 | * Copyright (C) 2005 Sigmatel Inc | ||
5 | * | ||
6 | * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved. | ||
7 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
8 | */ | ||
9 | |||
10 | /* | ||
11 | * The code contained herein is licensed under the GNU General Public | ||
12 | * License. You may obtain a copy of the GNU General Public License | ||
13 | * Version 2 or later at the following locations: | ||
14 | * | ||
15 | * http://www.opensource.org/licenses/gpl-license.html | ||
16 | * http://www.gnu.org/copyleft/gpl.html | ||
17 | */ | ||
18 | #ifndef _ASM_ARCH_IRQS_H | ||
19 | #define _ASM_ARCH_IRQS_H | ||
20 | |||
21 | #define IRQ_DEBUG_UART 0 | ||
22 | #define IRQ_COMMS_RX 1 | ||
23 | #define IRQ_COMMS_TX 1 | ||
24 | #define IRQ_SSP2_ERROR 2 | ||
25 | #define IRQ_VDD5V 3 | ||
26 | #define IRQ_HEADPHONE_SHORT 4 | ||
27 | #define IRQ_DAC_DMA 5 | ||
28 | #define IRQ_DAC_ERROR 6 | ||
29 | #define IRQ_ADC_DMA 7 | ||
30 | #define IRQ_ADC_ERROR 8 | ||
31 | #define IRQ_SPDIF_DMA 9 | ||
32 | #define IRQ_SAIF2_DMA 9 | ||
33 | #define IRQ_SPDIF_ERROR 10 | ||
34 | #define IRQ_SAIF1_IRQ 10 | ||
35 | #define IRQ_SAIF2_IRQ 10 | ||
36 | #define IRQ_USB_CTRL 11 | ||
37 | #define IRQ_USB_WAKEUP 12 | ||
38 | #define IRQ_GPMI_DMA 13 | ||
39 | #define IRQ_SSP1_DMA 14 | ||
40 | #define IRQ_SSP_ERROR 15 | ||
41 | #define IRQ_GPIO0 16 | ||
42 | #define IRQ_GPIO1 17 | ||
43 | #define IRQ_GPIO2 18 | ||
44 | #define IRQ_SAIF1_DMA 19 | ||
45 | #define IRQ_SSP2_DMA 20 | ||
46 | #define IRQ_ECC8_IRQ 21 | ||
47 | #define IRQ_RTC_ALARM 22 | ||
48 | #define IRQ_UARTAPP_TX_DMA 23 | ||
49 | #define IRQ_UARTAPP_INTERNAL 24 | ||
50 | #define IRQ_UARTAPP_RX_DMA 25 | ||
51 | #define IRQ_I2C_DMA 26 | ||
52 | #define IRQ_I2C_ERROR 27 | ||
53 | #define IRQ_TIMER0 28 | ||
54 | #define IRQ_TIMER1 29 | ||
55 | #define IRQ_TIMER2 30 | ||
56 | #define IRQ_TIMER3 31 | ||
57 | #define IRQ_BATT_BRNOUT 32 | ||
58 | #define IRQ_VDDD_BRNOUT 33 | ||
59 | #define IRQ_VDDIO_BRNOUT 34 | ||
60 | #define IRQ_VDD18_BRNOUT 35 | ||
61 | #define IRQ_TOUCH_DETECT 36 | ||
62 | #define IRQ_LRADC_CH0 37 | ||
63 | #define IRQ_LRADC_CH1 38 | ||
64 | #define IRQ_LRADC_CH2 39 | ||
65 | #define IRQ_LRADC_CH3 40 | ||
66 | #define IRQ_LRADC_CH4 41 | ||
67 | #define IRQ_LRADC_CH5 42 | ||
68 | #define IRQ_LRADC_CH6 43 | ||
69 | #define IRQ_LRADC_CH7 44 | ||
70 | #define IRQ_LCDIF_DMA 45 | ||
71 | #define IRQ_LCDIF_ERROR 46 | ||
72 | #define IRQ_DIGCTL_DEBUG_TRAP 47 | ||
73 | #define IRQ_RTC_1MSEC 48 | ||
74 | #define IRQ_DRI_DMA 49 | ||
75 | #define IRQ_DRI_ATTENTION 50 | ||
76 | #define IRQ_GPMI_ATTENTION 51 | ||
77 | #define IRQ_IR 52 | ||
78 | #define IRQ_DCP_VMI 53 | ||
79 | #define IRQ_DCP 54 | ||
80 | #define IRQ_RESERVED_55 55 | ||
81 | #define IRQ_RESERVED_56 56 | ||
82 | #define IRQ_RESERVED_57 57 | ||
83 | #define IRQ_RESERVED_58 58 | ||
84 | #define IRQ_RESERVED_59 59 | ||
85 | #define SW_IRQ_60 60 | ||
86 | #define SW_IRQ_61 61 | ||
87 | #define SW_IRQ_62 62 | ||
88 | #define SW_IRQ_63 63 | ||
89 | |||
90 | #define NR_REAL_IRQS 64 | ||
91 | #define NR_IRQS (NR_REAL_IRQS + 32 * 3) | ||
92 | |||
93 | /* TIMER and BRNOUT are FIQ capable */ | ||
94 | #define FIQ_START IRQ_TIMER0 | ||
95 | |||
96 | /* Hard disk IRQ is a GPMI attention IRQ */ | ||
97 | #define IRQ_HARDDISK IRQ_GPMI_ATTENTION | ||
98 | |||
99 | #endif /* _ASM_ARCH_IRQS_H */ | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/pins.h b/arch/arm/mach-stmp37xx/include/mach/pins.h new file mode 100644 index 000000000000..d56de0c471d8 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/pins.h | |||
@@ -0,0 +1,147 @@ | |||
1 | /* | ||
2 | * Freescale STMP37XX SoC pin multiplexing | ||
3 | * | ||
4 | * Author: Vladislav Buzov <vbuzov@embeddedalley.com> | ||
5 | * | ||
6 | * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved. | ||
7 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
8 | */ | ||
9 | |||
10 | /* | ||
11 | * The code contained herein is licensed under the GNU General Public | ||
12 | * License. You may obtain a copy of the GNU General Public License | ||
13 | * Version 2 or later at the following locations: | ||
14 | * | ||
15 | * http://www.opensource.org/licenses/gpl-license.html | ||
16 | * http://www.gnu.org/copyleft/gpl.html | ||
17 | */ | ||
18 | #ifndef __ASM_ARCH_PINS_H | ||
19 | #define __ASM_ARCH_PINS_H | ||
20 | |||
21 | /* | ||
22 | * Define all STMP37XX pins, a pin name corresponds to a STMP37xx hardware | ||
23 | * interface this pin belongs to. | ||
24 | */ | ||
25 | |||
26 | /* Bank 0 */ | ||
27 | #define PINID_GPMI_D00 STMP3XXX_PINID(0, 0) | ||
28 | #define PINID_GPMI_D01 STMP3XXX_PINID(0, 1) | ||
29 | #define PINID_GPMI_D02 STMP3XXX_PINID(0, 2) | ||
30 | #define PINID_GPMI_D03 STMP3XXX_PINID(0, 3) | ||
31 | #define PINID_GPMI_D04 STMP3XXX_PINID(0, 4) | ||
32 | #define PINID_GPMI_D05 STMP3XXX_PINID(0, 5) | ||
33 | #define PINID_GPMI_D06 STMP3XXX_PINID(0, 6) | ||
34 | #define PINID_GPMI_D07 STMP3XXX_PINID(0, 7) | ||
35 | #define PINID_GPMI_D08 STMP3XXX_PINID(0, 8) | ||
36 | #define PINID_GPMI_D09 STMP3XXX_PINID(0, 9) | ||
37 | #define PINID_GPMI_D10 STMP3XXX_PINID(0, 10) | ||
38 | #define PINID_GPMI_D11 STMP3XXX_PINID(0, 11) | ||
39 | #define PINID_GPMI_D12 STMP3XXX_PINID(0, 12) | ||
40 | #define PINID_GPMI_D13 STMP3XXX_PINID(0, 13) | ||
41 | #define PINID_GPMI_D14 STMP3XXX_PINID(0, 14) | ||
42 | #define PINID_GPMI_D15 STMP3XXX_PINID(0, 15) | ||
43 | #define PINID_GPMI_A0 STMP3XXX_PINID(0, 16) | ||
44 | #define PINID_GPMI_A1 STMP3XXX_PINID(0, 17) | ||
45 | #define PINID_GPMI_A2 STMP3XXX_PINID(0, 18) | ||
46 | #define PINID_GPMI_RDY0 STMP3XXX_PINID(0, 19) | ||
47 | #define PINID_GPMI_RDY2 STMP3XXX_PINID(0, 20) | ||
48 | #define PINID_GPMI_RDY3 STMP3XXX_PINID(0, 21) | ||
49 | #define PINID_GPMI_RESETN STMP3XXX_PINID(0, 22) | ||
50 | #define PINID_GPMI_IRQ STMP3XXX_PINID(0, 23) | ||
51 | #define PINID_GPMI_WRN STMP3XXX_PINID(0, 24) | ||
52 | #define PINID_GPMI_RDN STMP3XXX_PINID(0, 25) | ||
53 | #define PINID_UART2_CTS STMP3XXX_PINID(0, 26) | ||
54 | #define PINID_UART2_RTS STMP3XXX_PINID(0, 27) | ||
55 | #define PINID_UART2_RX STMP3XXX_PINID(0, 28) | ||
56 | #define PINID_UART2_TX STMP3XXX_PINID(0, 29) | ||
57 | |||
58 | /* Bank 1 */ | ||
59 | #define PINID_LCD_D00 STMP3XXX_PINID(1, 0) | ||
60 | #define PINID_LCD_D01 STMP3XXX_PINID(1, 1) | ||
61 | #define PINID_LCD_D02 STMP3XXX_PINID(1, 2) | ||
62 | #define PINID_LCD_D03 STMP3XXX_PINID(1, 3) | ||
63 | #define PINID_LCD_D04 STMP3XXX_PINID(1, 4) | ||
64 | #define PINID_LCD_D05 STMP3XXX_PINID(1, 5) | ||
65 | #define PINID_LCD_D06 STMP3XXX_PINID(1, 6) | ||
66 | #define PINID_LCD_D07 STMP3XXX_PINID(1, 7) | ||
67 | #define PINID_LCD_D08 STMP3XXX_PINID(1, 8) | ||
68 | #define PINID_LCD_D09 STMP3XXX_PINID(1, 9) | ||
69 | #define PINID_LCD_D10 STMP3XXX_PINID(1, 10) | ||
70 | #define PINID_LCD_D11 STMP3XXX_PINID(1, 11) | ||
71 | #define PINID_LCD_D12 STMP3XXX_PINID(1, 12) | ||
72 | #define PINID_LCD_D13 STMP3XXX_PINID(1, 13) | ||
73 | #define PINID_LCD_D14 STMP3XXX_PINID(1, 14) | ||
74 | #define PINID_LCD_D15 STMP3XXX_PINID(1, 15) | ||
75 | #define PINID_LCD_RESET STMP3XXX_PINID(1, 16) | ||
76 | #define PINID_LCD_RS STMP3XXX_PINID(1, 17) | ||
77 | #define PINID_LCD_WR_RWN STMP3XXX_PINID(1, 18) | ||
78 | #define PINID_LCD_RD_E STMP3XXX_PINID(1, 19) | ||
79 | #define PINID_LCD_CS STMP3XXX_PINID(1, 20) | ||
80 | #define PINID_LCD_BUSY STMP3XXX_PINID(1, 21) | ||
81 | #define PINID_SSP1_CMD STMP3XXX_PINID(1, 22) | ||
82 | #define PINID_SSP1_SCK STMP3XXX_PINID(1, 23) | ||
83 | #define PINID_SSP1_DATA0 STMP3XXX_PINID(1, 24) | ||
84 | #define PINID_SSP1_DATA1 STMP3XXX_PINID(1, 25) | ||
85 | #define PINID_SSP1_DATA2 STMP3XXX_PINID(1, 26) | ||
86 | #define PINID_SSP1_DATA3 STMP3XXX_PINID(1, 27) | ||
87 | #define PINID_SSP1_DETECT STMP3XXX_PINID(1, 28) | ||
88 | |||
89 | /* Bank 2 */ | ||
90 | #define PINID_PWM0 STMP3XXX_PINID(2, 0) | ||
91 | #define PINID_PWM1 STMP3XXX_PINID(2, 1) | ||
92 | #define PINID_PWM2 STMP3XXX_PINID(2, 2) | ||
93 | #define PINID_PWM3 STMP3XXX_PINID(2, 3) | ||
94 | #define PINID_PWM4 STMP3XXX_PINID(2, 4) | ||
95 | #define PINID_I2C_SCL STMP3XXX_PINID(2, 5) | ||
96 | #define PINID_I2C_SDA STMP3XXX_PINID(2, 6) | ||
97 | #define PINID_ROTTARYA STMP3XXX_PINID(2, 7) | ||
98 | #define PINID_ROTTARYB STMP3XXX_PINID(2, 8) | ||
99 | #define PINID_EMI_CKE STMP3XXX_PINID(2, 9) | ||
100 | #define PINID_EMI_RASN STMP3XXX_PINID(2, 10) | ||
101 | #define PINID_EMI_CASN STMP3XXX_PINID(2, 11) | ||
102 | #define PINID_EMI_CE0N STMP3XXX_PINID(2, 12) | ||
103 | #define PINID_EMI_CE1N STMP3XXX_PINID(2, 13) | ||
104 | #define PINID_EMI_CE2N STMP3XXX_PINID(2, 14) | ||
105 | #define PINID_EMI_CE3N STMP3XXX_PINID(2, 15) | ||
106 | #define PINID_EMI_A00 STMP3XXX_PINID(2, 16) | ||
107 | #define PINID_EMI_A01 STMP3XXX_PINID(2, 17) | ||
108 | #define PINID_EMI_A02 STMP3XXX_PINID(2, 18) | ||
109 | #define PINID_EMI_A03 STMP3XXX_PINID(2, 19) | ||
110 | #define PINID_EMI_A04 STMP3XXX_PINID(2, 20) | ||
111 | #define PINID_EMI_A05 STMP3XXX_PINID(2, 21) | ||
112 | #define PINID_EMI_A06 STMP3XXX_PINID(2, 22) | ||
113 | #define PINID_EMI_A07 STMP3XXX_PINID(2, 23) | ||
114 | #define PINID_EMI_A08 STMP3XXX_PINID(2, 24) | ||
115 | #define PINID_EMI_A09 STMP3XXX_PINID(2, 25) | ||
116 | #define PINID_EMI_A10 STMP3XXX_PINID(2, 26) | ||
117 | #define PINID_EMI_A11 STMP3XXX_PINID(2, 27) | ||
118 | #define PINID_EMI_A12 STMP3XXX_PINID(2, 28) | ||
119 | #define PINID_EMI_A13 STMP3XXX_PINID(2, 29) | ||
120 | #define PINID_EMI_A14 STMP3XXX_PINID(2, 30) | ||
121 | #define PINID_EMI_WEN STMP3XXX_PINID(2, 31) | ||
122 | |||
123 | /* Bank 3 */ | ||
124 | #define PINID_EMI_D00 STMP3XXX_PINID(3, 0) | ||
125 | #define PINID_EMI_D01 STMP3XXX_PINID(3, 1) | ||
126 | #define PINID_EMI_D02 STMP3XXX_PINID(3, 2) | ||
127 | #define PINID_EMI_D03 STMP3XXX_PINID(3, 3) | ||
128 | #define PINID_EMI_D04 STMP3XXX_PINID(3, 4) | ||
129 | #define PINID_EMI_D05 STMP3XXX_PINID(3, 5) | ||
130 | #define PINID_EMI_D06 STMP3XXX_PINID(3, 6) | ||
131 | #define PINID_EMI_D07 STMP3XXX_PINID(3, 7) | ||
132 | #define PINID_EMI_D08 STMP3XXX_PINID(3, 8) | ||
133 | #define PINID_EMI_D09 STMP3XXX_PINID(3, 9) | ||
134 | #define PINID_EMI_D10 STMP3XXX_PINID(3, 10) | ||
135 | #define PINID_EMI_D11 STMP3XXX_PINID(3, 11) | ||
136 | #define PINID_EMI_D12 STMP3XXX_PINID(3, 12) | ||
137 | #define PINID_EMI_D13 STMP3XXX_PINID(3, 13) | ||
138 | #define PINID_EMI_D14 STMP3XXX_PINID(3, 14) | ||
139 | #define PINID_EMI_D15 STMP3XXX_PINID(3, 15) | ||
140 | #define PINID_EMI_DQS0 STMP3XXX_PINID(3, 16) | ||
141 | #define PINID_EMI_DQS1 STMP3XXX_PINID(3, 17) | ||
142 | #define PINID_EMI_DQM0 STMP3XXX_PINID(3, 18) | ||
143 | #define PINID_EMI_DQM1 STMP3XXX_PINID(3, 19) | ||
144 | #define PINID_EMI_CLK STMP3XXX_PINID(3, 20) | ||
145 | #define PINID_EMI_CLKN STMP3XXX_PINID(3, 21) | ||
146 | |||
147 | #endif /* __ASM_ARCH_PINS_H */ | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-apbh.h b/arch/arm/mach-stmp37xx/include/mach/regs-apbh.h new file mode 100644 index 000000000000..a323aa9a21f2 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-apbh.h | |||
@@ -0,0 +1,97 @@ | |||
1 | /* | ||
2 | * stmp37xx: APBH register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #ifndef _MACH_REGS_APBH | ||
22 | #define _MACH_REGS_APBH | ||
23 | |||
24 | #define REGS_APBH_BASE (STMP3XXX_REGS_BASE + 0x4000) | ||
25 | |||
26 | #define HW_APBH_CTRL0 0x0 | ||
27 | #define BM_APBH_CTRL0_RESET_CHANNEL 0x00FF0000 | ||
28 | #define BP_APBH_CTRL0_RESET_CHANNEL 16 | ||
29 | #define BM_APBH_CTRL0_CLKGATE 0x40000000 | ||
30 | #define BM_APBH_CTRL0_SFTRST 0x80000000 | ||
31 | |||
32 | #define HW_APBH_CTRL1 0x10 | ||
33 | #define BM_APBH_CTRL1_CH0_CMDCMPLT_IRQ 0x00000001 | ||
34 | #define BP_APBH_CTRL1_CH0_CMDCMPLT_IRQ 0 | ||
35 | |||
36 | #define HW_APBH_DEVSEL 0x20 | ||
37 | |||
38 | #define HW_APBH_CH0_NXTCMDAR (0x50 + 0 * 0x70) | ||
39 | #define HW_APBH_CH1_NXTCMDAR (0x50 + 1 * 0x70) | ||
40 | #define HW_APBH_CH2_NXTCMDAR (0x50 + 2 * 0x70) | ||
41 | #define HW_APBH_CH3_NXTCMDAR (0x50 + 3 * 0x70) | ||
42 | #define HW_APBH_CH4_NXTCMDAR (0x50 + 4 * 0x70) | ||
43 | #define HW_APBH_CH5_NXTCMDAR (0x50 + 5 * 0x70) | ||
44 | #define HW_APBH_CH6_NXTCMDAR (0x50 + 6 * 0x70) | ||
45 | #define HW_APBH_CH7_NXTCMDAR (0x50 + 7 * 0x70) | ||
46 | #define HW_APBH_CH8_NXTCMDAR (0x50 + 8 * 0x70) | ||
47 | #define HW_APBH_CH9_NXTCMDAR (0x50 + 9 * 0x70) | ||
48 | #define HW_APBH_CH10_NXTCMDAR (0x50 + 10 * 0x70) | ||
49 | #define HW_APBH_CH11_NXTCMDAR (0x50 + 11 * 0x70) | ||
50 | #define HW_APBH_CH12_NXTCMDAR (0x50 + 12 * 0x70) | ||
51 | #define HW_APBH_CH13_NXTCMDAR (0x50 + 13 * 0x70) | ||
52 | #define HW_APBH_CH14_NXTCMDAR (0x50 + 14 * 0x70) | ||
53 | #define HW_APBH_CH15_NXTCMDAR (0x50 + 15 * 0x70) | ||
54 | |||
55 | #define HW_APBH_CHn_NXTCMDAR 0x50 | ||
56 | |||
57 | #define BM_APBH_CHn_CMD_MODE 0x00000003 | ||
58 | #define BP_APBH_CHn_CMD_MODE 0x00000001 | ||
59 | #define BV_APBH_CHn_CMD_MODE_NOOP 0 | ||
60 | #define BV_APBH_CHn_CMD_MODE_WRITE 1 | ||
61 | #define BV_APBH_CHn_CMD_MODE_READ 2 | ||
62 | #define BV_APBH_CHn_CMD_MODE_SENSE 3 | ||
63 | #define BM_APBH_CHn_CMD_CHAIN 0x00000004 | ||
64 | #define BM_APBH_CHn_CMD_IRQONCMPLT 0x00000008 | ||
65 | #define BM_APBH_CHn_CMD_NANDLOCK 0x00000010 | ||
66 | #define BM_APBH_CHn_CMD_NANDWAIT4READY 0x00000020 | ||
67 | #define BM_APBH_CHn_CMD_SEMAPHORE 0x00000040 | ||
68 | #define BM_APBH_CHn_CMD_WAIT4ENDCMD 0x00000080 | ||
69 | #define BM_APBH_CHn_CMD_CMDWORDS 0x0000F000 | ||
70 | #define BP_APBH_CHn_CMD_CMDWORDS 12 | ||
71 | #define BM_APBH_CHn_CMD_XFER_COUNT 0xFFFF0000 | ||
72 | #define BP_APBH_CHn_CMD_XFER_COUNT 16 | ||
73 | |||
74 | #define HW_APBH_CH0_SEMA (0x80 + 0 * 0x70) | ||
75 | #define HW_APBH_CH1_SEMA (0x80 + 1 * 0x70) | ||
76 | #define HW_APBH_CH2_SEMA (0x80 + 2 * 0x70) | ||
77 | #define HW_APBH_CH3_SEMA (0x80 + 3 * 0x70) | ||
78 | #define HW_APBH_CH4_SEMA (0x80 + 4 * 0x70) | ||
79 | #define HW_APBH_CH5_SEMA (0x80 + 5 * 0x70) | ||
80 | #define HW_APBH_CH6_SEMA (0x80 + 6 * 0x70) | ||
81 | #define HW_APBH_CH7_SEMA (0x80 + 7 * 0x70) | ||
82 | #define HW_APBH_CH8_SEMA (0x80 + 8 * 0x70) | ||
83 | #define HW_APBH_CH9_SEMA (0x80 + 9 * 0x70) | ||
84 | #define HW_APBH_CH10_SEMA (0x80 + 10 * 0x70) | ||
85 | #define HW_APBH_CH11_SEMA (0x80 + 11 * 0x70) | ||
86 | #define HW_APBH_CH12_SEMA (0x80 + 12 * 0x70) | ||
87 | #define HW_APBH_CH13_SEMA (0x80 + 13 * 0x70) | ||
88 | #define HW_APBH_CH14_SEMA (0x80 + 14 * 0x70) | ||
89 | #define HW_APBH_CH15_SEMA (0x80 + 15 * 0x70) | ||
90 | |||
91 | #define HW_APBH_CHn_SEMA 0x80 | ||
92 | #define BM_APBH_CHn_SEMA_INCREMENT_SEMA 0x000000FF | ||
93 | #define BP_APBH_CHn_SEMA_INCREMENT_SEMA 0 | ||
94 | #define BM_APBH_CHn_SEMA_PHORE 0x00FF0000 | ||
95 | #define BP_APBH_CHn_SEMA_PHORE 16 | ||
96 | |||
97 | #endif | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-apbx.h b/arch/arm/mach-stmp37xx/include/mach/regs-apbx.h new file mode 100644 index 000000000000..6d080cd5b702 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-apbx.h | |||
@@ -0,0 +1,113 @@ | |||
1 | /* | ||
2 | * stmp37xx: APBX register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #ifndef _MACH_REGS_APBX | ||
22 | #define _MACH_REGS_APBX | ||
23 | |||
24 | #define REGS_APBX_BASE (STMP3XXX_REGS_BASE + 0x24000) | ||
25 | |||
26 | #define HW_APBX_CTRL0 0x0 | ||
27 | #define BM_APBX_CTRL0_RESET_CHANNEL 0x00FF0000 | ||
28 | #define BP_APBX_CTRL0_RESET_CHANNEL 16 | ||
29 | #define BM_APBX_CTRL0_CLKGATE 0x40000000 | ||
30 | #define BM_APBX_CTRL0_SFTRST 0x80000000 | ||
31 | |||
32 | #define HW_APBX_CTRL1 0x10 | ||
33 | |||
34 | #define HW_APBX_DEVSEL 0x20 | ||
35 | |||
36 | #define HW_APBX_CH0_NXTCMDAR (0x50 + 0 * 0x70) | ||
37 | #define HW_APBX_CH1_NXTCMDAR (0x50 + 1 * 0x70) | ||
38 | #define HW_APBX_CH2_NXTCMDAR (0x50 + 2 * 0x70) | ||
39 | #define HW_APBX_CH3_NXTCMDAR (0x50 + 3 * 0x70) | ||
40 | #define HW_APBX_CH4_NXTCMDAR (0x50 + 4 * 0x70) | ||
41 | #define HW_APBX_CH5_NXTCMDAR (0x50 + 5 * 0x70) | ||
42 | #define HW_APBX_CH6_NXTCMDAR (0x50 + 6 * 0x70) | ||
43 | #define HW_APBX_CH7_NXTCMDAR (0x50 + 7 * 0x70) | ||
44 | #define HW_APBX_CH8_NXTCMDAR (0x50 + 8 * 0x70) | ||
45 | #define HW_APBX_CH9_NXTCMDAR (0x50 + 9 * 0x70) | ||
46 | #define HW_APBX_CH10_NXTCMDAR (0x50 + 10 * 0x70) | ||
47 | #define HW_APBX_CH11_NXTCMDAR (0x50 + 11 * 0x70) | ||
48 | #define HW_APBX_CH12_NXTCMDAR (0x50 + 12 * 0x70) | ||
49 | #define HW_APBX_CH13_NXTCMDAR (0x50 + 13 * 0x70) | ||
50 | #define HW_APBX_CH14_NXTCMDAR (0x50 + 14 * 0x70) | ||
51 | #define HW_APBX_CH15_NXTCMDAR (0x50 + 15 * 0x70) | ||
52 | |||
53 | #define HW_APBX_CHn_NXTCMDAR 0x50 | ||
54 | #define BM_APBX_CHn_CMD_MODE 0x00000003 | ||
55 | #define BP_APBX_CHn_CMD_MODE 0x00000001 | ||
56 | #define BV_APBX_CHn_CMD_MODE_NOOP 0 | ||
57 | #define BV_APBX_CHn_CMD_MODE_WRITE 1 | ||
58 | #define BV_APBX_CHn_CMD_MODE_READ 2 | ||
59 | #define BV_APBX_CHn_CMD_MODE_SENSE 3 | ||
60 | #define BM_APBX_CHn_CMD_COMMAND 0x00000003 | ||
61 | #define BP_APBX_CHn_CMD_COMMAND 0 | ||
62 | #define BM_APBX_CHn_CMD_CHAIN 0x00000004 | ||
63 | #define BM_APBX_CHn_CMD_IRQONCMPLT 0x00000008 | ||
64 | #define BM_APBX_CHn_CMD_SEMAPHORE 0x00000040 | ||
65 | #define BM_APBX_CHn_CMD_WAIT4ENDCMD 0x00000080 | ||
66 | #define BM_APBX_CHn_CMD_CMDWORDS 0x0000F000 | ||
67 | #define BP_APBX_CHn_CMD_CMDWORDS 12 | ||
68 | #define BM_APBX_CHn_CMD_XFER_COUNT 0xFFFF0000 | ||
69 | #define BP_APBX_CHn_CMD_XFER_COUNT 16 | ||
70 | |||
71 | #define HW_APBX_CH0_BAR (0x70 + 0 * 0x70) | ||
72 | #define HW_APBX_CH1_BAR (0x70 + 1 * 0x70) | ||
73 | #define HW_APBX_CH2_BAR (0x70 + 2 * 0x70) | ||
74 | #define HW_APBX_CH3_BAR (0x70 + 3 * 0x70) | ||
75 | #define HW_APBX_CH4_BAR (0x70 + 4 * 0x70) | ||
76 | #define HW_APBX_CH5_BAR (0x70 + 5 * 0x70) | ||
77 | #define HW_APBX_CH6_BAR (0x70 + 6 * 0x70) | ||
78 | #define HW_APBX_CH7_BAR (0x70 + 7 * 0x70) | ||
79 | #define HW_APBX_CH8_BAR (0x70 + 8 * 0x70) | ||
80 | #define HW_APBX_CH9_BAR (0x70 + 9 * 0x70) | ||
81 | #define HW_APBX_CH10_BAR (0x70 + 10 * 0x70) | ||
82 | #define HW_APBX_CH11_BAR (0x70 + 11 * 0x70) | ||
83 | #define HW_APBX_CH12_BAR (0x70 + 12 * 0x70) | ||
84 | #define HW_APBX_CH13_BAR (0x70 + 13 * 0x70) | ||
85 | #define HW_APBX_CH14_BAR (0x70 + 14 * 0x70) | ||
86 | #define HW_APBX_CH15_BAR (0x70 + 15 * 0x70) | ||
87 | |||
88 | #define HW_APBX_CHn_BAR 0x70 | ||
89 | |||
90 | #define HW_APBX_CH0_SEMA (0x80 + 0 * 0x70) | ||
91 | #define HW_APBX_CH1_SEMA (0x80 + 1 * 0x70) | ||
92 | #define HW_APBX_CH2_SEMA (0x80 + 2 * 0x70) | ||
93 | #define HW_APBX_CH3_SEMA (0x80 + 3 * 0x70) | ||
94 | #define HW_APBX_CH4_SEMA (0x80 + 4 * 0x70) | ||
95 | #define HW_APBX_CH5_SEMA (0x80 + 5 * 0x70) | ||
96 | #define HW_APBX_CH6_SEMA (0x80 + 6 * 0x70) | ||
97 | #define HW_APBX_CH7_SEMA (0x80 + 7 * 0x70) | ||
98 | #define HW_APBX_CH8_SEMA (0x80 + 8 * 0x70) | ||
99 | #define HW_APBX_CH9_SEMA (0x80 + 9 * 0x70) | ||
100 | #define HW_APBX_CH10_SEMA (0x80 + 10 * 0x70) | ||
101 | #define HW_APBX_CH11_SEMA (0x80 + 11 * 0x70) | ||
102 | #define HW_APBX_CH12_SEMA (0x80 + 12 * 0x70) | ||
103 | #define HW_APBX_CH13_SEMA (0x80 + 13 * 0x70) | ||
104 | #define HW_APBX_CH14_SEMA (0x80 + 14 * 0x70) | ||
105 | #define HW_APBX_CH15_SEMA (0x80 + 15 * 0x70) | ||
106 | |||
107 | #define HW_APBX_CHn_SEMA 0x80 | ||
108 | #define BM_APBX_CHn_SEMA_INCREMENT_SEMA 0x000000FF | ||
109 | #define BP_APBX_CHn_SEMA_INCREMENT_SEMA 0 | ||
110 | #define BM_APBX_CHn_SEMA_PHORE 0x00FF0000 | ||
111 | #define BP_APBX_CHn_SEMA_PHORE 16 | ||
112 | |||
113 | #endif | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-audioin.h b/arch/arm/mach-stmp37xx/include/mach/regs-audioin.h new file mode 100644 index 000000000000..3b511f947a53 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-audioin.h | |||
@@ -0,0 +1,61 @@ | |||
1 | /* | ||
2 | * stmp37xx: AUDIOIN register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_AUDIOIN_BASE (STMP3XXX_REGS_BASE + 0x4C000) | ||
22 | |||
23 | #define HW_AUDIOIN_CTRL 0x0 | ||
24 | #define BM_AUDIOIN_CTRL_RUN 0x00000001 | ||
25 | #define BP_AUDIOIN_CTRL_RUN 0 | ||
26 | #define BM_AUDIOIN_CTRL_FIFO_ERROR_IRQ_EN 0x00000002 | ||
27 | #define BM_AUDIOIN_CTRL_FIFO_OVERFLOW_IRQ 0x00000004 | ||
28 | #define BM_AUDIOIN_CTRL_FIFO_UNDERFLOW_IRQ 0x00000008 | ||
29 | #define BM_AUDIOIN_CTRL_WORD_LENGTH 0x00000020 | ||
30 | #define BM_AUDIOIN_CTRL_CLKGATE 0x40000000 | ||
31 | #define BM_AUDIOIN_CTRL_SFTRST 0x80000000 | ||
32 | |||
33 | #define HW_AUDIOIN_STAT 0x10 | ||
34 | |||
35 | #define HW_AUDIOIN_ADCSRR 0x20 | ||
36 | |||
37 | #define HW_AUDIOIN_ADCVOLUME 0x30 | ||
38 | #define BM_AUDIOIN_ADCVOLUME_VOLUME_RIGHT 0x000000FF | ||
39 | #define BP_AUDIOIN_ADCVOLUME_VOLUME_RIGHT 0 | ||
40 | #define BM_AUDIOIN_ADCVOLUME_VOLUME_LEFT 0x00FF0000 | ||
41 | #define BP_AUDIOIN_ADCVOLUME_VOLUME_LEFT 16 | ||
42 | |||
43 | #define HW_AUDIOIN_ADCDEBUG 0x40 | ||
44 | |||
45 | #define HW_AUDIOIN_ADCVOL 0x50 | ||
46 | #define BM_AUDIOIN_ADCVOL_GAIN_RIGHT 0x0000000F | ||
47 | #define BP_AUDIOIN_ADCVOL_GAIN_RIGHT 0 | ||
48 | #define BM_AUDIOIN_ADCVOL_SELECT_RIGHT 0x00000030 | ||
49 | #define BP_AUDIOIN_ADCVOL_SELECT_RIGHT 4 | ||
50 | #define BM_AUDIOIN_ADCVOL_GAIN_LEFT 0x00000F00 | ||
51 | #define BP_AUDIOIN_ADCVOL_GAIN_LEFT 8 | ||
52 | #define BM_AUDIOIN_ADCVOL_SELECT_LEFT 0x00003000 | ||
53 | #define BP_AUDIOIN_ADCVOL_SELECT_LEFT 12 | ||
54 | #define BM_AUDIOIN_ADCVOL_MUTE 0x01000000 | ||
55 | |||
56 | #define HW_AUDIOIN_MICLINE 0x60 | ||
57 | |||
58 | #define HW_AUDIOIN_ANACLKCTRL 0x70 | ||
59 | #define BM_AUDIOIN_ANACLKCTRL_CLKGATE 0x80000000 | ||
60 | |||
61 | #define HW_AUDIOIN_DATA 0x80 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-audioout.h b/arch/arm/mach-stmp37xx/include/mach/regs-audioout.h new file mode 100644 index 000000000000..ca1942b8a3e9 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-audioout.h | |||
@@ -0,0 +1,111 @@ | |||
1 | /* | ||
2 | * stmp37xx: AUDIOOUT register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_AUDIOOUT_BASE (STMP3XXX_REGS_BASE + 0x48000) | ||
22 | |||
23 | #define HW_AUDIOOUT_CTRL 0x0 | ||
24 | #define BM_AUDIOOUT_CTRL_RUN 0x00000001 | ||
25 | #define BP_AUDIOOUT_CTRL_RUN 0 | ||
26 | #define BM_AUDIOOUT_CTRL_FIFO_ERROR_IRQ_EN 0x00000002 | ||
27 | #define BM_AUDIOOUT_CTRL_FIFO_OVERFLOW_IRQ 0x00000004 | ||
28 | #define BM_AUDIOOUT_CTRL_FIFO_UNDERFLOW_IRQ 0x00000008 | ||
29 | #define BM_AUDIOOUT_CTRL_WORD_LENGTH 0x00000040 | ||
30 | #define BM_AUDIOOUT_CTRL_CLKGATE 0x40000000 | ||
31 | #define BM_AUDIOOUT_CTRL_SFTRST 0x80000000 | ||
32 | |||
33 | #define HW_AUDIOOUT_STAT 0x10 | ||
34 | |||
35 | #define HW_AUDIOOUT_DACSRR 0x20 | ||
36 | #define BM_AUDIOOUT_DACSRR_SRC_FRAC 0x00001FFF | ||
37 | #define BP_AUDIOOUT_DACSRR_SRC_FRAC 0 | ||
38 | #define BM_AUDIOOUT_DACSRR_SRC_INT 0x001F0000 | ||
39 | #define BP_AUDIOOUT_DACSRR_SRC_INT 16 | ||
40 | #define BM_AUDIOOUT_DACSRR_SRC_HOLD 0x07000000 | ||
41 | #define BP_AUDIOOUT_DACSRR_SRC_HOLD 24 | ||
42 | #define BM_AUDIOOUT_DACSRR_BASEMULT 0x70000000 | ||
43 | #define BP_AUDIOOUT_DACSRR_BASEMULT 28 | ||
44 | |||
45 | #define HW_AUDIOOUT_DACVOLUME 0x30 | ||
46 | #define BM_AUDIOOUT_DACVOLUME_MUTE_RIGHT 0x00000100 | ||
47 | #define BM_AUDIOOUT_DACVOLUME_MUTE_LEFT 0x01000000 | ||
48 | #define BM_AUDIOOUT_DACVOLUME_EN_ZCD 0x02000000 | ||
49 | |||
50 | #define HW_AUDIOOUT_DACDEBUG 0x40 | ||
51 | |||
52 | #define HW_AUDIOOUT_HPVOL 0x50 | ||
53 | #define BM_AUDIOOUT_HPVOL_MUTE 0x01000000 | ||
54 | #define BM_AUDIOOUT_HPVOL_EN_MSTR_ZCD 0x02000000 | ||
55 | |||
56 | #define HW_AUDIOOUT_PWRDN 0x70 | ||
57 | #define BM_AUDIOOUT_PWRDN_HEADPHONE 0x00000001 | ||
58 | #define BP_AUDIOOUT_PWRDN_HEADPHONE 0 | ||
59 | #define BM_AUDIOOUT_PWRDN_CAPLESS 0x00000010 | ||
60 | #define BM_AUDIOOUT_PWRDN_ADC 0x00000100 | ||
61 | #define BM_AUDIOOUT_PWRDN_DAC 0x00001000 | ||
62 | #define BM_AUDIOOUT_PWRDN_RIGHT_ADC 0x00010000 | ||
63 | #define BM_AUDIOOUT_PWRDN_LINEOUT 0x01000000 | ||
64 | |||
65 | #define HW_AUDIOOUT_REFCTRL 0x80 | ||
66 | #define BM_AUDIOOUT_REFCTRL_VAG_VAL 0x000000F0 | ||
67 | #define BP_AUDIOOUT_REFCTRL_VAG_VAL 4 | ||
68 | #define BM_AUDIOOUT_REFCTRL_ADC_REFVAL 0x00000F00 | ||
69 | #define BP_AUDIOOUT_REFCTRL_ADC_REFVAL 8 | ||
70 | #define BM_AUDIOOUT_REFCTRL_ADJ_VAG 0x00001000 | ||
71 | #define BM_AUDIOOUT_REFCTRL_ADJ_ADC 0x00002000 | ||
72 | #define BM_AUDIOOUT_REFCTRL_BIAS_CTRL 0x00030000 | ||
73 | #define BP_AUDIOOUT_REFCTRL_BIAS_CTRL 16 | ||
74 | #define BM_AUDIOOUT_REFCTRL_LOW_PWR 0x00080000 | ||
75 | #define BM_AUDIOOUT_REFCTRL_VBG_ADJ 0x00700000 | ||
76 | #define BP_AUDIOOUT_REFCTRL_VBG_ADJ 20 | ||
77 | #define BM_AUDIOOUT_REFCTRL_XTAL_BGR_BIAS 0x01000000 | ||
78 | #define BM_AUDIOOUT_REFCTRL_RAISE_REF 0x02000000 | ||
79 | |||
80 | #define HW_AUDIOOUT_ANACTRL 0x90 | ||
81 | #define BM_AUDIOOUT_ANACTRL_HP_CLASSAB 0x00000010 | ||
82 | #define BM_AUDIOOUT_ANACTRL_HP_HOLD_GND 0x00000020 | ||
83 | |||
84 | #define HW_AUDIOOUT_TEST 0xA0 | ||
85 | #define BM_AUDIOOUT_TEST_HP_I1_ADJ 0x00C00000 | ||
86 | #define BP_AUDIOOUT_TEST_HP_I1_ADJ 22 | ||
87 | |||
88 | #define HW_AUDIOOUT_BISTCTRL 0xB0 | ||
89 | |||
90 | #define HW_AUDIOOUT_BISTSTAT0 0xC0 | ||
91 | |||
92 | #define HW_AUDIOOUT_BISTSTAT1 0xD0 | ||
93 | |||
94 | #define HW_AUDIOOUT_ANACLKCTRL 0xE0 | ||
95 | #define BM_AUDIOOUT_ANACLKCTRL_CLKGATE 0x80000000 | ||
96 | |||
97 | #define HW_AUDIOOUT_DATA 0xF0 | ||
98 | |||
99 | #define HW_AUDIOOUT_LINEOUTCTRL 0x100 | ||
100 | #define BM_AUDIOOUT_LINEOUTCTRL_VOL_RIGHT 0x0000001F | ||
101 | #define BP_AUDIOOUT_LINEOUTCTRL_VOL_RIGHT 0 | ||
102 | #define BM_AUDIOOUT_LINEOUTCTRL_VOL_LEFT 0x00001F00 | ||
103 | #define BP_AUDIOOUT_LINEOUTCTRL_VOL_LEFT 8 | ||
104 | #define BM_AUDIOOUT_LINEOUTCTRL_CHARGE_CAP 0x00007000 | ||
105 | #define BP_AUDIOOUT_LINEOUTCTRL_CHARGE_CAP 12 | ||
106 | #define BM_AUDIOOUT_LINEOUTCTRL_VAG_CTRL 0x00F00000 | ||
107 | #define BP_AUDIOOUT_LINEOUTCTRL_VAG_CTRL 20 | ||
108 | #define BM_AUDIOOUT_LINEOUTCTRL_MUTE 0x01000000 | ||
109 | #define BM_AUDIOOUT_LINEOUTCTRL_EN_ZCD 0x02000000 | ||
110 | |||
111 | #define HW_AUDIOOUT_VERSION 0x200 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-clkctrl.h b/arch/arm/mach-stmp37xx/include/mach/regs-clkctrl.h new file mode 100644 index 000000000000..47f5c92fdaf6 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-clkctrl.h | |||
@@ -0,0 +1,72 @@ | |||
1 | /* | ||
2 | * stmp37xx: CLKCTRL register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #ifndef _MACH_REGS_CLKCTRL | ||
22 | #define _MACH_REGS_CLKCTRL | ||
23 | |||
24 | #define REGS_CLKCTRL_BASE (STMP3XXX_REGS_BASE + 0x40000) | ||
25 | |||
26 | #define HW_CLKCTRL_PLLCTRL0 0x0 | ||
27 | #define BM_CLKCTRL_PLLCTRL0_EN_USB_CLKS 0x00040000 | ||
28 | |||
29 | #define HW_CLKCTRL_CPU 0x20 | ||
30 | #define BM_CLKCTRL_CPU_DIV_CPU 0x0000003F | ||
31 | #define BP_CLKCTRL_CPU_DIV_CPU 0 | ||
32 | |||
33 | #define HW_CLKCTRL_HBUS 0x30 | ||
34 | #define BM_CLKCTRL_HBUS_DIV 0x0000001F | ||
35 | #define BP_CLKCTRL_HBUS_DIV 0 | ||
36 | |||
37 | #define HW_CLKCTRL_XBUS 0x40 | ||
38 | |||
39 | #define HW_CLKCTRL_XTAL 0x50 | ||
40 | |||
41 | #define HW_CLKCTRL_PIX 0x60 | ||
42 | #define BM_CLKCTRL_PIX_DIV 0x00007FFF | ||
43 | #define BP_CLKCTRL_PIX_DIV 0 | ||
44 | #define BM_CLKCTRL_PIX_CLKGATE 0x80000000 | ||
45 | |||
46 | #define HW_CLKCTRL_SSP 0x70 | ||
47 | |||
48 | #define HW_CLKCTRL_GPMI 0x80 | ||
49 | |||
50 | #define HW_CLKCTRL_SPDIF 0x90 | ||
51 | |||
52 | #define HW_CLKCTRL_EMI 0xA0 | ||
53 | |||
54 | #define HW_CLKCTRL_IR 0xB0 | ||
55 | |||
56 | #define HW_CLKCTRL_SAIF 0xC0 | ||
57 | |||
58 | #define HW_CLKCTRL_FRAC 0xD0 | ||
59 | #define BM_CLKCTRL_FRAC_EMIFRAC 0x00003F00 | ||
60 | #define BP_CLKCTRL_FRAC_EMIFRAC 8 | ||
61 | #define BM_CLKCTRL_FRAC_PIXFRAC 0x003F0000 | ||
62 | #define BP_CLKCTRL_FRAC_PIXFRAC 16 | ||
63 | #define BM_CLKCTRL_FRAC_CLKGATEPIX 0x00800000 | ||
64 | |||
65 | #define HW_CLKCTRL_CLKSEQ 0xE0 | ||
66 | #define BM_CLKCTRL_CLKSEQ_BYPASS_PIX 0x00000002 | ||
67 | |||
68 | #define HW_CLKCTRL_RESET 0xF0 | ||
69 | #define BM_CLKCTRL_RESET_DIG 0x00000001 | ||
70 | #define BP_CLKCTRL_RESET_DIG 0 | ||
71 | |||
72 | #endif | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-digctl.h b/arch/arm/mach-stmp37xx/include/mach/regs-digctl.h new file mode 100644 index 000000000000..ba1bbe265c20 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-digctl.h | |||
@@ -0,0 +1,24 @@ | |||
1 | /* | ||
2 | * stmp37xx: DIGCTL register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_DIGCTL_BASE (STMP3XXX_REGS_BASE + 0x1C000) | ||
22 | |||
23 | #define HW_DIGCTL_CTRL 0x0 | ||
24 | #define BM_DIGCTL_CTRL_USB_CLKGATE 0x00000004 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-ecc8.h b/arch/arm/mach-stmp37xx/include/mach/regs-ecc8.h new file mode 100644 index 000000000000..3b6d990a3af5 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-ecc8.h | |||
@@ -0,0 +1,37 @@ | |||
1 | /* | ||
2 | * stmp37xx: ECC8 register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_ECC8_BASE (STMP3XXX_REGS_BASE + 0x8000) | ||
22 | |||
23 | #define HW_ECC8_CTRL 0x0 | ||
24 | #define BM_ECC8_CTRL_COMPLETE_IRQ 0x00000001 | ||
25 | #define BP_ECC8_CTRL_COMPLETE_IRQ 0 | ||
26 | #define BM_ECC8_CTRL_COMPLETE_IRQ_EN 0x00000100 | ||
27 | #define BM_ECC8_CTRL_AHBM_SFTRST 0x20000000 | ||
28 | |||
29 | #define HW_ECC8_STATUS0 0x10 | ||
30 | #define BM_ECC8_STATUS0_UNCORRECTABLE 0x00000004 | ||
31 | #define BM_ECC8_STATUS0_CORRECTED 0x00000008 | ||
32 | #define BM_ECC8_STATUS0_STATUS_AUX 0x00000F00 | ||
33 | #define BP_ECC8_STATUS0_STATUS_AUX 8 | ||
34 | #define BM_ECC8_STATUS0_COMPLETED_CE 0x000F0000 | ||
35 | #define BP_ECC8_STATUS0_COMPLETED_CE 16 | ||
36 | |||
37 | #define HW_ECC8_STATUS1 0x20 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-gpmi.h b/arch/arm/mach-stmp37xx/include/mach/regs-gpmi.h new file mode 100644 index 000000000000..f2b304f54490 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-gpmi.h | |||
@@ -0,0 +1,63 @@ | |||
1 | /* | ||
2 | * stmp37xx: GPMI register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_GPMI_BASE (STMP3XXX_REGS_BASE + 0xC000) | ||
22 | #define REGS_GPMI_PHYS 0x8000C000 | ||
23 | #define REGS_GPMI_SIZE 0x2000 | ||
24 | |||
25 | #define HW_GPMI_CTRL0 0x0 | ||
26 | #define BM_GPMI_CTRL0_XFER_COUNT 0x0000FFFF | ||
27 | #define BP_GPMI_CTRL0_XFER_COUNT 0 | ||
28 | #define BM_GPMI_CTRL0_CS 0x00300000 | ||
29 | #define BP_GPMI_CTRL0_CS 20 | ||
30 | #define BM_GPMI_CTRL0_LOCK_CS 0x00400000 | ||
31 | #define BM_GPMI_CTRL0_WORD_LENGTH 0x00800000 | ||
32 | #define BM_GPMI_CTRL0_COMMAND_MODE 0x03000000 | ||
33 | #define BP_GPMI_CTRL0_COMMAND_MODE 24 | ||
34 | #define BV_GPMI_CTRL0_COMMAND_MODE__WRITE 0x0 | ||
35 | #define BV_GPMI_CTRL0_COMMAND_MODE__READ 0x1 | ||
36 | #define BV_GPMI_CTRL0_COMMAND_MODE__READ_AND_COMPARE 0x2 | ||
37 | #define BV_GPMI_CTRL0_COMMAND_MODE__WAIT_FOR_READY 0x3 | ||
38 | #define BM_GPMI_CTRL0_RUN 0x20000000 | ||
39 | #define BM_GPMI_CTRL0_CLKGATE 0x40000000 | ||
40 | #define BM_GPMI_CTRL0_SFTRST 0x80000000 | ||
41 | #define BM_GPMI_ECCCTRL_ENABLE_ECC 0x00001000 | ||
42 | #define BM_GPMI_ECCCTRL_ECC_CMD 0x00006000 | ||
43 | #define BP_GPMI_ECCCTRL_ECC_CMD 13 | ||
44 | |||
45 | #define HW_GPMI_CTRL1 0x60 | ||
46 | #define BM_GPMI_CTRL1_GPMI_MODE 0x00000003 | ||
47 | #define BP_GPMI_CTRL1_GPMI_MODE 0 | ||
48 | #define BM_GPMI_CTRL1_ATA_IRQRDY_POLARITY 0x00000004 | ||
49 | #define BM_GPMI_CTRL1_DEV_RESET 0x00000008 | ||
50 | #define BM_GPMI_CTRL1_TIMEOUT_IRQ 0x00000200 | ||
51 | #define BM_GPMI_CTRL1_DEV_IRQ 0x00000400 | ||
52 | #define BM_GPMI_CTRL1_DSAMPLE_TIME 0x00007000 | ||
53 | #define BP_GPMI_CTRL1_DSAMPLE_TIME 12 | ||
54 | |||
55 | #define HW_GPMI_TIMING0 0x70 | ||
56 | #define BM_GPMI_TIMING0_DATA_SETUP 0x000000FF | ||
57 | #define BP_GPMI_TIMING0_DATA_SETUP 0 | ||
58 | #define BM_GPMI_TIMING0_DATA_HOLD 0x0000FF00 | ||
59 | #define BP_GPMI_TIMING0_DATA_HOLD 8 | ||
60 | |||
61 | #define HW_GPMI_TIMING1 0x80 | ||
62 | #define BM_GPMI_TIMING1_DEVICE_BUSY_TIMEOUT 0xFFFF0000 | ||
63 | #define BP_GPMI_TIMING1_DEVICE_BUSY_TIMEOUT 16 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-i2c.h b/arch/arm/mach-stmp37xx/include/mach/regs-i2c.h new file mode 100644 index 000000000000..35882a9b8bc5 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-i2c.h | |||
@@ -0,0 +1,55 @@ | |||
1 | /* | ||
2 | * stmp37xx: I2C register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_I2C_BASE (STMP3XXX_REGS_BASE + 0x58000) | ||
22 | #define REGS_I2C_PHYS 0x80058000 | ||
23 | #define REGS_I2C_SIZE 0x2000 | ||
24 | |||
25 | #define HW_I2C_CTRL0 0x0 | ||
26 | #define BM_I2C_CTRL0_XFER_COUNT 0x0000FFFF | ||
27 | #define BP_I2C_CTRL0_XFER_COUNT 0 | ||
28 | #define BM_I2C_CTRL0_DIRECTION 0x00010000 | ||
29 | #define BM_I2C_CTRL0_MASTER_MODE 0x00020000 | ||
30 | #define BM_I2C_CTRL0_PRE_SEND_START 0x00080000 | ||
31 | #define BM_I2C_CTRL0_POST_SEND_STOP 0x00100000 | ||
32 | #define BM_I2C_CTRL0_RETAIN_CLOCK 0x00200000 | ||
33 | #define BM_I2C_CTRL0_SEND_NAK_ON_LAST 0x02000000 | ||
34 | #define BM_I2C_CTRL0_CLKGATE 0x40000000 | ||
35 | #define BM_I2C_CTRL0_SFTRST 0x80000000 | ||
36 | |||
37 | #define HW_I2C_TIMING0 0x10 | ||
38 | |||
39 | #define HW_I2C_TIMING1 0x20 | ||
40 | |||
41 | #define HW_I2C_TIMING2 0x30 | ||
42 | |||
43 | #define HW_I2C_CTRL1 0x40 | ||
44 | #define BM_I2C_CTRL1_SLAVE_IRQ 0x00000001 | ||
45 | #define BP_I2C_CTRL1_SLAVE_IRQ 0 | ||
46 | #define BM_I2C_CTRL1_SLAVE_STOP_IRQ 0x00000002 | ||
47 | #define BM_I2C_CTRL1_MASTER_LOSS_IRQ 0x00000004 | ||
48 | #define BM_I2C_CTRL1_EARLY_TERM_IRQ 0x00000008 | ||
49 | #define BM_I2C_CTRL1_OVERSIZE_XFER_TERM_IRQ 0x00000010 | ||
50 | #define BM_I2C_CTRL1_NO_SLAVE_ACK_IRQ 0x00000020 | ||
51 | #define BM_I2C_CTRL1_DATA_ENGINE_CMPLT_IRQ 0x00000040 | ||
52 | #define BM_I2C_CTRL1_BUS_FREE_IRQ 0x00000080 | ||
53 | #define BM_I2C_CTRL1_CLR_GOT_A_NAK 0x10000000 | ||
54 | |||
55 | #define HW_I2C_VERSION 0x90 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-icoll.h b/arch/arm/mach-stmp37xx/include/mach/regs-icoll.h new file mode 100644 index 000000000000..3b7c92239e20 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-icoll.h | |||
@@ -0,0 +1,43 @@ | |||
1 | /* | ||
2 | * stmp37xx: ICOLL register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #ifndef _MACH_REGS_ICOLL | ||
22 | #define _MACH_REGS_ICOLL | ||
23 | |||
24 | #define REGS_ICOLL_BASE (STMP3XXX_REGS_BASE + 0x0) | ||
25 | |||
26 | #define HW_ICOLL_VECTOR 0x0 | ||
27 | |||
28 | #define HW_ICOLL_LEVELACK 0x10 | ||
29 | |||
30 | #define HW_ICOLL_CTRL 0x20 | ||
31 | #define BM_ICOLL_CTRL_CLKGATE 0x40000000 | ||
32 | #define BM_ICOLL_CTRL_SFTRST 0x80000000 | ||
33 | |||
34 | #define HW_ICOLL_STAT 0x30 | ||
35 | |||
36 | #define HW_ICOLL_PRIORITY0 (0x60 + 0 * 0x10) | ||
37 | #define HW_ICOLL_PRIORITY1 (0x60 + 1 * 0x10) | ||
38 | #define HW_ICOLL_PRIORITY2 (0x60 + 2 * 0x10) | ||
39 | #define HW_ICOLL_PRIORITY3 (0x60 + 3 * 0x10) | ||
40 | |||
41 | #define HW_ICOLL_PRIORITYn 0x60 | ||
42 | |||
43 | #endif | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-lcdif.h b/arch/arm/mach-stmp37xx/include/mach/regs-lcdif.h new file mode 100644 index 000000000000..72514e8b0737 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-lcdif.h | |||
@@ -0,0 +1,89 @@ | |||
1 | /* | ||
2 | * stmp37xx: LCDIF register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_LCDIF_BASE (STMP3XXX_REGS_BASE + 0x30000) | ||
22 | #define REGS_LCDIF_PHYS 0x80030000 | ||
23 | #define REGS_LCDIF_SIZE 0x2000 | ||
24 | |||
25 | #define HW_LCDIF_CTRL 0x0 | ||
26 | #define BM_LCDIF_CTRL_COUNT 0x0000FFFF | ||
27 | #define BP_LCDIF_CTRL_COUNT 0 | ||
28 | #define BM_LCDIF_CTRL_RUN 0x00010000 | ||
29 | #define BM_LCDIF_CTRL_WORD_LENGTH 0x00020000 | ||
30 | #define BM_LCDIF_CTRL_DATA_SELECT 0x00040000 | ||
31 | #define BM_LCDIF_CTRL_DOTCLK_MODE 0x00080000 | ||
32 | #define BM_LCDIF_CTRL_VSYNC_MODE 0x00100000 | ||
33 | #define BM_LCDIF_CTRL_DATA_SWIZZLE 0x00600000 | ||
34 | #define BP_LCDIF_CTRL_DATA_SWIZZLE 21 | ||
35 | #define BM_LCDIF_CTRL_BYPASS_COUNT 0x00800000 | ||
36 | #define BM_LCDIF_CTRL_SHIFT_NUM_BITS 0x06000000 | ||
37 | #define BP_LCDIF_CTRL_SHIFT_NUM_BITS 25 | ||
38 | #define BM_LCDIF_CTRL_DATA_SHIFT_DIR 0x08000000 | ||
39 | #define BM_LCDIF_CTRL_WAIT_FOR_VSYNC_EDGE 0x10000000 | ||
40 | #define BM_LCDIF_CTRL_CLKGATE 0x40000000 | ||
41 | #define BM_LCDIF_CTRL_SFTRST 0x80000000 | ||
42 | |||
43 | #define HW_LCDIF_CTRL1 0x10 | ||
44 | #define BM_LCDIF_CTRL1_RESET 0x00000001 | ||
45 | #define BP_LCDIF_CTRL1_RESET 0 | ||
46 | #define BM_LCDIF_CTRL1_MODE86 0x00000002 | ||
47 | #define BM_LCDIF_CTRL1_BUSY_ENABLE 0x00000004 | ||
48 | #define BM_LCDIF_CTRL1_VSYNC_EDGE_IRQ 0x00000100 | ||
49 | #define BM_LCDIF_CTRL1_CUR_FRAME_DONE_IRQ 0x00000200 | ||
50 | #define BM_LCDIF_CTRL1_UNDERFLOW_IRQ 0x00000400 | ||
51 | #define BM_LCDIF_CTRL1_OVERFLOW_IRQ 0x00000800 | ||
52 | #define BM_LCDIF_CTRL1_VSYNC_EDGE_IRQ_EN 0x00001000 | ||
53 | #define BM_LCDIF_CTRL1_BYTE_PACKING_FORMAT 0x000F0000 | ||
54 | #define BP_LCDIF_CTRL1_BYTE_PACKING_FORMAT 16 | ||
55 | |||
56 | #define HW_LCDIF_TIMING 0x20 | ||
57 | |||
58 | #define HW_LCDIF_VDCTRL0 0x30 | ||
59 | #define BM_LCDIF_VDCTRL0_VALID_DATA_CNT 0x000003FF | ||
60 | #define BP_LCDIF_VDCTRL0_VALID_DATA_CNT 0 | ||
61 | #define BM_LCDIF_VDCTRL0_VSYNC_PULSE_WIDTH_UNIT 0x00100000 | ||
62 | #define BM_LCDIF_VDCTRL0_VSYNC_PERIOD_UNIT 0x00200000 | ||
63 | #define BM_LCDIF_VDCTRL0_ENABLE_POL 0x01000000 | ||
64 | #define BM_LCDIF_VDCTRL0_DOTCLK_POL 0x02000000 | ||
65 | #define BM_LCDIF_VDCTRL0_HSYNC_POL 0x04000000 | ||
66 | #define BM_LCDIF_VDCTRL0_VSYNC_POL 0x08000000 | ||
67 | #define BM_LCDIF_VDCTRL0_ENABLE_PRESENT 0x10000000 | ||
68 | #define BM_LCDIF_VDCTRL0_VSYNC_OEB 0x20000000 | ||
69 | |||
70 | #define HW_LCDIF_VDCTRL1 0x40 | ||
71 | #define BM_LCDIF_VDCTRL1_VSYNC_PERIOD 0x000FFFFF | ||
72 | #define BP_LCDIF_VDCTRL1_VSYNC_PERIOD 0 | ||
73 | #define BM_LCDIF_VDCTRL1_VSYNC_PULSE_WIDTH 0xFFF00000 | ||
74 | #define BP_LCDIF_VDCTRL1_VSYNC_PULSE_WIDTH 20 | ||
75 | |||
76 | #define HW_LCDIF_VDCTRL2 0x50 | ||
77 | #define BM_LCDIF_VDCTRL2_VALID_DATA_CNT 0x000007FF | ||
78 | #define BP_LCDIF_VDCTRL2_VALID_DATA_CNT 0 | ||
79 | #define BM_LCDIF_VDCTRL2_HSYNC_PERIOD 0x007FF800 | ||
80 | #define BP_LCDIF_VDCTRL2_HSYNC_PERIOD 11 | ||
81 | #define BM_LCDIF_VDCTRL2_HSYNC_PULSE_WIDTH 0xFF800000 | ||
82 | #define BP_LCDIF_VDCTRL2_HSYNC_PULSE_WIDTH 23 | ||
83 | |||
84 | #define HW_LCDIF_VDCTRL3 0x60 | ||
85 | #define BM_LCDIF_VDCTRL3_VERTICAL_WAIT_CNT 0x000001FF | ||
86 | #define BP_LCDIF_VDCTRL3_VERTICAL_WAIT_CNT 0 | ||
87 | #define BM_LCDIF_VDCTRL3_HORIZONTAL_WAIT_CNT 0x00FFF000 | ||
88 | #define BP_LCDIF_VDCTRL3_HORIZONTAL_WAIT_CNT 12 | ||
89 | #define BM_LCDIF_VDCTRL3_SYNC_SIGNALS_ON 0x01000000 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-lradc.h b/arch/arm/mach-stmp37xx/include/mach/regs-lradc.h new file mode 100644 index 000000000000..cc7b4702d1cd --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-lradc.h | |||
@@ -0,0 +1,97 @@ | |||
1 | /* | ||
2 | * stmp37xx: LRADC register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_LRADC_BASE (STMP3XXX_REGS_BASE + 0x50000) | ||
22 | |||
23 | #define HW_LRADC_CTRL0 0x0 | ||
24 | #define BM_LRADC_CTRL0_SCHEDULE 0x000000FF | ||
25 | #define BP_LRADC_CTRL0_SCHEDULE 0 | ||
26 | #define BM_LRADC_CTRL0_XPLUS_ENABLE 0x00010000 | ||
27 | #define BM_LRADC_CTRL0_YPLUS_ENABLE 0x00020000 | ||
28 | #define BM_LRADC_CTRL0_XMINUS_ENABLE 0x00040000 | ||
29 | #define BM_LRADC_CTRL0_YMINUS_ENABLE 0x00080000 | ||
30 | #define BM_LRADC_CTRL0_TOUCH_DETECT_ENABLE 0x00100000 | ||
31 | #define BM_LRADC_CTRL0_ONCHIP_GROUNDREF 0x00200000 | ||
32 | #define BM_LRADC_CTRL0_CLKGATE 0x40000000 | ||
33 | #define BM_LRADC_CTRL0_SFTRST 0x80000000 | ||
34 | |||
35 | #define HW_LRADC_CTRL1 0x10 | ||
36 | #define BM_LRADC_CTRL1_LRADC0_IRQ 0x00000001 | ||
37 | #define BP_LRADC_CTRL1_LRADC0_IRQ 0 | ||
38 | #define BM_LRADC_CTRL1_LRADC5_IRQ 0x00000020 | ||
39 | #define BM_LRADC_CTRL1_LRADC6_IRQ 0x00000040 | ||
40 | #define BM_LRADC_CTRL1_TOUCH_DETECT_IRQ 0x00000100 | ||
41 | #define BM_LRADC_CTRL1_LRADC0_IRQ_EN 0x00010000 | ||
42 | #define BM_LRADC_CTRL1_LRADC5_IRQ_EN 0x00200000 | ||
43 | #define BM_LRADC_CTRL1_TOUCH_DETECT_IRQ_EN 0x01000000 | ||
44 | |||
45 | #define HW_LRADC_CTRL2 0x20 | ||
46 | #define BM_LRADC_CTRL2_BL_BRIGHTNESS 0x001F0000 | ||
47 | #define BP_LRADC_CTRL2_BL_BRIGHTNESS 16 | ||
48 | #define BM_LRADC_CTRL2_BL_MUX_SELECT 0x00200000 | ||
49 | #define BM_LRADC_CTRL2_BL_ENABLE 0x00400000 | ||
50 | #define BM_LRADC_CTRL2_DIVIDE_BY_TWO 0xFF000000 | ||
51 | #define BP_LRADC_CTRL2_DIVIDE_BY_TWO 24 | ||
52 | |||
53 | #define HW_LRADC_CTRL3 0x30 | ||
54 | #define BM_LRADC_CTRL3_CYCLE_TIME 0x00000300 | ||
55 | #define BP_LRADC_CTRL3_CYCLE_TIME 8 | ||
56 | |||
57 | #define HW_LRADC_STATUS 0x40 | ||
58 | #define BM_LRADC_STATUS_TOUCH_DETECT_RAW 0x00000001 | ||
59 | #define BP_LRADC_STATUS_TOUCH_DETECT_RAW 0 | ||
60 | |||
61 | #define HW_LRADC_CH0 (0x50 + 0 * 0x10) | ||
62 | #define HW_LRADC_CH1 (0x50 + 1 * 0x10) | ||
63 | #define HW_LRADC_CH2 (0x50 + 2 * 0x10) | ||
64 | #define HW_LRADC_CH3 (0x50 + 3 * 0x10) | ||
65 | #define HW_LRADC_CH4 (0x50 + 4 * 0x10) | ||
66 | #define HW_LRADC_CH5 (0x50 + 5 * 0x10) | ||
67 | #define HW_LRADC_CH6 (0x50 + 6 * 0x10) | ||
68 | #define HW_LRADC_CH7 (0x50 + 7 * 0x10) | ||
69 | |||
70 | #define HW_LRADC_CHn 0x50 | ||
71 | #define BM_LRADC_CHn_VALUE 0x0003FFFF | ||
72 | #define BP_LRADC_CHn_VALUE 0 | ||
73 | #define BM_LRADC_CHn_NUM_SAMPLES 0x1F000000 | ||
74 | #define BP_LRADC_CHn_NUM_SAMPLES 24 | ||
75 | #define BM_LRADC_CHn_ACCUMULATE 0x20000000 | ||
76 | |||
77 | #define HW_LRADC_DELAY0 (0xD0 + 0 * 0x10) | ||
78 | #define HW_LRADC_DELAY1 (0xD0 + 1 * 0x10) | ||
79 | #define HW_LRADC_DELAY2 (0xD0 + 2 * 0x10) | ||
80 | #define HW_LRADC_DELAY3 (0xD0 + 3 * 0x10) | ||
81 | |||
82 | #define HW_LRADC_DELAYn 0xD0 | ||
83 | #define BM_LRADC_DELAYn_DELAY 0x000007FF | ||
84 | #define BP_LRADC_DELAYn_DELAY 0 | ||
85 | #define BM_LRADC_DELAYn_LOOP_COUNT 0x0000F800 | ||
86 | #define BP_LRADC_DELAYn_LOOP_COUNT 11 | ||
87 | #define BM_LRADC_DELAYn_TRIGGER_DELAYS 0x000F0000 | ||
88 | #define BP_LRADC_DELAYn_TRIGGER_DELAYS 16 | ||
89 | #define BM_LRADC_DELAYn_KICK 0x00100000 | ||
90 | #define BM_LRADC_DELAYn_TRIGGER_LRADCS 0xFF000000 | ||
91 | #define BP_LRADC_DELAYn_TRIGGER_LRADCS 24 | ||
92 | |||
93 | #define HW_LRADC_CTRL4 0x140 | ||
94 | #define BM_LRADC_CTRL4_LRADC6SELECT 0x0F000000 | ||
95 | #define BP_LRADC_CTRL4_LRADC6SELECT 24 | ||
96 | #define BM_LRADC_CTRL4_LRADC7SELECT 0xF0000000 | ||
97 | #define BP_LRADC_CTRL4_LRADC7SELECT 28 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-pinctrl.h b/arch/arm/mach-stmp37xx/include/mach/regs-pinctrl.h new file mode 100644 index 000000000000..d5efce2388c7 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-pinctrl.h | |||
@@ -0,0 +1,88 @@ | |||
1 | /* | ||
2 | * stmp37xx: PINCTRL register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #ifndef _MACH_REGS_PINCTRL | ||
22 | #define _MACH_REGS_PINCTRL | ||
23 | |||
24 | #define REGS_PINCTRL_BASE (STMP3XXX_REGS_BASE + 0x18000) | ||
25 | |||
26 | #define HW_PINCTRL_MUXSEL0 0x100 | ||
27 | #define HW_PINCTRL_MUXSEL1 0x110 | ||
28 | #define HW_PINCTRL_MUXSEL2 0x120 | ||
29 | #define HW_PINCTRL_MUXSEL3 0x130 | ||
30 | #define HW_PINCTRL_MUXSEL4 0x140 | ||
31 | #define HW_PINCTRL_MUXSEL5 0x150 | ||
32 | #define HW_PINCTRL_MUXSEL6 0x160 | ||
33 | #define HW_PINCTRL_MUXSEL7 0x170 | ||
34 | |||
35 | #define HW_PINCTRL_DRIVE0 0x200 | ||
36 | #define HW_PINCTRL_DRIVE1 0x210 | ||
37 | #define HW_PINCTRL_DRIVE2 0x220 | ||
38 | #define HW_PINCTRL_DRIVE3 0x230 | ||
39 | #define HW_PINCTRL_DRIVE4 0x240 | ||
40 | #define HW_PINCTRL_DRIVE5 0x250 | ||
41 | #define HW_PINCTRL_DRIVE6 0x260 | ||
42 | #define HW_PINCTRL_DRIVE7 0x270 | ||
43 | #define HW_PINCTRL_DRIVE8 0x280 | ||
44 | #define HW_PINCTRL_DRIVE9 0x290 | ||
45 | #define HW_PINCTRL_DRIVE10 0x2A0 | ||
46 | #define HW_PINCTRL_DRIVE11 0x2B0 | ||
47 | #define HW_PINCTRL_DRIVE12 0x2C0 | ||
48 | #define HW_PINCTRL_DRIVE13 0x2D0 | ||
49 | #define HW_PINCTRL_DRIVE14 0x2E0 | ||
50 | |||
51 | #define HW_PINCTRL_PULL0 0x300 | ||
52 | #define HW_PINCTRL_PULL1 0x310 | ||
53 | #define HW_PINCTRL_PULL2 0x320 | ||
54 | #define HW_PINCTRL_PULL3 0x330 | ||
55 | |||
56 | #define HW_PINCTRL_DOUT0 0x400 | ||
57 | #define HW_PINCTRL_DOUT1 0x410 | ||
58 | #define HW_PINCTRL_DOUT2 0x420 | ||
59 | |||
60 | #define HW_PINCTRL_DIN0 0x500 | ||
61 | #define HW_PINCTRL_DIN1 0x510 | ||
62 | #define HW_PINCTRL_DIN2 0x520 | ||
63 | |||
64 | #define HW_PINCTRL_DOE0 0x600 | ||
65 | #define HW_PINCTRL_DOE1 0x610 | ||
66 | #define HW_PINCTRL_DOE2 0x620 | ||
67 | |||
68 | #define HW_PINCTRL_PIN2IRQ0 0x700 | ||
69 | #define HW_PINCTRL_PIN2IRQ1 0x710 | ||
70 | #define HW_PINCTRL_PIN2IRQ2 0x720 | ||
71 | |||
72 | #define HW_PINCTRL_IRQEN0 0x800 | ||
73 | #define HW_PINCTRL_IRQEN1 0x810 | ||
74 | #define HW_PINCTRL_IRQEN2 0x820 | ||
75 | |||
76 | #define HW_PINCTRL_IRQLEVEL0 0x900 | ||
77 | #define HW_PINCTRL_IRQLEVEL1 0x910 | ||
78 | #define HW_PINCTRL_IRQLEVEL2 0x920 | ||
79 | |||
80 | #define HW_PINCTRL_IRQPOL0 0xA00 | ||
81 | #define HW_PINCTRL_IRQPOL1 0xA10 | ||
82 | #define HW_PINCTRL_IRQPOL2 0xA20 | ||
83 | |||
84 | #define HW_PINCTRL_IRQSTAT0 0xB00 | ||
85 | #define HW_PINCTRL_IRQSTAT1 0xB10 | ||
86 | #define HW_PINCTRL_IRQSTAT2 0xB20 | ||
87 | |||
88 | #endif | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-power.h b/arch/arm/mach-stmp37xx/include/mach/regs-power.h new file mode 100644 index 000000000000..0e733d74a229 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-power.h | |||
@@ -0,0 +1,56 @@ | |||
1 | /* | ||
2 | * stmp37xx: POWER register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #ifndef _MACH_REGS_POWER | ||
22 | #define _MACH_REGS_POWER | ||
23 | |||
24 | #define REGS_POWER_BASE (STMP3XXX_REGS_BASE + 0x44000) | ||
25 | |||
26 | #define HW_POWER_CTRL 0x0 | ||
27 | #define BM_POWER_CTRL_CLKGATE 0x40000000 | ||
28 | |||
29 | #define HW_POWER_5VCTRL 0x10 | ||
30 | |||
31 | #define HW_POWER_MINPWR 0x20 | ||
32 | |||
33 | #define HW_POWER_CHARGE 0x30 | ||
34 | |||
35 | #define HW_POWER_VDDDCTRL 0x40 | ||
36 | |||
37 | #define HW_POWER_VDDACTRL 0x50 | ||
38 | |||
39 | #define HW_POWER_VDDIOCTRL 0x60 | ||
40 | #define BM_POWER_VDDIOCTRL_TRG 0x0000001F | ||
41 | #define BP_POWER_VDDIOCTRL_TRG 0 | ||
42 | |||
43 | #define HW_POWER_STS 0xB0 | ||
44 | #define BM_POWER_STS_VBUSVALID 0x00000002 | ||
45 | #define BM_POWER_STS_BVALID 0x00000004 | ||
46 | #define BM_POWER_STS_AVALID 0x00000008 | ||
47 | #define BM_POWER_STS_DC_OK 0x00000100 | ||
48 | |||
49 | #define HW_POWER_RESET 0xE0 | ||
50 | |||
51 | #define HW_POWER_DEBUG 0xF0 | ||
52 | #define BM_POWER_DEBUG_BVALIDPIOLOCK 0x00000002 | ||
53 | #define BM_POWER_DEBUG_AVALIDPIOLOCK 0x00000004 | ||
54 | #define BM_POWER_DEBUG_VBUSVALIDPIOLOCK 0x00000008 | ||
55 | |||
56 | #endif | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-pwm.h b/arch/arm/mach-stmp37xx/include/mach/regs-pwm.h new file mode 100644 index 000000000000..15966a1b62e0 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-pwm.h | |||
@@ -0,0 +1,51 @@ | |||
1 | /* | ||
2 | * stmp37xx: PWM register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_PWM_BASE (STMP3XXX_REGS_BASE + 0x64000) | ||
22 | |||
23 | #define HW_PWM_CTRL 0x0 | ||
24 | #define BM_PWM_CTRL_PWM2_ENABLE 0x00000004 | ||
25 | #define BM_PWM_CTRL_PWM2_ANA_CTRL_ENABLE 0x00000020 | ||
26 | |||
27 | #define HW_PWM_ACTIVE0 (0x10 + 0 * 0x20) | ||
28 | #define HW_PWM_ACTIVE1 (0x10 + 1 * 0x20) | ||
29 | #define HW_PWM_ACTIVE2 (0x10 + 2 * 0x20) | ||
30 | #define HW_PWM_ACTIVE3 (0x10 + 3 * 0x20) | ||
31 | |||
32 | #define HW_PWM_ACTIVEn 0x10 | ||
33 | #define BM_PWM_ACTIVEn_ACTIVE 0x0000FFFF | ||
34 | #define BP_PWM_ACTIVEn_ACTIVE 0 | ||
35 | #define BM_PWM_ACTIVEn_INACTIVE 0xFFFF0000 | ||
36 | #define BP_PWM_ACTIVEn_INACTIVE 16 | ||
37 | |||
38 | #define HW_PWM_PERIOD0 (0x20 + 0 * 0x20) | ||
39 | #define HW_PWM_PERIOD1 (0x20 + 1 * 0x20) | ||
40 | #define HW_PWM_PERIOD2 (0x20 + 2 * 0x20) | ||
41 | #define HW_PWM_PERIOD3 (0x20 + 3 * 0x20) | ||
42 | |||
43 | #define HW_PWM_PERIODn 0x20 | ||
44 | #define BM_PWM_PERIODn_PERIOD 0x0000FFFF | ||
45 | #define BP_PWM_PERIODn_PERIOD 0 | ||
46 | #define BM_PWM_PERIODn_ACTIVE_STATE 0x00030000 | ||
47 | #define BP_PWM_PERIODn_ACTIVE_STATE 16 | ||
48 | #define BM_PWM_PERIODn_INACTIVE_STATE 0x000C0000 | ||
49 | #define BP_PWM_PERIODn_INACTIVE_STATE 18 | ||
50 | #define BM_PWM_PERIODn_CDIV 0x00700000 | ||
51 | #define BP_PWM_PERIODn_CDIV 20 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-rtc.h b/arch/arm/mach-stmp37xx/include/mach/regs-rtc.h new file mode 100644 index 000000000000..fac40edc38a1 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-rtc.h | |||
@@ -0,0 +1,57 @@ | |||
1 | /* | ||
2 | * stmp37xx: RTC register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_RTC_BASE (STMP3XXX_REGS_BASE + 0x5C000) | ||
22 | #define REGS_RTC_PHYS 0x8005C000 | ||
23 | #define REGS_RTC_SIZE 0x2000 | ||
24 | |||
25 | #define HW_RTC_CTRL 0x0 | ||
26 | #define BM_RTC_CTRL_ALARM_IRQ_EN 0x00000001 | ||
27 | #define BP_RTC_CTRL_ALARM_IRQ_EN 0 | ||
28 | #define BM_RTC_CTRL_ONEMSEC_IRQ_EN 0x00000002 | ||
29 | #define BM_RTC_CTRL_ALARM_IRQ 0x00000004 | ||
30 | #define BM_RTC_CTRL_ONEMSEC_IRQ 0x00000008 | ||
31 | #define BM_RTC_CTRL_WATCHDOGEN 0x00000010 | ||
32 | |||
33 | #define HW_RTC_STAT 0x10 | ||
34 | #define BM_RTC_STAT_NEW_REGS 0x0000FF00 | ||
35 | #define BP_RTC_STAT_NEW_REGS 8 | ||
36 | #define BM_RTC_STAT_STALE_REGS 0x00FF0000 | ||
37 | #define BP_RTC_STAT_STALE_REGS 16 | ||
38 | #define BM_RTC_STAT_RTC_PRESENT 0x80000000 | ||
39 | |||
40 | #define HW_RTC_SECONDS 0x30 | ||
41 | |||
42 | #define HW_RTC_ALARM 0x40 | ||
43 | |||
44 | #define HW_RTC_WATCHDOG 0x50 | ||
45 | |||
46 | #define HW_RTC_PERSISTENT0 0x60 | ||
47 | #define BM_RTC_PERSISTENT0_ALARM_WAKE_EN 0x00000002 | ||
48 | #define BM_RTC_PERSISTENT0_ALARM_EN 0x00000004 | ||
49 | #define BM_RTC_PERSISTENT0_XTAL24MHZ_PWRUP 0x00000010 | ||
50 | #define BM_RTC_PERSISTENT0_XTAL32KHZ_PWRUP 0x00000020 | ||
51 | #define BM_RTC_PERSISTENT0_ALARM_WAKE 0x00000080 | ||
52 | #define BM_RTC_PERSISTENT0_SPARE_ANALOG 0xFFFC0000 | ||
53 | #define BP_RTC_PERSISTENT0_SPARE_ANALOG 18 | ||
54 | |||
55 | #define HW_RTC_PERSISTENT1 0x70 | ||
56 | |||
57 | #define HW_RTC_VERSION 0xD0 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-ssp.h b/arch/arm/mach-stmp37xx/include/mach/regs-ssp.h new file mode 100644 index 000000000000..cbde891a06c2 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-ssp.h | |||
@@ -0,0 +1,101 @@ | |||
1 | /* | ||
2 | * stmp37xx: SSP register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_SSP_BASE (STMP3XXX_REGS_BASE + 0x10000) | ||
22 | #define REGS_SSP1_PHYS 0x80010000 | ||
23 | #define REGS_SSP2_PHYS 0x80034000 | ||
24 | #define REGS_SSP_SIZE 0x2000 | ||
25 | |||
26 | #define HW_SSP_CTRL0 0x0 | ||
27 | #define BM_SSP_CTRL0_XFER_COUNT 0x0000FFFF | ||
28 | #define BP_SSP_CTRL0_XFER_COUNT 0 | ||
29 | #define BM_SSP_CTRL0_ENABLE 0x00010000 | ||
30 | #define BM_SSP_CTRL0_GET_RESP 0x00020000 | ||
31 | #define BM_SSP_CTRL0_LONG_RESP 0x00080000 | ||
32 | #define BM_SSP_CTRL0_WAIT_FOR_CMD 0x00100000 | ||
33 | #define BM_SSP_CTRL0_WAIT_FOR_IRQ 0x00200000 | ||
34 | #define BM_SSP_CTRL0_BUS_WIDTH 0x00C00000 | ||
35 | #define BP_SSP_CTRL0_BUS_WIDTH 22 | ||
36 | #define BM_SSP_CTRL0_DATA_XFER 0x01000000 | ||
37 | #define BM_SSP_CTRL0_READ 0x02000000 | ||
38 | #define BM_SSP_CTRL0_IGNORE_CRC 0x04000000 | ||
39 | #define BM_SSP_CTRL0_LOCK_CS 0x08000000 | ||
40 | #define BM_SSP_CTRL0_RUN 0x20000000 | ||
41 | #define BM_SSP_CTRL0_CLKGATE 0x40000000 | ||
42 | #define BM_SSP_CTRL0_SFTRST 0x80000000 | ||
43 | |||
44 | #define HW_SSP_CMD0 0x10 | ||
45 | #define BM_SSP_CMD0_CMD 0x000000FF | ||
46 | #define BP_SSP_CMD0_CMD 0 | ||
47 | #define BM_SSP_CMD0_BLOCK_COUNT 0x0000FF00 | ||
48 | #define BP_SSP_CMD0_BLOCK_COUNT 8 | ||
49 | #define BM_SSP_CMD0_BLOCK_SIZE 0x000F0000 | ||
50 | #define BP_SSP_CMD0_BLOCK_SIZE 16 | ||
51 | #define BM_SSP_CMD0_APPEND_8CYC 0x00100000 | ||
52 | #define BM_SSP_CMD1_CMD_ARG 0xFFFFFFFF | ||
53 | #define BP_SSP_CMD1_CMD_ARG 0 | ||
54 | |||
55 | #define HW_SSP_TIMING 0x50 | ||
56 | #define BM_SSP_TIMING_CLOCK_RATE 0x000000FF | ||
57 | #define BP_SSP_TIMING_CLOCK_RATE 0 | ||
58 | #define BM_SSP_TIMING_CLOCK_DIVIDE 0x0000FF00 | ||
59 | #define BP_SSP_TIMING_CLOCK_DIVIDE 8 | ||
60 | #define BM_SSP_TIMING_TIMEOUT 0xFFFF0000 | ||
61 | #define BP_SSP_TIMING_TIMEOUT 16 | ||
62 | |||
63 | #define HW_SSP_CTRL1 0x60 | ||
64 | #define BM_SSP_CTRL1_SSP_MODE 0x0000000F | ||
65 | #define BP_SSP_CTRL1_SSP_MODE 0 | ||
66 | #define BM_SSP_CTRL1_WORD_LENGTH 0x000000F0 | ||
67 | #define BP_SSP_CTRL1_WORD_LENGTH 4 | ||
68 | #define BM_SSP_CTRL1_POLARITY 0x00000200 | ||
69 | #define BM_SSP_CTRL1_PHASE 0x00000400 | ||
70 | #define BM_SSP_CTRL1_DMA_ENABLE 0x00002000 | ||
71 | #define BM_SSP_CTRL1_FIFO_OVERRUN_IRQ 0x00008000 | ||
72 | #define BM_SSP_CTRL1_RECV_TIMEOUT_IRQ_EN 0x00010000 | ||
73 | #define BM_SSP_CTRL1_RECV_TIMEOUT_IRQ 0x00020000 | ||
74 | #define BM_SSP_CTRL1_FIFO_UNDERRUN_IRQ 0x00200000 | ||
75 | #define BM_SSP_CTRL1_DATA_CRC_IRQ_EN 0x00400000 | ||
76 | #define BM_SSP_CTRL1_DATA_CRC_IRQ 0x00800000 | ||
77 | #define BM_SSP_CTRL1_DATA_TIMEOUT_IRQ_EN 0x01000000 | ||
78 | #define BM_SSP_CTRL1_DATA_TIMEOUT_IRQ 0x02000000 | ||
79 | #define BM_SSP_CTRL1_RESP_TIMEOUT_IRQ_EN 0x04000000 | ||
80 | #define BM_SSP_CTRL1_RESP_TIMEOUT_IRQ 0x08000000 | ||
81 | #define BM_SSP_CTRL1_RESP_ERR_IRQ_EN 0x10000000 | ||
82 | #define BM_SSP_CTRL1_RESP_ERR_IRQ 0x20000000 | ||
83 | #define BM_SSP_CTRL1_SDIO_IRQ 0x80000000 | ||
84 | |||
85 | #define HW_SSP_DATA 0x70 | ||
86 | |||
87 | #define HW_SSP_SDRESP0 0x80 | ||
88 | |||
89 | #define HW_SSP_SDRESP1 0x90 | ||
90 | |||
91 | #define HW_SSP_SDRESP2 0xA0 | ||
92 | |||
93 | #define HW_SSP_SDRESP3 0xB0 | ||
94 | |||
95 | #define HW_SSP_STATUS 0xC0 | ||
96 | #define BM_SSP_STATUS_FIFO_EMPTY 0x00000020 | ||
97 | #define BM_SSP_STATUS_TIMEOUT 0x00001000 | ||
98 | #define BM_SSP_STATUS_RESP_TIMEOUT 0x00004000 | ||
99 | #define BM_SSP_STATUS_RESP_ERR 0x00008000 | ||
100 | #define BM_SSP_STATUS_RESP_CRC_ERR 0x00010000 | ||
101 | #define BM_SSP_STATUS_CARD_DETECT 0x10000000 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-timrot.h b/arch/arm/mach-stmp37xx/include/mach/regs-timrot.h new file mode 100644 index 000000000000..4af0f6edfa78 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-timrot.h | |||
@@ -0,0 +1,49 @@ | |||
1 | /* | ||
2 | * stmp37xx: TIMROT register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #ifndef _MACH_REGS_TIMROT | ||
22 | #define _MACH_REGS_TIMROT | ||
23 | |||
24 | #define REGS_TIMROT_BASE (STMP3XXX_REGS_BASE + 0x68000) | ||
25 | |||
26 | #define HW_TIMROT_ROTCTRL 0x0 | ||
27 | #define BM_TIMROT_ROTCTRL_CLKGATE 0x40000000 | ||
28 | #define BM_TIMROT_ROTCTRL_SFTRST 0x80000000 | ||
29 | |||
30 | #define HW_TIMROT_TIMCTRL0 (0x20 + 0 * 0x20) | ||
31 | #define HW_TIMROT_TIMCTRL1 (0x20 + 1 * 0x20) | ||
32 | #define HW_TIMROT_TIMCTRL2 (0x20 + 2 * 0x20) | ||
33 | |||
34 | #define HW_TIMROT_TIMCTRLn 0x20 | ||
35 | #define BM_TIMROT_TIMCTRLn_SELECT 0x0000000F | ||
36 | #define BP_TIMROT_TIMCTRLn_SELECT 0 | ||
37 | #define BM_TIMROT_TIMCTRLn_PRESCALE 0x00000030 | ||
38 | #define BP_TIMROT_TIMCTRLn_PRESCALE 4 | ||
39 | #define BM_TIMROT_TIMCTRLn_RELOAD 0x00000040 | ||
40 | #define BM_TIMROT_TIMCTRLn_UPDATE 0x00000080 | ||
41 | #define BM_TIMROT_TIMCTRLn_IRQ_EN 0x00004000 | ||
42 | #define BM_TIMROT_TIMCTRLn_IRQ 0x00008000 | ||
43 | |||
44 | #define HW_TIMROT_TIMCOUNT0 (0x30 + 0 * 0x20) | ||
45 | #define HW_TIMROT_TIMCOUNT1 (0x30 + 1 * 0x20) | ||
46 | #define HW_TIMROT_TIMCOUNT2 (0x30 + 2 * 0x20) | ||
47 | |||
48 | #define HW_TIMROT_TIMCOUNTn 0x30 | ||
49 | #endif | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-uartapp.h b/arch/arm/mach-stmp37xx/include/mach/regs-uartapp.h new file mode 100644 index 000000000000..0594275d860c --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-uartapp.h | |||
@@ -0,0 +1,85 @@ | |||
1 | /* | ||
2 | * stmp37xx: UARTAPP register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_UARTAPP_BASE (STMP3XXX_REGS_BASE + 0x6C000) | ||
22 | #define REGS_UARTAPP1_PHYS 0x8006C000 | ||
23 | #define REGS_UARTAPP_SIZE 0x2000 | ||
24 | |||
25 | #define HW_UARTAPP_CTRL0 0x0 | ||
26 | #define BM_UARTAPP_CTRL0_XFER_COUNT 0x0000FFFF | ||
27 | #define BP_UARTAPP_CTRL0_XFER_COUNT 0 | ||
28 | #define BM_UARTAPP_CTRL0_RXTIMEOUT 0x07FF0000 | ||
29 | #define BP_UARTAPP_CTRL0_RXTIMEOUT 16 | ||
30 | #define BM_UARTAPP_CTRL0_RXTO_ENABLE 0x08000000 | ||
31 | #define BM_UARTAPP_CTRL0_RUN 0x20000000 | ||
32 | #define BM_UARTAPP_CTRL0_SFTRST 0x80000000 | ||
33 | #define BM_UARTAPP_CTRL1_XFER_COUNT 0x0000FFFF | ||
34 | #define BP_UARTAPP_CTRL1_XFER_COUNT 0 | ||
35 | #define BM_UARTAPP_CTRL1_RUN 0x10000000 | ||
36 | |||
37 | #define HW_UARTAPP_CTRL2 0x20 | ||
38 | #define BM_UARTAPP_CTRL2_UARTEN 0x00000001 | ||
39 | #define BP_UARTAPP_CTRL2_UARTEN 0 | ||
40 | #define BM_UARTAPP_CTRL2_TXE 0x00000100 | ||
41 | #define BM_UARTAPP_CTRL2_RXE 0x00000200 | ||
42 | #define BM_UARTAPP_CTRL2_RTS 0x00000800 | ||
43 | #define BM_UARTAPP_CTRL2_RTSEN 0x00004000 | ||
44 | #define BM_UARTAPP_CTRL2_CTSEN 0x00008000 | ||
45 | #define BM_UARTAPP_CTRL2_RXDMAE 0x01000000 | ||
46 | #define BM_UARTAPP_CTRL2_TXDMAE 0x02000000 | ||
47 | #define BM_UARTAPP_CTRL2_DMAONERR 0x04000000 | ||
48 | |||
49 | #define HW_UARTAPP_LINECTRL 0x30 | ||
50 | #define BM_UARTAPP_LINECTRL_BRK 0x00000001 | ||
51 | #define BP_UARTAPP_LINECTRL_BRK 0 | ||
52 | #define BM_UARTAPP_LINECTRL_PEN 0x00000002 | ||
53 | #define BM_UARTAPP_LINECTRL_EPS 0x00000004 | ||
54 | #define BM_UARTAPP_LINECTRL_STP2 0x00000008 | ||
55 | #define BM_UARTAPP_LINECTRL_FEN 0x00000010 | ||
56 | #define BM_UARTAPP_LINECTRL_WLEN 0x00000060 | ||
57 | #define BP_UARTAPP_LINECTRL_WLEN 5 | ||
58 | #define BM_UARTAPP_LINECTRL_SPS 0x00000080 | ||
59 | #define BM_UARTAPP_LINECTRL_BAUD_DIVFRAC 0x00003F00 | ||
60 | #define BP_UARTAPP_LINECTRL_BAUD_DIVFRAC 8 | ||
61 | #define BM_UARTAPP_LINECTRL_BAUD_DIVINT 0xFFFF0000 | ||
62 | #define BP_UARTAPP_LINECTRL_BAUD_DIVINT 16 | ||
63 | |||
64 | #define HW_UARTAPP_INTR 0x50 | ||
65 | #define BM_UARTAPP_INTR_CTSMIS 0x00000002 | ||
66 | #define BM_UARTAPP_INTR_RTIS 0x00000040 | ||
67 | #define BM_UARTAPP_INTR_CTSMIEN 0x00020000 | ||
68 | #define BM_UARTAPP_INTR_RXIEN 0x00100000 | ||
69 | #define BM_UARTAPP_INTR_RTIEN 0x00400000 | ||
70 | |||
71 | #define HW_UARTAPP_DATA 0x60 | ||
72 | |||
73 | #define HW_UARTAPP_STAT 0x70 | ||
74 | #define BM_UARTAPP_STAT_RXCOUNT 0x0000FFFF | ||
75 | #define BP_UARTAPP_STAT_RXCOUNT 0 | ||
76 | #define BM_UARTAPP_STAT_FERR 0x00010000 | ||
77 | #define BM_UARTAPP_STAT_PERR 0x00020000 | ||
78 | #define BM_UARTAPP_STAT_BERR 0x00040000 | ||
79 | #define BM_UARTAPP_STAT_OERR 0x00080000 | ||
80 | #define BM_UARTAPP_STAT_RXFE 0x01000000 | ||
81 | #define BM_UARTAPP_STAT_TXFF 0x02000000 | ||
82 | #define BM_UARTAPP_STAT_TXFE 0x08000000 | ||
83 | #define BM_UARTAPP_STAT_CTS 0x10000000 | ||
84 | |||
85 | #define HW_UARTAPP_VERSION 0x90 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-uartdbg.h b/arch/arm/mach-stmp37xx/include/mach/regs-uartdbg.h new file mode 100644 index 000000000000..b810deb552a9 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-uartdbg.h | |||
@@ -0,0 +1,268 @@ | |||
1 | /* | ||
2 | * stmp378x: UARTDBG register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_UARTDBG_BASE (STMP3XXX_REGS_BASE + 0x70000) | ||
22 | #define REGS_UARTDBG_PHYS 0x80070000 | ||
23 | #define REGS_UARTDBG_SIZE 0x2000 | ||
24 | |||
25 | #define HW_UARTDBGDR 0x00000000 | ||
26 | #define BP_UARTDBGDR_UNAVAILABLE 16 | ||
27 | #define BM_UARTDBGDR_UNAVAILABLE 0xFFFF0000 | ||
28 | #define BF_UARTDBGDR_UNAVAILABLE(v) \ | ||
29 | (((v) << 16) & BM_UARTDBGDR_UNAVAILABLE) | ||
30 | #define BP_UARTDBGDR_RESERVED 12 | ||
31 | #define BM_UARTDBGDR_RESERVED 0x0000F000 | ||
32 | #define BF_UARTDBGDR_RESERVED(v) \ | ||
33 | (((v) << 12) & BM_UARTDBGDR_RESERVED) | ||
34 | #define BM_UARTDBGDR_OE 0x00000800 | ||
35 | #define BM_UARTDBGDR_BE 0x00000400 | ||
36 | #define BM_UARTDBGDR_PE 0x00000200 | ||
37 | #define BM_UARTDBGDR_FE 0x00000100 | ||
38 | #define BP_UARTDBGDR_DATA 0 | ||
39 | #define BM_UARTDBGDR_DATA 0x000000FF | ||
40 | #define BF_UARTDBGDR_DATA(v) \ | ||
41 | (((v) << 0) & BM_UARTDBGDR_DATA) | ||
42 | #define HW_UARTDBGRSR_ECR 0x00000004 | ||
43 | #define BP_UARTDBGRSR_ECR_UNAVAILABLE 8 | ||
44 | #define BM_UARTDBGRSR_ECR_UNAVAILABLE 0xFFFFFF00 | ||
45 | #define BF_UARTDBGRSR_ECR_UNAVAILABLE(v) \ | ||
46 | (((v) << 8) & BM_UARTDBGRSR_ECR_UNAVAILABLE) | ||
47 | #define BP_UARTDBGRSR_ECR_EC 4 | ||
48 | #define BM_UARTDBGRSR_ECR_EC 0x000000F0 | ||
49 | #define BF_UARTDBGRSR_ECR_EC(v) \ | ||
50 | (((v) << 4) & BM_UARTDBGRSR_ECR_EC) | ||
51 | #define BM_UARTDBGRSR_ECR_OE 0x00000008 | ||
52 | #define BM_UARTDBGRSR_ECR_BE 0x00000004 | ||
53 | #define BM_UARTDBGRSR_ECR_PE 0x00000002 | ||
54 | #define BM_UARTDBGRSR_ECR_FE 0x00000001 | ||
55 | #define HW_UARTDBGFR 0x00000018 | ||
56 | #define BP_UARTDBGFR_UNAVAILABLE 16 | ||
57 | #define BM_UARTDBGFR_UNAVAILABLE 0xFFFF0000 | ||
58 | #define BF_UARTDBGFR_UNAVAILABLE(v) \ | ||
59 | (((v) << 16) & BM_UARTDBGFR_UNAVAILABLE) | ||
60 | #define BP_UARTDBGFR_RESERVED 9 | ||
61 | #define BM_UARTDBGFR_RESERVED 0x0000FE00 | ||
62 | #define BF_UARTDBGFR_RESERVED(v) \ | ||
63 | (((v) << 9) & BM_UARTDBGFR_RESERVED) | ||
64 | #define BM_UARTDBGFR_RI 0x00000100 | ||
65 | #define BM_UARTDBGFR_TXFE 0x00000080 | ||
66 | #define BM_UARTDBGFR_RXFF 0x00000040 | ||
67 | #define BM_UARTDBGFR_TXFF 0x00000020 | ||
68 | #define BM_UARTDBGFR_RXFE 0x00000010 | ||
69 | #define BM_UARTDBGFR_BUSY 0x00000008 | ||
70 | #define BM_UARTDBGFR_DCD 0x00000004 | ||
71 | #define BM_UARTDBGFR_DSR 0x00000002 | ||
72 | #define BM_UARTDBGFR_CTS 0x00000001 | ||
73 | #define HW_UARTDBGILPR 0x00000020 | ||
74 | #define BP_UARTDBGILPR_UNAVAILABLE 8 | ||
75 | #define BM_UARTDBGILPR_UNAVAILABLE 0xFFFFFF00 | ||
76 | #define BF_UARTDBGILPR_UNAVAILABLE(v) \ | ||
77 | (((v) << 8) & BM_UARTDBGILPR_UNAVAILABLE) | ||
78 | #define BP_UARTDBGILPR_ILPDVSR 0 | ||
79 | #define BM_UARTDBGILPR_ILPDVSR 0x000000FF | ||
80 | #define BF_UARTDBGILPR_ILPDVSR(v) \ | ||
81 | (((v) << 0) & BM_UARTDBGILPR_ILPDVSR) | ||
82 | #define HW_UARTDBGIBRD 0x00000024 | ||
83 | #define BP_UARTDBGIBRD_UNAVAILABLE 16 | ||
84 | #define BM_UARTDBGIBRD_UNAVAILABLE 0xFFFF0000 | ||
85 | #define BF_UARTDBGIBRD_UNAVAILABLE(v) \ | ||
86 | (((v) << 16) & BM_UARTDBGIBRD_UNAVAILABLE) | ||
87 | #define BP_UARTDBGIBRD_BAUD_DIVINT 0 | ||
88 | #define BM_UARTDBGIBRD_BAUD_DIVINT 0x0000FFFF | ||
89 | #define BF_UARTDBGIBRD_BAUD_DIVINT(v) \ | ||
90 | (((v) << 0) & BM_UARTDBGIBRD_BAUD_DIVINT) | ||
91 | #define HW_UARTDBGFBRD 0x00000028 | ||
92 | #define BP_UARTDBGFBRD_UNAVAILABLE 8 | ||
93 | #define BM_UARTDBGFBRD_UNAVAILABLE 0xFFFFFF00 | ||
94 | #define BF_UARTDBGFBRD_UNAVAILABLE(v) \ | ||
95 | (((v) << 8) & BM_UARTDBGFBRD_UNAVAILABLE) | ||
96 | #define BP_UARTDBGFBRD_RESERVED 6 | ||
97 | #define BM_UARTDBGFBRD_RESERVED 0x000000C0 | ||
98 | #define BF_UARTDBGFBRD_RESERVED(v) \ | ||
99 | (((v) << 6) & BM_UARTDBGFBRD_RESERVED) | ||
100 | #define BP_UARTDBGFBRD_BAUD_DIVFRAC 0 | ||
101 | #define BM_UARTDBGFBRD_BAUD_DIVFRAC 0x0000003F | ||
102 | #define BF_UARTDBGFBRD_BAUD_DIVFRAC(v) \ | ||
103 | (((v) << 0) & BM_UARTDBGFBRD_BAUD_DIVFRAC) | ||
104 | #define HW_UARTDBGLCR_H 0x0000002c | ||
105 | #define BP_UARTDBGLCR_H_UNAVAILABLE 16 | ||
106 | #define BM_UARTDBGLCR_H_UNAVAILABLE 0xFFFF0000 | ||
107 | #define BF_UARTDBGLCR_H_UNAVAILABLE(v) \ | ||
108 | (((v) << 16) & BM_UARTDBGLCR_H_UNAVAILABLE) | ||
109 | #define BP_UARTDBGLCR_H_RESERVED 8 | ||
110 | #define BM_UARTDBGLCR_H_RESERVED 0x0000FF00 | ||
111 | #define BF_UARTDBGLCR_H_RESERVED(v) \ | ||
112 | (((v) << 8) & BM_UARTDBGLCR_H_RESERVED) | ||
113 | #define BM_UARTDBGLCR_H_SPS 0x00000080 | ||
114 | #define BP_UARTDBGLCR_H_WLEN 5 | ||
115 | #define BM_UARTDBGLCR_H_WLEN 0x00000060 | ||
116 | #define BF_UARTDBGLCR_H_WLEN(v) \ | ||
117 | (((v) << 5) & BM_UARTDBGLCR_H_WLEN) | ||
118 | #define BM_UARTDBGLCR_H_FEN 0x00000010 | ||
119 | #define BM_UARTDBGLCR_H_STP2 0x00000008 | ||
120 | #define BM_UARTDBGLCR_H_EPS 0x00000004 | ||
121 | #define BM_UARTDBGLCR_H_PEN 0x00000002 | ||
122 | #define BM_UARTDBGLCR_H_BRK 0x00000001 | ||
123 | #define HW_UARTDBGCR 0x00000030 | ||
124 | #define BP_UARTDBGCR_UNAVAILABLE 16 | ||
125 | #define BM_UARTDBGCR_UNAVAILABLE 0xFFFF0000 | ||
126 | #define BF_UARTDBGCR_UNAVAILABLE(v) \ | ||
127 | (((v) << 16) & BM_UARTDBGCR_UNAVAILABLE) | ||
128 | #define BM_UARTDBGCR_CTSEN 0x00008000 | ||
129 | #define BM_UARTDBGCR_RTSEN 0x00004000 | ||
130 | #define BM_UARTDBGCR_OUT2 0x00002000 | ||
131 | #define BM_UARTDBGCR_OUT1 0x00001000 | ||
132 | #define BM_UARTDBGCR_RTS 0x00000800 | ||
133 | #define BM_UARTDBGCR_DTR 0x00000400 | ||
134 | #define BM_UARTDBGCR_RXE 0x00000200 | ||
135 | #define BM_UARTDBGCR_TXE 0x00000100 | ||
136 | #define BM_UARTDBGCR_LBE 0x00000080 | ||
137 | #define BP_UARTDBGCR_RESERVED 3 | ||
138 | #define BM_UARTDBGCR_RESERVED 0x00000078 | ||
139 | #define BF_UARTDBGCR_RESERVED(v) \ | ||
140 | (((v) << 3) & BM_UARTDBGCR_RESERVED) | ||
141 | #define BM_UARTDBGCR_SIRLP 0x00000004 | ||
142 | #define BM_UARTDBGCR_SIREN 0x00000002 | ||
143 | #define BM_UARTDBGCR_UARTEN 0x00000001 | ||
144 | #define HW_UARTDBGIFLS 0x00000034 | ||
145 | #define BP_UARTDBGIFLS_UNAVAILABLE 16 | ||
146 | #define BM_UARTDBGIFLS_UNAVAILABLE 0xFFFF0000 | ||
147 | #define BF_UARTDBGIFLS_UNAVAILABLE(v) \ | ||
148 | (((v) << 16) & BM_UARTDBGIFLS_UNAVAILABLE) | ||
149 | #define BP_UARTDBGIFLS_RESERVED 6 | ||
150 | #define BM_UARTDBGIFLS_RESERVED 0x0000FFC0 | ||
151 | #define BF_UARTDBGIFLS_RESERVED(v) \ | ||
152 | (((v) << 6) & BM_UARTDBGIFLS_RESERVED) | ||
153 | #define BP_UARTDBGIFLS_RXIFLSEL 3 | ||
154 | #define BM_UARTDBGIFLS_RXIFLSEL 0x00000038 | ||
155 | #define BF_UARTDBGIFLS_RXIFLSEL(v) \ | ||
156 | (((v) << 3) & BM_UARTDBGIFLS_RXIFLSEL) | ||
157 | #define BV_UARTDBGIFLS_RXIFLSEL__NOT_EMPTY 0x0 | ||
158 | #define BV_UARTDBGIFLS_RXIFLSEL__ONE_QUARTER 0x1 | ||
159 | #define BV_UARTDBGIFLS_RXIFLSEL__ONE_HALF 0x2 | ||
160 | #define BV_UARTDBGIFLS_RXIFLSEL__THREE_QUARTERS 0x3 | ||
161 | #define BV_UARTDBGIFLS_RXIFLSEL__SEVEN_EIGHTHS 0x4 | ||
162 | #define BV_UARTDBGIFLS_RXIFLSEL__INVALID5 0x5 | ||
163 | #define BV_UARTDBGIFLS_RXIFLSEL__INVALID6 0x6 | ||
164 | #define BV_UARTDBGIFLS_RXIFLSEL__INVALID7 0x7 | ||
165 | #define BP_UARTDBGIFLS_TXIFLSEL 0 | ||
166 | #define BM_UARTDBGIFLS_TXIFLSEL 0x00000007 | ||
167 | #define BF_UARTDBGIFLS_TXIFLSEL(v) \ | ||
168 | (((v) << 0) & BM_UARTDBGIFLS_TXIFLSEL) | ||
169 | #define BV_UARTDBGIFLS_TXIFLSEL__EMPTY 0x0 | ||
170 | #define BV_UARTDBGIFLS_TXIFLSEL__ONE_QUARTER 0x1 | ||
171 | #define BV_UARTDBGIFLS_TXIFLSEL__ONE_HALF 0x2 | ||
172 | #define BV_UARTDBGIFLS_TXIFLSEL__THREE_QUARTERS 0x3 | ||
173 | #define BV_UARTDBGIFLS_TXIFLSEL__SEVEN_EIGHTHS 0x4 | ||
174 | #define BV_UARTDBGIFLS_TXIFLSEL__INVALID5 0x5 | ||
175 | #define BV_UARTDBGIFLS_TXIFLSEL__INVALID6 0x6 | ||
176 | #define BV_UARTDBGIFLS_TXIFLSEL__INVALID7 0x7 | ||
177 | #define HW_UARTDBGIMSC 0x00000038 | ||
178 | #define BP_UARTDBGIMSC_UNAVAILABLE 16 | ||
179 | #define BM_UARTDBGIMSC_UNAVAILABLE 0xFFFF0000 | ||
180 | #define BF_UARTDBGIMSC_UNAVAILABLE(v) \ | ||
181 | (((v) << 16) & BM_UARTDBGIMSC_UNAVAILABLE) | ||
182 | #define BP_UARTDBGIMSC_RESERVED 11 | ||
183 | #define BM_UARTDBGIMSC_RESERVED 0x0000F800 | ||
184 | #define BF_UARTDBGIMSC_RESERVED(v) \ | ||
185 | (((v) << 11) & BM_UARTDBGIMSC_RESERVED) | ||
186 | #define BM_UARTDBGIMSC_OEIM 0x00000400 | ||
187 | #define BM_UARTDBGIMSC_BEIM 0x00000200 | ||
188 | #define BM_UARTDBGIMSC_PEIM 0x00000100 | ||
189 | #define BM_UARTDBGIMSC_FEIM 0x00000080 | ||
190 | #define BM_UARTDBGIMSC_RTIM 0x00000040 | ||
191 | #define BM_UARTDBGIMSC_TXIM 0x00000020 | ||
192 | #define BM_UARTDBGIMSC_RXIM 0x00000010 | ||
193 | #define BM_UARTDBGIMSC_DSRMIM 0x00000008 | ||
194 | #define BM_UARTDBGIMSC_DCDMIM 0x00000004 | ||
195 | #define BM_UARTDBGIMSC_CTSMIM 0x00000002 | ||
196 | #define BM_UARTDBGIMSC_RIMIM 0x00000001 | ||
197 | #define HW_UARTDBGRIS 0x0000003c | ||
198 | #define BP_UARTDBGRIS_UNAVAILABLE 16 | ||
199 | #define BM_UARTDBGRIS_UNAVAILABLE 0xFFFF0000 | ||
200 | #define BF_UARTDBGRIS_UNAVAILABLE(v) \ | ||
201 | (((v) << 16) & BM_UARTDBGRIS_UNAVAILABLE) | ||
202 | #define BP_UARTDBGRIS_RESERVED 11 | ||
203 | #define BM_UARTDBGRIS_RESERVED 0x0000F800 | ||
204 | #define BF_UARTDBGRIS_RESERVED(v) \ | ||
205 | (((v) << 11) & BM_UARTDBGRIS_RESERVED) | ||
206 | #define BM_UARTDBGRIS_OERIS 0x00000400 | ||
207 | #define BM_UARTDBGRIS_BERIS 0x00000200 | ||
208 | #define BM_UARTDBGRIS_PERIS 0x00000100 | ||
209 | #define BM_UARTDBGRIS_FERIS 0x00000080 | ||
210 | #define BM_UARTDBGRIS_RTRIS 0x00000040 | ||
211 | #define BM_UARTDBGRIS_TXRIS 0x00000020 | ||
212 | #define BM_UARTDBGRIS_RXRIS 0x00000010 | ||
213 | #define BM_UARTDBGRIS_DSRRMIS 0x00000008 | ||
214 | #define BM_UARTDBGRIS_DCDRMIS 0x00000004 | ||
215 | #define BM_UARTDBGRIS_CTSRMIS 0x00000002 | ||
216 | #define BM_UARTDBGRIS_RIRMIS 0x00000001 | ||
217 | #define HW_UARTDBGMIS 0x00000040 | ||
218 | #define BP_UARTDBGMIS_UNAVAILABLE 16 | ||
219 | #define BM_UARTDBGMIS_UNAVAILABLE 0xFFFF0000 | ||
220 | #define BF_UARTDBGMIS_UNAVAILABLE(v) \ | ||
221 | (((v) << 16) & BM_UARTDBGMIS_UNAVAILABLE) | ||
222 | #define BP_UARTDBGMIS_RESERVED 11 | ||
223 | #define BM_UARTDBGMIS_RESERVED 0x0000F800 | ||
224 | #define BF_UARTDBGMIS_RESERVED(v) \ | ||
225 | (((v) << 11) & BM_UARTDBGMIS_RESERVED) | ||
226 | #define BM_UARTDBGMIS_OEMIS 0x00000400 | ||
227 | #define BM_UARTDBGMIS_BEMIS 0x00000200 | ||
228 | #define BM_UARTDBGMIS_PEMIS 0x00000100 | ||
229 | #define BM_UARTDBGMIS_FEMIS 0x00000080 | ||
230 | #define BM_UARTDBGMIS_RTMIS 0x00000040 | ||
231 | #define BM_UARTDBGMIS_TXMIS 0x00000020 | ||
232 | #define BM_UARTDBGMIS_RXMIS 0x00000010 | ||
233 | #define BM_UARTDBGMIS_DSRMMIS 0x00000008 | ||
234 | #define BM_UARTDBGMIS_DCDMMIS 0x00000004 | ||
235 | #define BM_UARTDBGMIS_CTSMMIS 0x00000002 | ||
236 | #define BM_UARTDBGMIS_RIMMIS 0x00000001 | ||
237 | #define HW_UARTDBGICR 0x00000044 | ||
238 | #define BP_UARTDBGICR_UNAVAILABLE 16 | ||
239 | #define BM_UARTDBGICR_UNAVAILABLE 0xFFFF0000 | ||
240 | #define BF_UARTDBGICR_UNAVAILABLE(v) \ | ||
241 | (((v) << 16) & BM_UARTDBGICR_UNAVAILABLE) | ||
242 | #define BP_UARTDBGICR_RESERVED 11 | ||
243 | #define BM_UARTDBGICR_RESERVED 0x0000F800 | ||
244 | #define BF_UARTDBGICR_RESERVED(v) \ | ||
245 | (((v) << 11) & BM_UARTDBGICR_RESERVED) | ||
246 | #define BM_UARTDBGICR_OEIC 0x00000400 | ||
247 | #define BM_UARTDBGICR_BEIC 0x00000200 | ||
248 | #define BM_UARTDBGICR_PEIC 0x00000100 | ||
249 | #define BM_UARTDBGICR_FEIC 0x00000080 | ||
250 | #define BM_UARTDBGICR_RTIC 0x00000040 | ||
251 | #define BM_UARTDBGICR_TXIC 0x00000020 | ||
252 | #define BM_UARTDBGICR_RXIC 0x00000010 | ||
253 | #define BM_UARTDBGICR_DSRMIC 0x00000008 | ||
254 | #define BM_UARTDBGICR_DCDMIC 0x00000004 | ||
255 | #define BM_UARTDBGICR_CTSMIC 0x00000002 | ||
256 | #define BM_UARTDBGICR_RIMIC 0x00000001 | ||
257 | #define HW_UARTDBGDMACR 0x00000048 | ||
258 | #define BP_UARTDBGDMACR_UNAVAILABLE 16 | ||
259 | #define BM_UARTDBGDMACR_UNAVAILABLE 0xFFFF0000 | ||
260 | #define BF_UARTDBGDMACR_UNAVAILABLE(v) \ | ||
261 | (((v) << 16) & BM_UARTDBGDMACR_UNAVAILABLE) | ||
262 | #define BP_UARTDBGDMACR_RESERVED 3 | ||
263 | #define BM_UARTDBGDMACR_RESERVED 0x0000FFF8 | ||
264 | #define BF_UARTDBGDMACR_RESERVED(v) \ | ||
265 | (((v) << 3) & BM_UARTDBGDMACR_RESERVED) | ||
266 | #define BM_UARTDBGDMACR_DMAONERR 0x00000004 | ||
267 | #define BM_UARTDBGDMACR_TXDMAE 0x00000002 | ||
268 | #define BM_UARTDBGDMACR_RXDMAE 0x00000001 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-usbctl.h b/arch/arm/mach-stmp37xx/include/mach/regs-usbctl.h new file mode 100644 index 000000000000..9145e22df32c --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-usbctl.h | |||
@@ -0,0 +1,22 @@ | |||
1 | /* | ||
2 | * stmp37xx: USBCTL register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_USBCTL_BASE (STMP3XXX_REGS_BASE + 0x80000) | ||
22 | #define REGS_USBCTL_PHYS 0x80000 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-usbctrl.h b/arch/arm/mach-stmp37xx/include/mach/regs-usbctrl.h new file mode 100644 index 000000000000..1a2ae9cbdfed --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-usbctrl.h | |||
@@ -0,0 +1,22 @@ | |||
1 | /* | ||
2 | * stmp37xx: USBCTRL register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_USBCTRL_BASE (STMP3XXX_REGS_BASE + 0x80000) | ||
22 | #define REGS_USBCTRL_PHYS 0x80080000 | ||
diff --git a/arch/arm/mach-stmp37xx/include/mach/regs-usbphy.h b/arch/arm/mach-stmp37xx/include/mach/regs-usbphy.h new file mode 100644 index 000000000000..b7fce0fbc560 --- /dev/null +++ b/arch/arm/mach-stmp37xx/include/mach/regs-usbphy.h | |||
@@ -0,0 +1,37 @@ | |||
1 | /* | ||
2 | * stmp37xx: USBPHY register definitions | ||
3 | * | ||
4 | * Copyright (c) 2008 Freescale Semiconductor | ||
5 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify | ||
8 | * it under the terms of the GNU General Public License as published by | ||
9 | * the Free Software Foundation; either version 2 of the License, or | ||
10 | * (at your option) any later version. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU General Public License | ||
18 | * along with this program; if not, write to the Free Software | ||
19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
20 | */ | ||
21 | #define REGS_USBPHY_BASE (STMP3XXX_REGS_BASE + 0x7C000) | ||
22 | |||
23 | #define HW_USBPHY_PWD 0x0 | ||
24 | |||
25 | #define HW_USBPHY_CTRL 0x30 | ||
26 | #define BM_USBPHY_CTRL_ENHSPRECHARGEXMIT 0x00000001 | ||
27 | #define BP_USBPHY_CTRL_ENHSPRECHARGEXMIT 0 | ||
28 | #define BM_USBPHY_CTRL_ENHOSTDISCONDETECT 0x00000002 | ||
29 | #define BM_USBPHY_CTRL_ENDEVPLUGINDETECT 0x00000010 | ||
30 | #define BM_USBPHY_CTRL_ENOTGIDDETECT 0x00000080 | ||
31 | #define BM_USBPHY_CTRL_ENIRQDEVPLUGIN 0x00000800 | ||
32 | #define BM_USBPHY_CTRL_CLKGATE 0x40000000 | ||
33 | #define BM_USBPHY_CTRL_SFTRST 0x80000000 | ||
34 | |||
35 | #define HW_USBPHY_STATUS 0x40 | ||
36 | #define BM_USBPHY_STATUS_DEVPLUGIN_STATUS 0x00000040 | ||
37 | #define BM_USBPHY_STATUS_OTGID_STATUS 0x00000100 | ||
diff --git a/arch/arm/mach-stmp37xx/stmp37xx.c b/arch/arm/mach-stmp37xx/stmp37xx.c new file mode 100644 index 000000000000..8c7d6fb191a3 --- /dev/null +++ b/arch/arm/mach-stmp37xx/stmp37xx.c | |||
@@ -0,0 +1,219 @@ | |||
1 | /* | ||
2 | * Freescale STMP37XX platform support | ||
3 | * | ||
4 | * Embedded Alley Solutions, Inc <source@embeddedalley.com> | ||
5 | * | ||
6 | * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved. | ||
7 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
8 | */ | ||
9 | |||
10 | /* | ||
11 | * The code contained herein is licensed under the GNU General Public | ||
12 | * License. You may obtain a copy of the GNU General Public License | ||
13 | * Version 2 or later at the following locations: | ||
14 | * | ||
15 | * http://www.opensource.org/licenses/gpl-license.html | ||
16 | * http://www.gnu.org/copyleft/gpl.html | ||
17 | */ | ||
18 | #include <linux/types.h> | ||
19 | #include <linux/kernel.h> | ||
20 | #include <linux/init.h> | ||
21 | #include <linux/device.h> | ||
22 | #include <linux/platform_device.h> | ||
23 | #include <linux/irq.h> | ||
24 | #include <linux/io.h> | ||
25 | |||
26 | #include <asm/setup.h> | ||
27 | #include <asm/mach-types.h> | ||
28 | |||
29 | #include <asm/mach/arch.h> | ||
30 | #include <asm/mach/irq.h> | ||
31 | #include <asm/mach/map.h> | ||
32 | #include <asm/mach/time.h> | ||
33 | |||
34 | #include <mach/stmp3xxx.h> | ||
35 | #include <mach/dma.h> | ||
36 | |||
37 | #include <mach/platform.h> | ||
38 | #include <mach/regs-icoll.h> | ||
39 | #include <mach/regs-apbh.h> | ||
40 | #include <mach/regs-apbx.h> | ||
41 | #include "stmp37xx.h" | ||
42 | |||
43 | /* | ||
44 | * IRQ handling | ||
45 | */ | ||
46 | static void stmp37xx_ack_irq(unsigned int irq) | ||
47 | { | ||
48 | /* Disable IRQ */ | ||
49 | stmp3xxx_clearl(0x04 << ((irq % 4) * 8), | ||
50 | REGS_ICOLL_BASE + HW_ICOLL_PRIORITYn + irq / 4 * 0x10); | ||
51 | |||
52 | /* ACK current interrupt */ | ||
53 | __raw_writel(1, REGS_ICOLL_BASE + HW_ICOLL_LEVELACK); | ||
54 | |||
55 | /* Barrier */ | ||
56 | (void)__raw_readl(REGS_ICOLL_BASE + HW_ICOLL_STAT); | ||
57 | } | ||
58 | |||
59 | static void stmp37xx_mask_irq(unsigned int irq) | ||
60 | { | ||
61 | /* IRQ disable */ | ||
62 | stmp3xxx_clearl(0x04 << ((irq % 4) * 8), | ||
63 | REGS_ICOLL_BASE + HW_ICOLL_PRIORITYn + irq / 4 * 0x10); | ||
64 | } | ||
65 | |||
66 | static void stmp37xx_unmask_irq(unsigned int irq) | ||
67 | { | ||
68 | /* IRQ enable */ | ||
69 | stmp3xxx_setl(0x04 << ((irq % 4) * 8), | ||
70 | REGS_ICOLL_BASE + HW_ICOLL_PRIORITYn + irq / 4 * 0x10); | ||
71 | } | ||
72 | |||
73 | static struct irq_chip stmp37xx_chip = { | ||
74 | .ack = stmp37xx_ack_irq, | ||
75 | .mask = stmp37xx_mask_irq, | ||
76 | .unmask = stmp37xx_unmask_irq, | ||
77 | }; | ||
78 | |||
79 | void __init stmp37xx_init_irq(void) | ||
80 | { | ||
81 | stmp3xxx_init_irq(&stmp37xx_chip); | ||
82 | } | ||
83 | |||
84 | /* | ||
85 | * DMA interrupt handling | ||
86 | */ | ||
87 | void stmp3xxx_arch_dma_enable_interrupt(int channel) | ||
88 | { | ||
89 | switch (STMP3XXX_DMA_BUS(channel)) { | ||
90 | case STMP3XXX_BUS_APBH: | ||
91 | stmp3xxx_setl(1 << (8 + STMP3XXX_DMA_CHANNEL(channel)), | ||
92 | REGS_APBH_BASE + HW_APBH_CTRL1); | ||
93 | break; | ||
94 | |||
95 | case STMP3XXX_BUS_APBX: | ||
96 | stmp3xxx_setl(1 << (8 + STMP3XXX_DMA_CHANNEL(channel)), | ||
97 | REGS_APBX_BASE + HW_APBX_CTRL1); | ||
98 | break; | ||
99 | } | ||
100 | } | ||
101 | EXPORT_SYMBOL(stmp3xxx_arch_dma_enable_interrupt); | ||
102 | |||
103 | void stmp3xxx_arch_dma_clear_interrupt(int channel) | ||
104 | { | ||
105 | switch (STMP3XXX_DMA_BUS(channel)) { | ||
106 | case STMP3XXX_BUS_APBH: | ||
107 | stmp3xxx_clearl(1 << STMP3XXX_DMA_CHANNEL(channel), | ||
108 | REGS_APBH_BASE + HW_APBH_CTRL1); | ||
109 | break; | ||
110 | |||
111 | case STMP3XXX_BUS_APBX: | ||
112 | stmp3xxx_clearl(1 << STMP3XXX_DMA_CHANNEL(channel), | ||
113 | REGS_APBX_BASE + HW_APBX_CTRL1); | ||
114 | break; | ||
115 | } | ||
116 | } | ||
117 | EXPORT_SYMBOL(stmp3xxx_arch_dma_clear_interrupt); | ||
118 | |||
119 | int stmp3xxx_arch_dma_is_interrupt(int channel) | ||
120 | { | ||
121 | int r = 0; | ||
122 | |||
123 | switch (STMP3XXX_DMA_BUS(channel)) { | ||
124 | case STMP3XXX_BUS_APBH: | ||
125 | r = __raw_readl(REGS_APBH_BASE + HW_APBH_CTRL1) & | ||
126 | (1 << STMP3XXX_DMA_CHANNEL(channel)); | ||
127 | break; | ||
128 | |||
129 | case STMP3XXX_BUS_APBX: | ||
130 | r = __raw_readl(REGS_APBH_BASE + HW_APBH_CTRL1) & | ||
131 | (1 << STMP3XXX_DMA_CHANNEL(channel)); | ||
132 | break; | ||
133 | } | ||
134 | return r; | ||
135 | } | ||
136 | EXPORT_SYMBOL(stmp3xxx_arch_dma_is_interrupt); | ||
137 | |||
138 | void stmp3xxx_arch_dma_reset_channel(int channel) | ||
139 | { | ||
140 | unsigned chbit = 1 << STMP3XXX_DMA_CHANNEL(channel); | ||
141 | |||
142 | switch (STMP3XXX_DMA_BUS(channel)) { | ||
143 | case STMP3XXX_BUS_APBH: | ||
144 | /* Reset channel and wait for it to complete */ | ||
145 | stmp3xxx_setl(chbit << BP_APBH_CTRL0_RESET_CHANNEL, | ||
146 | REGS_APBH_BASE + HW_APBH_CTRL0); | ||
147 | while (__raw_readl(REGS_APBH_BASE + HW_APBH_CTRL0) & | ||
148 | (chbit << BP_APBH_CTRL0_RESET_CHANNEL)) | ||
149 | cpu_relax(); | ||
150 | break; | ||
151 | |||
152 | case STMP3XXX_BUS_APBX: | ||
153 | stmp3xxx_setl(chbit << BP_APBX_CTRL0_RESET_CHANNEL, | ||
154 | REGS_APBX_BASE + HW_APBX_CTRL0); | ||
155 | while (__raw_readl(REGS_APBX_BASE + HW_APBX_CTRL0) & | ||
156 | (chbit << BP_APBX_CTRL0_RESET_CHANNEL)) | ||
157 | cpu_relax(); | ||
158 | break; | ||
159 | } | ||
160 | } | ||
161 | EXPORT_SYMBOL(stmp3xxx_arch_dma_reset_channel); | ||
162 | |||
163 | void stmp3xxx_arch_dma_freeze(int channel) | ||
164 | { | ||
165 | unsigned chbit = 1 << STMP3XXX_DMA_CHANNEL(channel); | ||
166 | |||
167 | switch (STMP3XXX_DMA_BUS(channel)) { | ||
168 | case STMP3XXX_BUS_APBH: | ||
169 | stmp3xxx_setl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0); | ||
170 | break; | ||
171 | case STMP3XXX_BUS_APBX: | ||
172 | stmp3xxx_setl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0); | ||
173 | break; | ||
174 | } | ||
175 | } | ||
176 | EXPORT_SYMBOL(stmp3xxx_arch_dma_freeze); | ||
177 | |||
178 | void stmp3xxx_arch_dma_unfreeze(int channel) | ||
179 | { | ||
180 | unsigned chbit = 1 << STMP3XXX_DMA_CHANNEL(channel); | ||
181 | |||
182 | switch (STMP3XXX_DMA_BUS(channel)) { | ||
183 | case STMP3XXX_BUS_APBH: | ||
184 | stmp3xxx_clearl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0); | ||
185 | break; | ||
186 | case STMP3XXX_BUS_APBX: | ||
187 | stmp3xxx_clearl(1 << chbit, REGS_APBH_BASE + HW_APBH_CTRL0); | ||
188 | break; | ||
189 | } | ||
190 | } | ||
191 | EXPORT_SYMBOL(stmp3xxx_arch_dma_unfreeze); | ||
192 | |||
193 | /* | ||
194 | * The registers are all very closely mapped, so we might as well map them all | ||
195 | * with a single mapping | ||
196 | * | ||
197 | * Logical Physical | ||
198 | * f0000000 80000000 On-chip registers | ||
199 | * f1000000 00000000 32k on-chip SRAM | ||
200 | */ | ||
201 | static struct map_desc stmp37xx_io_desc[] __initdata = { | ||
202 | { | ||
203 | .virtual = (u32)STMP3XXX_REGS_BASE, | ||
204 | .pfn = __phys_to_pfn(STMP3XXX_REGS_PHBASE), | ||
205 | .length = SZ_1M, | ||
206 | .type = MT_DEVICE | ||
207 | }, | ||
208 | { | ||
209 | .virtual = (u32)STMP3XXX_OCRAM_BASE, | ||
210 | .pfn = __phys_to_pfn(STMP3XXX_OCRAM_PHBASE), | ||
211 | .length = STMP3XXX_OCRAM_SIZE, | ||
212 | .type = MT_DEVICE, | ||
213 | }, | ||
214 | }; | ||
215 | |||
216 | void __init stmp37xx_map_io(void) | ||
217 | { | ||
218 | iotable_init(stmp37xx_io_desc, ARRAY_SIZE(stmp37xx_io_desc)); | ||
219 | } | ||
diff --git a/arch/arm/mach-stmp37xx/stmp37xx.h b/arch/arm/mach-stmp37xx/stmp37xx.h new file mode 100644 index 000000000000..0b75fb796a64 --- /dev/null +++ b/arch/arm/mach-stmp37xx/stmp37xx.h | |||
@@ -0,0 +1,24 @@ | |||
1 | /* | ||
2 | * Freescale STMP37XX/STMP378X internal functions and data declarations | ||
3 | * | ||
4 | * Embedded Alley Solutions, Inc <source@embeddedalley.com> | ||
5 | * | ||
6 | * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved. | ||
7 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
8 | */ | ||
9 | |||
10 | /* | ||
11 | * The code contained herein is licensed under the GNU General Public | ||
12 | * License. You may obtain a copy of the GNU General Public License | ||
13 | * Version 2 or later at the following locations: | ||
14 | * | ||
15 | * http://www.opensource.org/licenses/gpl-license.html | ||
16 | * http://www.gnu.org/copyleft/gpl.html | ||
17 | */ | ||
18 | #ifndef __MACH_STMP37XX_H | ||
19 | #define __MACH_STMP37XX_H | ||
20 | |||
21 | void stmp37xx_map_io(void); | ||
22 | void stmp37xx_init_irq(void); | ||
23 | |||
24 | #endif /* __MACH_STMP37XX_H */ | ||
diff --git a/arch/arm/mach-stmp37xx/stmp37xx_devb.c b/arch/arm/mach-stmp37xx/stmp37xx_devb.c new file mode 100644 index 000000000000..394f21ab59e6 --- /dev/null +++ b/arch/arm/mach-stmp37xx/stmp37xx_devb.c | |||
@@ -0,0 +1,101 @@ | |||
1 | /* | ||
2 | * Freescale STMP37XX development board support | ||
3 | * | ||
4 | * Embedded Alley Solutions, Inc <source@embeddedalley.com> | ||
5 | * | ||
6 | * Copyright 2008 Freescale Semiconductor, Inc. All Rights Reserved. | ||
7 | * Copyright 2008 Embedded Alley Solutions, Inc All Rights Reserved. | ||
8 | */ | ||
9 | |||
10 | /* | ||
11 | * The code contained herein is licensed under the GNU General Public | ||
12 | * License. You may obtain a copy of the GNU General Public License | ||
13 | * Version 2 or later at the following locations: | ||
14 | * | ||
15 | * http://www.opensource.org/licenses/gpl-license.html | ||
16 | * http://www.gnu.org/copyleft/gpl.html | ||
17 | */ | ||
18 | #include <linux/kernel.h> | ||
19 | #include <linux/init.h> | ||
20 | #include <linux/device.h> | ||
21 | #include <linux/platform_device.h> | ||
22 | #include <asm/setup.h> | ||
23 | #include <asm/mach-types.h> | ||
24 | #include <asm/mach/arch.h> | ||
25 | |||
26 | #include <mach/stmp3xxx.h> | ||
27 | #include <mach/pins.h> | ||
28 | #include <mach/pinmux.h> | ||
29 | #include "stmp37xx.h" | ||
30 | |||
31 | /* | ||
32 | * List of STMP37xx development board specific devices | ||
33 | */ | ||
34 | static struct platform_device *stmp37xx_devb_devices[] = { | ||
35 | &stmp3xxx_dbguart, | ||
36 | &stmp3xxx_appuart, | ||
37 | }; | ||
38 | |||
39 | static struct pin_desc dbguart_pins_0[] = { | ||
40 | { PINID_PWM0, PIN_FUN3, }, | ||
41 | { PINID_PWM1, PIN_FUN3, }, | ||
42 | }; | ||
43 | |||
44 | struct pin_desc appuart_pins_0[] = { | ||
45 | { PINID_UART2_CTS, PIN_FUN1, PIN_4MA, PIN_1_8V, 0, }, | ||
46 | { PINID_UART2_RTS, PIN_FUN1, PIN_4MA, PIN_1_8V, 0, }, | ||
47 | { PINID_UART2_RX, PIN_FUN1, PIN_4MA, PIN_1_8V, 0, }, | ||
48 | { PINID_UART2_TX, PIN_FUN1, PIN_4MA, PIN_1_8V, 0, }, | ||
49 | }; | ||
50 | |||
51 | static struct pin_group appuart_pins[] = { | ||
52 | [0] = { | ||
53 | .pins = appuart_pins_0, | ||
54 | .nr_pins = ARRAY_SIZE(appuart_pins_0), | ||
55 | }, | ||
56 | /* 37xx has the only app uart */ | ||
57 | }; | ||
58 | |||
59 | static struct pin_group dbguart_pins[] = { | ||
60 | [0] = { | ||
61 | .pins = dbguart_pins_0, | ||
62 | .nr_pins = ARRAY_SIZE(dbguart_pins_0), | ||
63 | }, | ||
64 | }; | ||
65 | |||
66 | static int dbguart_pins_control(int id, int request) | ||
67 | { | ||
68 | int r = 0; | ||
69 | |||
70 | if (request) | ||
71 | r = stmp3xxx_request_pin_group(&dbguart_pins[id], "debug uart"); | ||
72 | else | ||
73 | stmp3xxx_release_pin_group(&dbguart_pins[id], "debug uart"); | ||
74 | return r; | ||
75 | } | ||
76 | |||
77 | |||
78 | static void __init stmp37xx_devb_init(void) | ||
79 | { | ||
80 | stmp3xxx_pinmux_init(NR_REAL_IRQS); | ||
81 | |||
82 | /* Init STMP3xxx platform */ | ||
83 | stmp3xxx_init(); | ||
84 | |||
85 | stmp3xxx_dbguart.dev.platform_data = dbguart_pins_control; | ||
86 | stmp3xxx_appuart.dev.platform_data = appuart_pins; | ||
87 | |||
88 | /* Add STMP37xx development board devices */ | ||
89 | platform_add_devices(stmp37xx_devb_devices, | ||
90 | ARRAY_SIZE(stmp37xx_devb_devices)); | ||
91 | } | ||
92 | |||
93 | MACHINE_START(STMP37XX, "STMP37XX") | ||
94 | .phys_io = 0x80000000, | ||
95 | .io_pg_offst = ((0xf0000000) >> 18) & 0xfffc, | ||
96 | .boot_params = 0x40000100, | ||
97 | .map_io = stmp37xx_map_io, | ||
98 | .init_irq = stmp37xx_init_irq, | ||
99 | .timer = &stmp3xxx_timer, | ||
100 | .init_machine = stmp37xx_devb_init, | ||
101 | MACHINE_END | ||