diff options
author | dmitry pervushin <dpervushin@embeddedalley.com> | 2009-06-04 08:49:37 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2009-06-04 09:16:44 -0400 |
commit | a50808b6c4e0e25a72314391d70479447e3ce092 (patch) | |
tree | 6e5de7206277c7dfb9df1423d56c9f5a2b591f78 | |
parent | fc3fdfd632925990f14cffe314f5d90a2b0ae8f6 (diff) |
[ARM] 5538/1: Freescale STMP: 378n registers definition
Add register definitions for Freescale STMP 378n boards
Signed-off-by: dmitry pervushin <dpervushin@embeddedalley.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
27 files changed, 1920 insertions, 0 deletions
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-audioin.h b/arch/arm/mach-stmp378x/include/mach/regs-audioin.h new file mode 100644 index 000000000000..641ac6126f83 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-audioin.h | |||
@@ -0,0 +1,63 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define REGS_AUDIOIN_PHYS 0x8004C000 | ||
23 | #define REGS_AUDIOIN_SIZE 0x2000 | ||
24 | |||
25 | #define HW_AUDIOIN_CTRL 0x0 | ||
26 | #define BM_AUDIOIN_CTRL_RUN 0x00000001 | ||
27 | #define BP_AUDIOIN_CTRL_RUN 0 | ||
28 | #define BM_AUDIOIN_CTRL_FIFO_ERROR_IRQ_EN 0x00000002 | ||
29 | #define BM_AUDIOIN_CTRL_FIFO_OVERFLOW_IRQ 0x00000004 | ||
30 | #define BM_AUDIOIN_CTRL_FIFO_UNDERFLOW_IRQ 0x00000008 | ||
31 | #define BM_AUDIOIN_CTRL_WORD_LENGTH 0x00000020 | ||
32 | #define BM_AUDIOIN_CTRL_CLKGATE 0x40000000 | ||
33 | #define BM_AUDIOIN_CTRL_SFTRST 0x80000000 | ||
34 | |||
35 | #define HW_AUDIOIN_STAT 0x10 | ||
36 | |||
37 | #define HW_AUDIOIN_ADCSRR 0x20 | ||
38 | |||
39 | #define HW_AUDIOIN_ADCVOLUME 0x30 | ||
40 | #define BM_AUDIOIN_ADCVOLUME_VOLUME_RIGHT 0x000000FF | ||
41 | #define BP_AUDIOIN_ADCVOLUME_VOLUME_RIGHT 0 | ||
42 | #define BM_AUDIOIN_ADCVOLUME_VOLUME_LEFT 0x00FF0000 | ||
43 | #define BP_AUDIOIN_ADCVOLUME_VOLUME_LEFT 16 | ||
44 | |||
45 | #define HW_AUDIOIN_ADCDEBUG 0x40 | ||
46 | |||
47 | #define HW_AUDIOIN_ADCVOL 0x50 | ||
48 | #define BM_AUDIOIN_ADCVOL_GAIN_RIGHT 0x0000000F | ||
49 | #define BP_AUDIOIN_ADCVOL_GAIN_RIGHT 0 | ||
50 | #define BM_AUDIOIN_ADCVOL_SELECT_RIGHT 0x00000030 | ||
51 | #define BP_AUDIOIN_ADCVOL_SELECT_RIGHT 4 | ||
52 | #define BM_AUDIOIN_ADCVOL_GAIN_LEFT 0x00000F00 | ||
53 | #define BP_AUDIOIN_ADCVOL_GAIN_LEFT 8 | ||
54 | #define BM_AUDIOIN_ADCVOL_SELECT_LEFT 0x00003000 | ||
55 | #define BP_AUDIOIN_ADCVOL_SELECT_LEFT 12 | ||
56 | #define BM_AUDIOIN_ADCVOL_MUTE 0x01000000 | ||
57 | |||
58 | #define HW_AUDIOIN_MICLINE 0x60 | ||
59 | |||
60 | #define HW_AUDIOIN_ANACLKCTRL 0x70 | ||
61 | #define BM_AUDIOIN_ANACLKCTRL_CLKGATE 0x80000000 | ||
62 | |||
63 | #define HW_AUDIOIN_DATA 0x80 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-audioout.h b/arch/arm/mach-stmp378x/include/mach/regs-audioout.h new file mode 100644 index 000000000000..f533e23694a0 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-audioout.h | |||
@@ -0,0 +1,104 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define REGS_AUDIOOUT_PHYS 0x80048000 | ||
23 | #define REGS_AUDIOOUT_SIZE 0x2000 | ||
24 | |||
25 | #define HW_AUDIOOUT_CTRL 0x0 | ||
26 | #define BM_AUDIOOUT_CTRL_RUN 0x00000001 | ||
27 | #define BP_AUDIOOUT_CTRL_RUN 0 | ||
28 | #define BM_AUDIOOUT_CTRL_FIFO_ERROR_IRQ_EN 0x00000002 | ||
29 | #define BM_AUDIOOUT_CTRL_FIFO_OVERFLOW_IRQ 0x00000004 | ||
30 | #define BM_AUDIOOUT_CTRL_FIFO_UNDERFLOW_IRQ 0x00000008 | ||
31 | #define BM_AUDIOOUT_CTRL_WORD_LENGTH 0x00000040 | ||
32 | #define BM_AUDIOOUT_CTRL_CLKGATE 0x40000000 | ||
33 | #define BM_AUDIOOUT_CTRL_SFTRST 0x80000000 | ||
34 | |||
35 | #define HW_AUDIOOUT_STAT 0x10 | ||
36 | |||
37 | #define HW_AUDIOOUT_DACSRR 0x20 | ||
38 | #define BM_AUDIOOUT_DACSRR_SRC_FRAC 0x00001FFF | ||
39 | #define BP_AUDIOOUT_DACSRR_SRC_FRAC 0 | ||
40 | #define BM_AUDIOOUT_DACSRR_SRC_INT 0x001F0000 | ||
41 | #define BP_AUDIOOUT_DACSRR_SRC_INT 16 | ||
42 | #define BM_AUDIOOUT_DACSRR_SRC_HOLD 0x07000000 | ||
43 | #define BP_AUDIOOUT_DACSRR_SRC_HOLD 24 | ||
44 | #define BM_AUDIOOUT_DACSRR_BASEMULT 0x70000000 | ||
45 | #define BP_AUDIOOUT_DACSRR_BASEMULT 28 | ||
46 | |||
47 | #define HW_AUDIOOUT_DACVOLUME 0x30 | ||
48 | #define BM_AUDIOOUT_DACVOLUME_MUTE_RIGHT 0x00000100 | ||
49 | #define BM_AUDIOOUT_DACVOLUME_MUTE_LEFT 0x01000000 | ||
50 | #define BM_AUDIOOUT_DACVOLUME_EN_ZCD 0x02000000 | ||
51 | |||
52 | #define HW_AUDIOOUT_DACDEBUG 0x40 | ||
53 | |||
54 | #define HW_AUDIOOUT_HPVOL 0x50 | ||
55 | #define BM_AUDIOOUT_HPVOL_MUTE 0x01000000 | ||
56 | #define BM_AUDIOOUT_HPVOL_EN_MSTR_ZCD 0x02000000 | ||
57 | |||
58 | #define HW_AUDIOOUT_PWRDN 0x70 | ||
59 | #define BM_AUDIOOUT_PWRDN_HEADPHONE 0x00000001 | ||
60 | #define BP_AUDIOOUT_PWRDN_HEADPHONE 0 | ||
61 | #define BM_AUDIOOUT_PWRDN_CAPLESS 0x00000010 | ||
62 | #define BM_AUDIOOUT_PWRDN_ADC 0x00000100 | ||
63 | #define BM_AUDIOOUT_PWRDN_DAC 0x00001000 | ||
64 | #define BM_AUDIOOUT_PWRDN_RIGHT_ADC 0x00010000 | ||
65 | #define BM_AUDIOOUT_PWRDN_SPEAKER 0x01000000 | ||
66 | |||
67 | #define HW_AUDIOOUT_REFCTRL 0x80 | ||
68 | #define BM_AUDIOOUT_REFCTRL_VAG_VAL 0x000000F0 | ||
69 | #define BP_AUDIOOUT_REFCTRL_VAG_VAL 4 | ||
70 | #define BM_AUDIOOUT_REFCTRL_ADC_REFVAL 0x00000F00 | ||
71 | #define BP_AUDIOOUT_REFCTRL_ADC_REFVAL 8 | ||
72 | #define BM_AUDIOOUT_REFCTRL_ADJ_VAG 0x00001000 | ||
73 | #define BM_AUDIOOUT_REFCTRL_ADJ_ADC 0x00002000 | ||
74 | #define BM_AUDIOOUT_REFCTRL_BIAS_CTRL 0x00030000 | ||
75 | #define BP_AUDIOOUT_REFCTRL_BIAS_CTRL 16 | ||
76 | #define BM_AUDIOOUT_REFCTRL_LOW_PWR 0x00080000 | ||
77 | #define BM_AUDIOOUT_REFCTRL_VBG_ADJ 0x00700000 | ||
78 | #define BP_AUDIOOUT_REFCTRL_VBG_ADJ 20 | ||
79 | #define BM_AUDIOOUT_REFCTRL_XTAL_BGR_BIAS 0x01000000 | ||
80 | #define BM_AUDIOOUT_REFCTRL_RAISE_REF 0x02000000 | ||
81 | |||
82 | #define HW_AUDIOOUT_ANACTRL 0x90 | ||
83 | #define BM_AUDIOOUT_ANACTRL_HP_CLASSAB 0x00000010 | ||
84 | #define BM_AUDIOOUT_ANACTRL_HP_HOLD_GND 0x00000020 | ||
85 | |||
86 | #define HW_AUDIOOUT_TEST 0xA0 | ||
87 | #define BM_AUDIOOUT_TEST_HP_I1_ADJ 0x00C00000 | ||
88 | #define BP_AUDIOOUT_TEST_HP_I1_ADJ 22 | ||
89 | |||
90 | #define HW_AUDIOOUT_BISTCTRL 0xB0 | ||
91 | |||
92 | #define HW_AUDIOOUT_BISTSTAT0 0xC0 | ||
93 | |||
94 | #define HW_AUDIOOUT_BISTSTAT1 0xD0 | ||
95 | |||
96 | #define HW_AUDIOOUT_ANACLKCTRL 0xE0 | ||
97 | #define BM_AUDIOOUT_ANACLKCTRL_CLKGATE 0x80000000 | ||
98 | |||
99 | #define HW_AUDIOOUT_DATA 0xF0 | ||
100 | |||
101 | #define HW_AUDIOOUT_SPEAKERCTRL 0x100 | ||
102 | #define BM_AUDIOOUT_SPEAKERCTRL_MUTE 0x01000000 | ||
103 | |||
104 | #define HW_AUDIOOUT_VERSION 0x200 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-bch.h b/arch/arm/mach-stmp378x/include/mach/regs-bch.h new file mode 100644 index 000000000000..532d24650717 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-bch.h | |||
@@ -0,0 +1,56 @@ | |||
1 | /* | ||
2 | * stmp378x: BCH 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_BCH_BASE (STMP3XXX_REGS_BASE + 0xA000) | ||
22 | #define REGS_BCH_PHYS 0x8000A000 | ||
23 | #define REGS_BCH_SIZE 0x2000 | ||
24 | |||
25 | #define HW_BCH_CTRL 0x0 | ||
26 | #define BM_BCH_CTRL_COMPLETE_IRQ 0x00000001 | ||
27 | #define BP_BCH_CTRL_COMPLETE_IRQ 0 | ||
28 | #define BM_BCH_CTRL_COMPLETE_IRQ_EN 0x00000100 | ||
29 | |||
30 | #define HW_BCH_STATUS0 0x10 | ||
31 | #define BM_BCH_STATUS0_UNCORRECTABLE 0x00000004 | ||
32 | #define BM_BCH_STATUS0_CORRECTED 0x00000008 | ||
33 | #define BM_BCH_STATUS0_STATUS_BLK0 0x0000FF00 | ||
34 | #define BP_BCH_STATUS0_STATUS_BLK0 8 | ||
35 | #define BM_BCH_STATUS0_COMPLETED_CE 0x000F0000 | ||
36 | #define BP_BCH_STATUS0_COMPLETED_CE 16 | ||
37 | |||
38 | #define HW_BCH_LAYOUTSELECT 0x70 | ||
39 | |||
40 | #define HW_BCH_FLASH0LAYOUT0 0x80 | ||
41 | #define BM_BCH_FLASH0LAYOUT0_DATA0_SIZE 0x00000FFF | ||
42 | #define BP_BCH_FLASH0LAYOUT0_DATA0_SIZE 0 | ||
43 | #define BM_BCH_FLASH0LAYOUT0_ECC0 0x0000F000 | ||
44 | #define BP_BCH_FLASH0LAYOUT0_ECC0 12 | ||
45 | #define BM_BCH_FLASH0LAYOUT0_META_SIZE 0x00FF0000 | ||
46 | #define BP_BCH_FLASH0LAYOUT0_META_SIZE 16 | ||
47 | #define BM_BCH_FLASH0LAYOUT0_NBLOCKS 0xFF000000 | ||
48 | #define BP_BCH_FLASH0LAYOUT0_NBLOCKS 24 | ||
49 | #define BM_BCH_FLASH0LAYOUT1_DATAN_SIZE 0x00000FFF | ||
50 | #define BP_BCH_FLASH0LAYOUT1_DATAN_SIZE 0 | ||
51 | #define BM_BCH_FLASH0LAYOUT1_ECCN 0x0000F000 | ||
52 | #define BP_BCH_FLASH0LAYOUT1_ECCN 12 | ||
53 | #define BM_BCH_FLASH0LAYOUT1_PAGE_SIZE 0xFFFF0000 | ||
54 | #define BP_BCH_FLASH0LAYOUT1_PAGE_SIZE 16 | ||
55 | |||
56 | #define HW_BCH_BLOCKNAME 0x150 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-dcp.h b/arch/arm/mach-stmp378x/include/mach/regs-dcp.h new file mode 100644 index 000000000000..fdedd00c0e28 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-dcp.h | |||
@@ -0,0 +1,87 @@ | |||
1 | /* | ||
2 | * stmp378x: DCP 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_DCP_BASE (STMP3XXX_REGS_BASE + 0x28000) | ||
22 | #define REGS_DCP_PHYS 0x80028000 | ||
23 | #define REGS_DCP_SIZE 0x2000 | ||
24 | |||
25 | #define HW_DCP_CTRL 0x0 | ||
26 | #define BM_DCP_CTRL_CHANNEL_INTERRUPT_ENABLE 0x000000FF | ||
27 | #define BP_DCP_CTRL_CHANNEL_INTERRUPT_ENABLE 0 | ||
28 | #define BM_DCP_CTRL_ENABLE_CONTEXT_CACHING 0x00400000 | ||
29 | #define BM_DCP_CTRL_GATHER_RESIDUAL_WRITES 0x00800000 | ||
30 | #define BM_DCP_CTRL_CLKGATE 0x40000000 | ||
31 | #define BM_DCP_CTRL_SFTRST 0x80000000 | ||
32 | |||
33 | #define HW_DCP_STAT 0x10 | ||
34 | #define BM_DCP_STAT_IRQ 0x0000000F | ||
35 | #define BP_DCP_STAT_IRQ 0 | ||
36 | |||
37 | #define HW_DCP_CHANNELCTRL 0x20 | ||
38 | #define BM_DCP_CHANNELCTRL_ENABLE_CHANNEL 0x000000FF | ||
39 | #define BP_DCP_CHANNELCTRL_ENABLE_CHANNEL 0 | ||
40 | |||
41 | #define HW_DCP_CONTEXT 0x50 | ||
42 | #define BM_DCP_PACKET1_INTERRUPT 0x00000001 | ||
43 | #define BP_DCP_PACKET1_INTERRUPT 0 | ||
44 | #define BM_DCP_PACKET1_DECR_SEMAPHORE 0x00000002 | ||
45 | #define BM_DCP_PACKET1_CHAIN 0x00000004 | ||
46 | #define BM_DCP_PACKET1_CHAIN_CONTIGUOUS 0x00000008 | ||
47 | #define BM_DCP_PACKET1_ENABLE_CIPHER 0x00000020 | ||
48 | #define BM_DCP_PACKET1_ENABLE_HASH 0x00000040 | ||
49 | #define BM_DCP_PACKET1_CIPHER_ENCRYPT 0x00000100 | ||
50 | #define BM_DCP_PACKET1_CIPHER_INIT 0x00000200 | ||
51 | #define BM_DCP_PACKET1_OTP_KEY 0x00000400 | ||
52 | #define BM_DCP_PACKET1_PAYLOAD_KEY 0x00000800 | ||
53 | #define BM_DCP_PACKET1_HASH_INIT 0x00001000 | ||
54 | #define BM_DCP_PACKET1_HASH_TERM 0x00002000 | ||
55 | #define BM_DCP_PACKET2_CIPHER_SELECT 0x0000000F | ||
56 | #define BP_DCP_PACKET2_CIPHER_SELECT 0 | ||
57 | #define BM_DCP_PACKET2_CIPHER_MODE 0x000000F0 | ||
58 | #define BP_DCP_PACKET2_CIPHER_MODE 4 | ||
59 | #define BM_DCP_PACKET2_KEY_SELECT 0x0000FF00 | ||
60 | #define BP_DCP_PACKET2_KEY_SELECT 8 | ||
61 | #define BM_DCP_PACKET2_HASH_SELECT 0x000F0000 | ||
62 | #define BP_DCP_PACKET2_HASH_SELECT 16 | ||
63 | #define BM_DCP_PACKET2_CIPHER_CFG 0xFF000000 | ||
64 | #define BP_DCP_PACKET2_CIPHER_CFG 24 | ||
65 | |||
66 | #define HW_DCP_CH0CMDPTR (0x100 + 0 * 0x40) | ||
67 | #define HW_DCP_CH1CMDPTR (0x100 + 1 * 0x40) | ||
68 | #define HW_DCP_CH2CMDPTR (0x100 + 2 * 0x40) | ||
69 | #define HW_DCP_CH3CMDPTR (0x100 + 3 * 0x40) | ||
70 | |||
71 | #define HW_DCP_CHnCMDPTR 0x100 | ||
72 | |||
73 | #define HW_DCP_CH0SEMA (0x110 + 0 * 0x40) | ||
74 | #define HW_DCP_CH1SEMA (0x110 + 1 * 0x40) | ||
75 | #define HW_DCP_CH2SEMA (0x110 + 2 * 0x40) | ||
76 | #define HW_DCP_CH3SEMA (0x110 + 3 * 0x40) | ||
77 | |||
78 | #define HW_DCP_CHnSEMA 0x110 | ||
79 | #define BM_DCP_CHnSEMA_INCREMENT 0x000000FF | ||
80 | #define BP_DCP_CHnSEMA_INCREMENT 0 | ||
81 | |||
82 | #define HW_DCP_CH0STAT (0x120 + 0 * 0x40) | ||
83 | #define HW_DCP_CH1STAT (0x120 + 1 * 0x40) | ||
84 | #define HW_DCP_CH2STAT (0x120 + 2 * 0x40) | ||
85 | #define HW_DCP_CH3STAT (0x120 + 3 * 0x40) | ||
86 | |||
87 | #define HW_DCP_CHnSTAT 0x120 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-digctl.h b/arch/arm/mach-stmp378x/include/mach/regs-digctl.h new file mode 100644 index 000000000000..5293005523b3 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-digctl.h | |||
@@ -0,0 +1,38 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define REGS_DIGCTL_PHYS 0x8001C000 | ||
23 | #define REGS_DIGCTL_SIZE 0x2000 | ||
24 | |||
25 | #define HW_DIGCTL_CTRL 0x0 | ||
26 | #define BM_DIGCTL_CTRL_USB_CLKGATE 0x00000004 | ||
27 | |||
28 | #define HW_DIGCTL_ARMCACHE 0x2B0 | ||
29 | #define BM_DIGCTL_ARMCACHE_ITAG_SS 0x00000003 | ||
30 | #define BP_DIGCTL_ARMCACHE_ITAG_SS 0 | ||
31 | #define BM_DIGCTL_ARMCACHE_DTAG_SS 0x00000030 | ||
32 | #define BP_DIGCTL_ARMCACHE_DTAG_SS 4 | ||
33 | #define BM_DIGCTL_ARMCACHE_CACHE_SS 0x00000300 | ||
34 | #define BP_DIGCTL_ARMCACHE_CACHE_SS 8 | ||
35 | #define BM_DIGCTL_ARMCACHE_DRTY_SS 0x00003000 | ||
36 | #define BP_DIGCTL_ARMCACHE_DRTY_SS 12 | ||
37 | #define BM_DIGCTL_ARMCACHE_VALID_SS 0x00030000 | ||
38 | #define BP_DIGCTL_ARMCACHE_VALID_SS 16 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-dram.h b/arch/arm/mach-stmp378x/include/mach/regs-dram.h new file mode 100644 index 000000000000..02851431677c --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-dram.h | |||
@@ -0,0 +1,27 @@ | |||
1 | /* | ||
2 | * stmp378x: DRAM 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_DRAM_BASE (STMP3XXX_REGS_BASE + 0xE0000) | ||
22 | #define REGS_DRAM_PHYS 0x800E0000 | ||
23 | #define REGS_DRAM_SIZE 0x2000 | ||
24 | |||
25 | #define HW_DRAM_CTL06 0x18 | ||
26 | |||
27 | #define HW_DRAM_CTL08 0x20 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-dri.h b/arch/arm/mach-stmp378x/include/mach/regs-dri.h new file mode 100644 index 000000000000..da25f7e397e5 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-dri.h | |||
@@ -0,0 +1,45 @@ | |||
1 | /* | ||
2 | * stmp378x: DRI 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_DRI_BASE (STMP3XXX_REGS_BASE + 0x74000) | ||
22 | #define REGS_DRI_PHYS 0x80074000 | ||
23 | #define REGS_DRI_SIZE 0x2000 | ||
24 | |||
25 | #define HW_DRI_CTRL 0x0 | ||
26 | #define BM_DRI_CTRL_RUN 0x00000001 | ||
27 | #define BP_DRI_CTRL_RUN 0 | ||
28 | #define BM_DRI_CTRL_ATTENTION_IRQ 0x00000002 | ||
29 | #define BM_DRI_CTRL_PILOT_SYNC_LOSS_IRQ 0x00000004 | ||
30 | #define BM_DRI_CTRL_OVERFLOW_IRQ 0x00000008 | ||
31 | #define BM_DRI_CTRL_ATTENTION_IRQ_EN 0x00000200 | ||
32 | #define BM_DRI_CTRL_PILOT_SYNC_LOSS_IRQ_EN 0x00000400 | ||
33 | #define BM_DRI_CTRL_OVERFLOW_IRQ_EN 0x00000800 | ||
34 | #define BM_DRI_CTRL_REACQUIRE_PHASE 0x00008000 | ||
35 | #define BM_DRI_CTRL_STOP_ON_PILOT_ERROR 0x02000000 | ||
36 | #define BM_DRI_CTRL_STOP_ON_OFLOW_ERROR 0x04000000 | ||
37 | #define BM_DRI_CTRL_ENABLE_INPUTS 0x20000000 | ||
38 | #define BM_DRI_CTRL_CLKGATE 0x40000000 | ||
39 | #define BM_DRI_CTRL_SFTRST 0x80000000 | ||
40 | |||
41 | #define HW_DRI_TIMING 0x10 | ||
42 | #define BM_DRI_TIMING_GAP_DETECTION_INTERVAL 0x000000FF | ||
43 | #define BP_DRI_TIMING_GAP_DETECTION_INTERVAL 0 | ||
44 | #define BM_DRI_TIMING_PILOT_REP_RATE 0x000F0000 | ||
45 | #define BP_DRI_TIMING_PILOT_REP_RATE 16 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-ecc8.h b/arch/arm/mach-stmp378x/include/mach/regs-ecc8.h new file mode 100644 index 000000000000..cc353bec331b --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-ecc8.h | |||
@@ -0,0 +1,39 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define REGS_ECC8_PHYS 0x80008000 | ||
23 | #define REGS_ECC8_SIZE 0x2000 | ||
24 | |||
25 | #define HW_ECC8_CTRL 0x0 | ||
26 | #define BM_ECC8_CTRL_COMPLETE_IRQ 0x00000001 | ||
27 | #define BP_ECC8_CTRL_COMPLETE_IRQ 0 | ||
28 | #define BM_ECC8_CTRL_COMPLETE_IRQ_EN 0x00000100 | ||
29 | #define BM_ECC8_CTRL_AHBM_SFTRST 0x20000000 | ||
30 | |||
31 | #define HW_ECC8_STATUS0 0x10 | ||
32 | #define BM_ECC8_STATUS0_UNCORRECTABLE 0x00000004 | ||
33 | #define BM_ECC8_STATUS0_CORRECTED 0x00000008 | ||
34 | #define BM_ECC8_STATUS0_STATUS_AUX 0x00000F00 | ||
35 | #define BP_ECC8_STATUS0_STATUS_AUX 8 | ||
36 | #define BM_ECC8_STATUS0_COMPLETED_CE 0x000F0000 | ||
37 | #define BP_ECC8_STATUS0_COMPLETED_CE 16 | ||
38 | |||
39 | #define HW_ECC8_STATUS1 0x20 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-emi.h b/arch/arm/mach-stmp378x/include/mach/regs-emi.h new file mode 100644 index 000000000000..98773fc33d7b --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-emi.h | |||
@@ -0,0 +1,25 @@ | |||
1 | /* | ||
2 | * stmp378x: EMI 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_EMI_BASE (STMP3XXX_REGS_BASE + 0x20000) | ||
22 | #define REGS_EMI_PHYS 0x80020000 | ||
23 | #define REGS_EMI_SIZE 0x2000 | ||
24 | |||
25 | #define HW_EMI_STAT 0x10 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-gpmi.h b/arch/arm/mach-stmp378x/include/mach/regs-gpmi.h new file mode 100644 index 000000000000..2cc8bbe91687 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-gpmi.h | |||
@@ -0,0 +1,78 @@ | |||
1 | /* | ||
2 | * stmp378x: 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_ADDRESS 0x000E0000 | ||
33 | #define BP_GPMI_CTRL0_ADDRESS 17 | ||
34 | #define BV_GPMI_CTRL0_ADDRESS__NAND_DATA 0x0 | ||
35 | #define BV_GPMI_CTRL0_ADDRESS__NAND_CLE 0x1 | ||
36 | #define BV_GPMI_CTRL0_ADDRESS__NAND_ALE 0x2 | ||
37 | #define BM_GPMI_CTRL0_ADDRESS_INCREMENT 0x00010000 | ||
38 | #define BM_GPMI_CTRL0_COMMAND_MODE 0x03000000 | ||
39 | #define BP_GPMI_CTRL0_COMMAND_MODE 24 | ||
40 | #define BV_GPMI_CTRL0_COMMAND_MODE__WRITE 0x0 | ||
41 | #define BV_GPMI_CTRL0_COMMAND_MODE__READ 0x1 | ||
42 | #define BV_GPMI_CTRL0_COMMAND_MODE__READ_AND_COMPARE 0x2 | ||
43 | #define BV_GPMI_CTRL0_COMMAND_MODE__WAIT_FOR_READY 0x3 | ||
44 | #define BM_GPMI_CTRL0_RUN 0x20000000 | ||
45 | #define BM_GPMI_CTRL0_CLKGATE 0x40000000 | ||
46 | #define BM_GPMI_CTRL0_SFTRST 0x80000000 | ||
47 | #define BM_GPMI_ECCCTRL_BUFFER_MASK 0x000001FF | ||
48 | #define BP_GPMI_ECCCTRL_BUFFER_MASK 0 | ||
49 | #define BM_GPMI_ECCCTRL_ENABLE_ECC 0x00001000 | ||
50 | #define BM_GPMI_ECCCTRL_ECC_CMD 0x00006000 | ||
51 | #define BP_GPMI_ECCCTRL_ECC_CMD 13 | ||
52 | #define BV_GPMI_ECCCTRL_ECC_CMD__DECODE_4_BIT 0 | ||
53 | #define BV_GPMI_ECCCTRL_ECC_CMD__ENCODE_4_BIT 1 | ||
54 | #define BV_GPMI_ECCCTRL_ECC_CMD__DECODE_8_BIT 2 | ||
55 | #define BV_GPMI_ECCCTRL_ECC_CMD__ENCODE_8_BIT 3 | ||
56 | |||
57 | #define HW_GPMI_CTRL1 0x60 | ||
58 | #define BM_GPMI_CTRL1_GPMI_MODE 0x00000001 | ||
59 | #define BP_GPMI_CTRL1_GPMI_MODE 0 | ||
60 | #define BM_GPMI_CTRL1_ATA_IRQRDY_POLARITY 0x00000004 | ||
61 | #define BM_GPMI_CTRL1_DEV_RESET 0x00000008 | ||
62 | #define BM_GPMI_CTRL1_TIMEOUT_IRQ 0x00000200 | ||
63 | #define BM_GPMI_CTRL1_DEV_IRQ 0x00000400 | ||
64 | #define BM_GPMI_CTRL1_RDN_DELAY 0x0000F000 | ||
65 | #define BP_GPMI_CTRL1_RDN_DELAY 12 | ||
66 | #define BM_GPMI_CTRL1_BCH_MODE 0x00040000 | ||
67 | |||
68 | #define HW_GPMI_TIMING0 0x70 | ||
69 | #define BM_GPMI_TIMING0_DATA_SETUP 0x000000FF | ||
70 | #define BP_GPMI_TIMING0_DATA_SETUP 0 | ||
71 | #define BM_GPMI_TIMING0_DATA_HOLD 0x0000FF00 | ||
72 | #define BP_GPMI_TIMING0_DATA_HOLD 8 | ||
73 | #define BM_GPMI_TIMING0_ADDRESS_SETUP 0x00FF0000 | ||
74 | #define BP_GPMI_TIMING0_ADDRESS_SETUP 16 | ||
75 | |||
76 | #define HW_GPMI_TIMING1 0x80 | ||
77 | #define BM_GPMI_TIMING1_DEVICE_BUSY_TIMEOUT 0xFFFF0000 | ||
78 | #define BP_GPMI_TIMING1_DEVICE_BUSY_TIMEOUT 16 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-i2c.h b/arch/arm/mach-stmp378x/include/mach/regs-i2c.h new file mode 100644 index 000000000000..13a234c99433 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-i2c.h | |||
@@ -0,0 +1,55 @@ | |||
1 | /* | ||
2 | * stmp378x: 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-stmp378x/include/mach/regs-ir.h b/arch/arm/mach-stmp378x/include/mach/regs-ir.h new file mode 100644 index 000000000000..a5b4ef10fab8 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-ir.h | |||
@@ -0,0 +1,23 @@ | |||
1 | /* | ||
2 | * stmp378x: IR 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_IR_BASE (STMP3XXX_REGS_BASE + 0x78000) | ||
22 | #define REGS_IR_PHYS 0x80078000 | ||
23 | #define REGS_IR_SIZE 0x2000 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-lcdif.h b/arch/arm/mach-stmp378x/include/mach/regs-lcdif.h new file mode 100644 index 000000000000..9cdbef4badc3 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-lcdif.h | |||
@@ -0,0 +1,195 @@ | |||
1 | /* | ||
2 | * stmp378x: 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_RUN 0x00000001 | ||
27 | #define BP_LCDIF_CTRL_RUN 0 | ||
28 | #define BM_LCDIF_CTRL_LCDIF_MASTER 0x00000020 | ||
29 | #define BM_LCDIF_CTRL_RGB_TO_YCBCR422_CSC 0x00000080 | ||
30 | #define BM_LCDIF_CTRL_WORD_LENGTH 0x00000300 | ||
31 | #define BP_LCDIF_CTRL_WORD_LENGTH 8 | ||
32 | #define BM_LCDIF_CTRL_LCD_DATABUS_WIDTH 0x00000C00 | ||
33 | #define BP_LCDIF_CTRL_LCD_DATABUS_WIDTH 10 | ||
34 | #define BM_LCDIF_CTRL_INPUT_DATA_SWIZZLE 0x0000C000 | ||
35 | #define BP_LCDIF_CTRL_INPUT_DATA_SWIZZLE 14 | ||
36 | #define BM_LCDIF_CTRL_DATA_SELECT 0x00010000 | ||
37 | #define BM_LCDIF_CTRL_DOTCLK_MODE 0x00020000 | ||
38 | #define BM_LCDIF_CTRL_VSYNC_MODE 0x00040000 | ||
39 | #define BM_LCDIF_CTRL_BYPASS_COUNT 0x00080000 | ||
40 | #define BM_LCDIF_CTRL_DVI_MODE 0x00100000 | ||
41 | #define BM_LCDIF_CTRL_SHIFT_NUM_BITS 0x03E00000 | ||
42 | #define BP_LCDIF_CTRL_SHIFT_NUM_BITS 21 | ||
43 | #define BM_LCDIF_CTRL_DATA_SHIFT_DIR 0x04000000 | ||
44 | #define BM_LCDIF_CTRL_WAIT_FOR_VSYNC_EDGE 0x08000000 | ||
45 | #define BM_LCDIF_CTRL_CLKGATE 0x40000000 | ||
46 | #define BM_LCDIF_CTRL_SFTRST 0x80000000 | ||
47 | |||
48 | #define HW_LCDIF_CTRL1 0x10 | ||
49 | #define BM_LCDIF_CTRL1_RESET 0x00000001 | ||
50 | #define BP_LCDIF_CTRL1_RESET 0 | ||
51 | #define BM_LCDIF_CTRL1_MODE86 0x00000002 | ||
52 | #define BM_LCDIF_CTRL1_BUSY_ENABLE 0x00000004 | ||
53 | #define BM_LCDIF_CTRL1_VSYNC_EDGE_IRQ 0x00000100 | ||
54 | #define BM_LCDIF_CTRL1_CUR_FRAME_DONE_IRQ 0x00000200 | ||
55 | #define BM_LCDIF_CTRL1_UNDERFLOW_IRQ 0x00000400 | ||
56 | #define BM_LCDIF_CTRL1_OVERFLOW_IRQ 0x00000800 | ||
57 | #define BM_LCDIF_CTRL1_VSYNC_EDGE_IRQ_EN 0x00001000 | ||
58 | #define BM_LCDIF_CTRL1_BYTE_PACKING_FORMAT 0x000F0000 | ||
59 | #define BP_LCDIF_CTRL1_BYTE_PACKING_FORMAT 16 | ||
60 | #define BM_LCDIF_CTRL1_INTERLACE_FIELDS 0x00800000 | ||
61 | #define BM_LCDIF_CTRL1_RECOVER_ON_UNDERFLOW 0x01000000 | ||
62 | |||
63 | #define HW_LCDIF_TRANSFER_COUNT 0x20 | ||
64 | #define BM_LCDIF_TRANSFER_COUNT_H_COUNT 0x0000FFFF | ||
65 | #define BP_LCDIF_TRANSFER_COUNT_H_COUNT 0 | ||
66 | #define BM_LCDIF_TRANSFER_COUNT_V_COUNT 0xFFFF0000 | ||
67 | #define BP_LCDIF_TRANSFER_COUNT_V_COUNT 16 | ||
68 | |||
69 | #define HW_LCDIF_CUR_BUF 0x30 | ||
70 | |||
71 | #define HW_LCDIF_NEXT_BUF 0x40 | ||
72 | |||
73 | #define HW_LCDIF_TIMING 0x60 | ||
74 | |||
75 | #define HW_LCDIF_VDCTRL0 0x70 | ||
76 | #define BM_LCDIF_VDCTRL0_VSYNC_PULSE_WIDTH 0x0003FFFF | ||
77 | #define BP_LCDIF_VDCTRL0_VSYNC_PULSE_WIDTH 0 | ||
78 | #define BM_LCDIF_VDCTRL0_VSYNC_PULSE_WIDTH_UNIT 0x00100000 | ||
79 | #define BM_LCDIF_VDCTRL0_VSYNC_PERIOD_UNIT 0x00200000 | ||
80 | #define BM_LCDIF_VDCTRL0_ENABLE_POL 0x01000000 | ||
81 | #define BM_LCDIF_VDCTRL0_DOTCLK_POL 0x02000000 | ||
82 | #define BM_LCDIF_VDCTRL0_HSYNC_POL 0x04000000 | ||
83 | #define BM_LCDIF_VDCTRL0_VSYNC_POL 0x08000000 | ||
84 | #define BM_LCDIF_VDCTRL0_ENABLE_PRESENT 0x10000000 | ||
85 | #define BM_LCDIF_VDCTRL0_VSYNC_OEB 0x20000000 | ||
86 | |||
87 | #define HW_LCDIF_VDCTRL1 0x80 | ||
88 | #define BM_LCDIF_VDCTRL1_VSYNC_PERIOD 0xFFFFFFFF | ||
89 | #define BP_LCDIF_VDCTRL1_VSYNC_PERIOD 0 | ||
90 | |||
91 | #define HW_LCDIF_VDCTRL2 0x90 | ||
92 | #define BM_LCDIF_VDCTRL2_HSYNC_PERIOD 0x0003FFFF | ||
93 | #define BP_LCDIF_VDCTRL2_HSYNC_PERIOD 0 | ||
94 | #define BM_LCDIF_VDCTRL2_HSYNC_PULSE_WIDTH 0xFF000000 | ||
95 | #define BP_LCDIF_VDCTRL2_HSYNC_PULSE_WIDTH 24 | ||
96 | |||
97 | #define HW_LCDIF_VDCTRL3 0xA0 | ||
98 | #define BM_LCDIF_VDCTRL3_VERTICAL_WAIT_CNT 0x0000FFFF | ||
99 | #define BP_LCDIF_VDCTRL3_VERTICAL_WAIT_CNT 0 | ||
100 | #define BM_LCDIF_VDCTRL3_HORIZONTAL_WAIT_CNT 0x0FFF0000 | ||
101 | #define BP_LCDIF_VDCTRL3_HORIZONTAL_WAIT_CNT 16 | ||
102 | |||
103 | #define HW_LCDIF_VDCTRL4 0xB0 | ||
104 | #define BM_LCDIF_VDCTRL4_DOTCLK_H_VALID_DATA_CNT 0x0003FFFF | ||
105 | #define BP_LCDIF_VDCTRL4_DOTCLK_H_VALID_DATA_CNT 0 | ||
106 | #define BM_LCDIF_VDCTRL4_SYNC_SIGNALS_ON 0x00040000 | ||
107 | |||
108 | #define HW_LCDIF_DVICTRL0 0xC0 | ||
109 | #define BM_LCDIF_DVICTRL0_V_LINES_CNT 0x000003FF | ||
110 | #define BP_LCDIF_DVICTRL0_V_LINES_CNT 0 | ||
111 | #define BM_LCDIF_DVICTRL0_H_BLANKING_CNT 0x000FFC00 | ||
112 | #define BP_LCDIF_DVICTRL0_H_BLANKING_CNT 10 | ||
113 | #define BM_LCDIF_DVICTRL0_H_ACTIVE_CNT 0x7FF00000 | ||
114 | #define BP_LCDIF_DVICTRL0_H_ACTIVE_CNT 20 | ||
115 | |||
116 | #define HW_LCDIF_DVICTRL1 0xD0 | ||
117 | #define BM_LCDIF_DVICTRL1_F2_START_LINE 0x000003FF | ||
118 | #define BP_LCDIF_DVICTRL1_F2_START_LINE 0 | ||
119 | #define BM_LCDIF_DVICTRL1_F1_END_LINE 0x000FFC00 | ||
120 | #define BP_LCDIF_DVICTRL1_F1_END_LINE 10 | ||
121 | #define BM_LCDIF_DVICTRL1_F1_START_LINE 0x3FF00000 | ||
122 | #define BP_LCDIF_DVICTRL1_F1_START_LINE 20 | ||
123 | |||
124 | #define HW_LCDIF_DVICTRL2 0xE0 | ||
125 | #define BM_LCDIF_DVICTRL2_V1_BLANK_END_LINE 0x000003FF | ||
126 | #define BP_LCDIF_DVICTRL2_V1_BLANK_END_LINE 0 | ||
127 | #define BM_LCDIF_DVICTRL2_V1_BLANK_START_LINE 0x000FFC00 | ||
128 | #define BP_LCDIF_DVICTRL2_V1_BLANK_START_LINE 10 | ||
129 | #define BM_LCDIF_DVICTRL2_F2_END_LINE 0x3FF00000 | ||
130 | #define BP_LCDIF_DVICTRL2_F2_END_LINE 20 | ||
131 | |||
132 | #define HW_LCDIF_DVICTRL3 0xF0 | ||
133 | #define BM_LCDIF_DVICTRL3_V2_BLANK_END_LINE 0x000003FF | ||
134 | #define BP_LCDIF_DVICTRL3_V2_BLANK_END_LINE 0 | ||
135 | #define BM_LCDIF_DVICTRL3_V2_BLANK_START_LINE 0x03FF0000 | ||
136 | #define BP_LCDIF_DVICTRL3_V2_BLANK_START_LINE 16 | ||
137 | |||
138 | #define HW_LCDIF_DVICTRL4 0x100 | ||
139 | #define BM_LCDIF_DVICTRL4_H_FILL_CNT 0x000000FF | ||
140 | #define BP_LCDIF_DVICTRL4_H_FILL_CNT 0 | ||
141 | #define BM_LCDIF_DVICTRL4_CR_FILL_VALUE 0x0000FF00 | ||
142 | #define BP_LCDIF_DVICTRL4_CR_FILL_VALUE 8 | ||
143 | #define BM_LCDIF_DVICTRL4_CB_FILL_VALUE 0x00FF0000 | ||
144 | #define BP_LCDIF_DVICTRL4_CB_FILL_VALUE 16 | ||
145 | #define BM_LCDIF_DVICTRL4_Y_FILL_VALUE 0xFF000000 | ||
146 | #define BP_LCDIF_DVICTRL4_Y_FILL_VALUE 24 | ||
147 | |||
148 | #define HW_LCDIF_CSC_COEFF0 0x110 | ||
149 | #define BM_LCDIF_CSC_COEFF0_CSC_SUBSAMPLE_FILTER 0x00000003 | ||
150 | #define BP_LCDIF_CSC_COEFF0_CSC_SUBSAMPLE_FILTER 0 | ||
151 | #define BM_LCDIF_CSC_COEFF0_C0 0x03FF0000 | ||
152 | #define BP_LCDIF_CSC_COEFF0_C0 16 | ||
153 | |||
154 | #define HW_LCDIF_CSC_COEFF1 0x120 | ||
155 | #define BM_LCDIF_CSC_COEFF1_C1 0x000003FF | ||
156 | #define BP_LCDIF_CSC_COEFF1_C1 0 | ||
157 | #define BM_LCDIF_CSC_COEFF1_C2 0x03FF0000 | ||
158 | #define BP_LCDIF_CSC_COEFF1_C2 16 | ||
159 | |||
160 | #define HW_LCDIF_CSC_COEFF2 0x130 | ||
161 | #define BM_LCDIF_CSC_COEFF2_C3 0x000003FF | ||
162 | #define BP_LCDIF_CSC_COEFF2_C3 0 | ||
163 | #define BM_LCDIF_CSC_COEFF2_C4 0x03FF0000 | ||
164 | #define BP_LCDIF_CSC_COEFF2_C4 16 | ||
165 | |||
166 | #define HW_LCDIF_CSC_COEFF3 0x140 | ||
167 | #define BM_LCDIF_CSC_COEFF3_C5 0x000003FF | ||
168 | #define BP_LCDIF_CSC_COEFF3_C5 0 | ||
169 | #define BM_LCDIF_CSC_COEFF3_C6 0x03FF0000 | ||
170 | #define BP_LCDIF_CSC_COEFF3_C6 16 | ||
171 | |||
172 | #define HW_LCDIF_CSC_COEFF4 0x150 | ||
173 | #define BM_LCDIF_CSC_COEFF4_C7 0x000003FF | ||
174 | #define BP_LCDIF_CSC_COEFF4_C7 0 | ||
175 | #define BM_LCDIF_CSC_COEFF4_C8 0x03FF0000 | ||
176 | #define BP_LCDIF_CSC_COEFF4_C8 16 | ||
177 | |||
178 | #define HW_LCDIF_CSC_OFFSET 0x160 | ||
179 | #define BM_LCDIF_CSC_OFFSET_Y_OFFSET 0x000001FF | ||
180 | #define BP_LCDIF_CSC_OFFSET_Y_OFFSET 0 | ||
181 | #define BM_LCDIF_CSC_OFFSET_CBCR_OFFSET 0x01FF0000 | ||
182 | #define BP_LCDIF_CSC_OFFSET_CBCR_OFFSET 16 | ||
183 | |||
184 | #define HW_LCDIF_CSC_LIMIT 0x170 | ||
185 | #define BM_LCDIF_CSC_LIMIT_Y_MAX 0x000000FF | ||
186 | #define BP_LCDIF_CSC_LIMIT_Y_MAX 0 | ||
187 | #define BM_LCDIF_CSC_LIMIT_Y_MIN 0x0000FF00 | ||
188 | #define BP_LCDIF_CSC_LIMIT_Y_MIN 8 | ||
189 | #define BM_LCDIF_CSC_LIMIT_CBCR_MAX 0x00FF0000 | ||
190 | #define BP_LCDIF_CSC_LIMIT_CBCR_MAX 16 | ||
191 | #define BM_LCDIF_CSC_LIMIT_CBCR_MIN 0xFF000000 | ||
192 | #define BP_LCDIF_CSC_LIMIT_CBCR_MIN 24 | ||
193 | |||
194 | #define HW_LCDIF_STAT 0x1D0 | ||
195 | #define BM_LCDIF_STAT_TXFIFO_EMPTY 0x04000000 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-lradc.h b/arch/arm/mach-stmp378x/include/mach/regs-lradc.h new file mode 100644 index 000000000000..cb8cb06f8277 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-lradc.h | |||
@@ -0,0 +1,99 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define REGS_LRADC_PHYS 0x80050000 | ||
23 | #define REGS_LRADC_SIZE 0x2000 | ||
24 | |||
25 | #define HW_LRADC_CTRL0 0x0 | ||
26 | #define BM_LRADC_CTRL0_SCHEDULE 0x000000FF | ||
27 | #define BP_LRADC_CTRL0_SCHEDULE 0 | ||
28 | #define BM_LRADC_CTRL0_XPLUS_ENABLE 0x00010000 | ||
29 | #define BM_LRADC_CTRL0_YPLUS_ENABLE 0x00020000 | ||
30 | #define BM_LRADC_CTRL0_XMINUS_ENABLE 0x00040000 | ||
31 | #define BM_LRADC_CTRL0_YMINUS_ENABLE 0x00080000 | ||
32 | #define BM_LRADC_CTRL0_TOUCH_DETECT_ENABLE 0x00100000 | ||
33 | #define BM_LRADC_CTRL0_ONCHIP_GROUNDREF 0x00200000 | ||
34 | #define BM_LRADC_CTRL0_CLKGATE 0x40000000 | ||
35 | #define BM_LRADC_CTRL0_SFTRST 0x80000000 | ||
36 | |||
37 | #define HW_LRADC_CTRL1 0x10 | ||
38 | #define BM_LRADC_CTRL1_LRADC0_IRQ 0x00000001 | ||
39 | #define BP_LRADC_CTRL1_LRADC0_IRQ 0 | ||
40 | #define BM_LRADC_CTRL1_LRADC5_IRQ 0x00000020 | ||
41 | #define BM_LRADC_CTRL1_LRADC6_IRQ 0x00000040 | ||
42 | #define BM_LRADC_CTRL1_TOUCH_DETECT_IRQ 0x00000100 | ||
43 | #define BM_LRADC_CTRL1_LRADC0_IRQ_EN 0x00010000 | ||
44 | #define BM_LRADC_CTRL1_LRADC5_IRQ_EN 0x00200000 | ||
45 | #define BM_LRADC_CTRL1_TOUCH_DETECT_IRQ_EN 0x01000000 | ||
46 | |||
47 | #define HW_LRADC_CTRL2 0x20 | ||
48 | #define BM_LRADC_CTRL2_BL_BRIGHTNESS 0x001F0000 | ||
49 | #define BP_LRADC_CTRL2_BL_BRIGHTNESS 16 | ||
50 | #define BM_LRADC_CTRL2_BL_MUX_SELECT 0x00200000 | ||
51 | #define BM_LRADC_CTRL2_BL_ENABLE 0x00400000 | ||
52 | #define BM_LRADC_CTRL2_DIVIDE_BY_TWO 0xFF000000 | ||
53 | #define BP_LRADC_CTRL2_DIVIDE_BY_TWO 24 | ||
54 | |||
55 | #define HW_LRADC_CTRL3 0x30 | ||
56 | #define BM_LRADC_CTRL3_CYCLE_TIME 0x00000300 | ||
57 | #define BP_LRADC_CTRL3_CYCLE_TIME 8 | ||
58 | |||
59 | #define HW_LRADC_STATUS 0x40 | ||
60 | #define BM_LRADC_STATUS_TOUCH_DETECT_RAW 0x00000001 | ||
61 | #define BP_LRADC_STATUS_TOUCH_DETECT_RAW 0 | ||
62 | |||
63 | #define HW_LRADC_CH0 (0x50 + 0 * 0x10) | ||
64 | #define HW_LRADC_CH1 (0x50 + 1 * 0x10) | ||
65 | #define HW_LRADC_CH2 (0x50 + 2 * 0x10) | ||
66 | #define HW_LRADC_CH3 (0x50 + 3 * 0x10) | ||
67 | #define HW_LRADC_CH4 (0x50 + 4 * 0x10) | ||
68 | #define HW_LRADC_CH5 (0x50 + 5 * 0x10) | ||
69 | #define HW_LRADC_CH6 (0x50 + 6 * 0x10) | ||
70 | #define HW_LRADC_CH7 (0x50 + 7 * 0x10) | ||
71 | |||
72 | #define HW_LRADC_CHn 0x50 | ||
73 | #define BM_LRADC_CHn_VALUE 0x0003FFFF | ||
74 | #define BP_LRADC_CHn_VALUE 0 | ||
75 | #define BM_LRADC_CHn_NUM_SAMPLES 0x1F000000 | ||
76 | #define BP_LRADC_CHn_NUM_SAMPLES 24 | ||
77 | #define BM_LRADC_CHn_ACCUMULATE 0x20000000 | ||
78 | |||
79 | #define HW_LRADC_DELAY0 (0xD0 + 0 * 0x10) | ||
80 | #define HW_LRADC_DELAY1 (0xD0 + 1 * 0x10) | ||
81 | #define HW_LRADC_DELAY2 (0xD0 + 2 * 0x10) | ||
82 | #define HW_LRADC_DELAY3 (0xD0 + 3 * 0x10) | ||
83 | |||
84 | #define HW_LRADC_DELAYn 0xD0 | ||
85 | #define BM_LRADC_DELAYn_DELAY 0x000007FF | ||
86 | #define BP_LRADC_DELAYn_DELAY 0 | ||
87 | #define BM_LRADC_DELAYn_LOOP_COUNT 0x0000F800 | ||
88 | #define BP_LRADC_DELAYn_LOOP_COUNT 11 | ||
89 | #define BM_LRADC_DELAYn_TRIGGER_DELAYS 0x000F0000 | ||
90 | #define BP_LRADC_DELAYn_TRIGGER_DELAYS 16 | ||
91 | #define BM_LRADC_DELAYn_KICK 0x00100000 | ||
92 | #define BM_LRADC_DELAYn_TRIGGER_LRADCS 0xFF000000 | ||
93 | #define BP_LRADC_DELAYn_TRIGGER_LRADCS 24 | ||
94 | |||
95 | #define HW_LRADC_CTRL4 0x140 | ||
96 | #define BM_LRADC_CTRL4_LRADC6SELECT 0x0F000000 | ||
97 | #define BP_LRADC_CTRL4_LRADC6SELECT 24 | ||
98 | #define BM_LRADC_CTRL4_LRADC7SELECT 0xF0000000 | ||
99 | #define BP_LRADC_CTRL4_LRADC7SELECT 28 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-ocotp.h b/arch/arm/mach-stmp378x/include/mach/regs-ocotp.h new file mode 100644 index 000000000000..f0af64d9937e --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-ocotp.h | |||
@@ -0,0 +1,40 @@ | |||
1 | /* | ||
2 | * stmp378x: OCOTP 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_OCOTP_BASE (STMP3XXX_REGS_BASE + 0x2C000) | ||
22 | #define REGS_OCOTP_PHYS 0x8002C000 | ||
23 | #define REGS_OCOTP_SIZE 0x2000 | ||
24 | |||
25 | #define HW_OCOTP_CTRL 0x0 | ||
26 | #define BM_OCOTP_CTRL_BUSY 0x00000100 | ||
27 | #define BM_OCOTP_CTRL_ERROR 0x00000200 | ||
28 | #define BM_OCOTP_CTRL_RD_BANK_OPEN 0x00001000 | ||
29 | #define BM_OCOTP_CTRL_RELOAD_SHADOWS 0x00002000 | ||
30 | #define BM_OCOTP_CTRL_WR_UNLOCK 0xFFFF0000 | ||
31 | #define BP_OCOTP_CTRL_WR_UNLOCK 16 | ||
32 | |||
33 | #define HW_OCOTP_DATA 0x10 | ||
34 | |||
35 | #define HW_OCOTP_CUST0 (0x20 + 0 * 0x10) | ||
36 | #define HW_OCOTP_CUST1 (0x20 + 1 * 0x10) | ||
37 | #define HW_OCOTP_CUST2 (0x20 + 2 * 0x10) | ||
38 | #define HW_OCOTP_CUST3 (0x20 + 3 * 0x10) | ||
39 | |||
40 | #define HW_OCOTP_CUSTn 0x20 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-pwm.h b/arch/arm/mach-stmp378x/include/mach/regs-pwm.h new file mode 100644 index 000000000000..0d0f9e56ec77 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-pwm.h | |||
@@ -0,0 +1,53 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define REGS_PWM_PHYS 0x80064000 | ||
23 | #define REGS_PWM_SIZE 0x2000 | ||
24 | |||
25 | #define HW_PWM_CTRL 0x0 | ||
26 | #define BM_PWM_CTRL_PWM2_ENABLE 0x00000004 | ||
27 | #define BM_PWM_CTRL_PWM2_ANA_CTRL_ENABLE 0x00000020 | ||
28 | |||
29 | #define HW_PWM_ACTIVE0 (0x10 + 0 * 0x20) | ||
30 | #define HW_PWM_ACTIVE1 (0x10 + 1 * 0x20) | ||
31 | #define HW_PWM_ACTIVE2 (0x10 + 2 * 0x20) | ||
32 | #define HW_PWM_ACTIVE3 (0x10 + 3 * 0x20) | ||
33 | |||
34 | #define HW_PWM_ACTIVEn 0x10 | ||
35 | #define BM_PWM_ACTIVEn_ACTIVE 0x0000FFFF | ||
36 | #define BP_PWM_ACTIVEn_ACTIVE 0 | ||
37 | #define BM_PWM_ACTIVEn_INACTIVE 0xFFFF0000 | ||
38 | #define BP_PWM_ACTIVEn_INACTIVE 16 | ||
39 | |||
40 | #define HW_PWM_PERIOD0 (0x20 + 0 * 0x20) | ||
41 | #define HW_PWM_PERIOD1 (0x20 + 1 * 0x20) | ||
42 | #define HW_PWM_PERIOD2 (0x20 + 2 * 0x20) | ||
43 | #define HW_PWM_PERIOD3 (0x20 + 3 * 0x20) | ||
44 | |||
45 | #define HW_PWM_PERIODn 0x20 | ||
46 | #define BM_PWM_PERIODn_PERIOD 0x0000FFFF | ||
47 | #define BP_PWM_PERIODn_PERIOD 0 | ||
48 | #define BM_PWM_PERIODn_ACTIVE_STATE 0x00030000 | ||
49 | #define BP_PWM_PERIODn_ACTIVE_STATE 16 | ||
50 | #define BM_PWM_PERIODn_INACTIVE_STATE 0x000C0000 | ||
51 | #define BP_PWM_PERIODn_INACTIVE_STATE 18 | ||
52 | #define BM_PWM_PERIODn_CDIV 0x00700000 | ||
53 | #define BP_PWM_PERIODn_CDIV 20 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-pxp.h b/arch/arm/mach-stmp378x/include/mach/regs-pxp.h new file mode 100644 index 000000000000..54d297896de8 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-pxp.h | |||
@@ -0,0 +1,140 @@ | |||
1 | /* | ||
2 | * stmp378x: PXP 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_PXP_BASE (STMP3XXX_REGS_BASE + 0x2A000) | ||
22 | #define REGS_PXP_PHYS 0x8002A000 | ||
23 | #define REGS_PXP_SIZE 0x2000 | ||
24 | |||
25 | #define HW_PXP_CTRL 0x0 | ||
26 | #define BM_PXP_CTRL_ENABLE 0x00000001 | ||
27 | #define BP_PXP_CTRL_ENABLE 0 | ||
28 | #define BM_PXP_CTRL_IRQ_ENABLE 0x00000002 | ||
29 | #define BM_PXP_CTRL_OUTPUT_RGB_FORMAT 0x000000F0 | ||
30 | #define BP_PXP_CTRL_OUTPUT_RGB_FORMAT 4 | ||
31 | #define BM_PXP_CTRL_ROTATE 0x00000300 | ||
32 | #define BP_PXP_CTRL_ROTATE 8 | ||
33 | #define BM_PXP_CTRL_HFLIP 0x00000400 | ||
34 | #define BM_PXP_CTRL_VFLIP 0x00000800 | ||
35 | #define BM_PXP_CTRL_S0_FORMAT 0x0000F000 | ||
36 | #define BP_PXP_CTRL_S0_FORMAT 12 | ||
37 | #define BM_PXP_CTRL_SCALE 0x00040000 | ||
38 | #define BM_PXP_CTRL_CROP 0x00080000 | ||
39 | |||
40 | #define HW_PXP_STAT 0x10 | ||
41 | #define BM_PXP_STAT_IRQ 0x00000001 | ||
42 | #define BP_PXP_STAT_IRQ 0 | ||
43 | |||
44 | #define HW_PXP_RGBBUF 0x20 | ||
45 | |||
46 | #define HW_PXP_RGBSIZE 0x40 | ||
47 | #define BM_PXP_RGBSIZE_HEIGHT 0x00000FFF | ||
48 | #define BP_PXP_RGBSIZE_HEIGHT 0 | ||
49 | #define BM_PXP_RGBSIZE_WIDTH 0x00FFF000 | ||
50 | #define BP_PXP_RGBSIZE_WIDTH 12 | ||
51 | |||
52 | #define HW_PXP_S0BUF 0x50 | ||
53 | |||
54 | #define HW_PXP_S0UBUF 0x60 | ||
55 | |||
56 | #define HW_PXP_S0VBUF 0x70 | ||
57 | |||
58 | #define HW_PXP_S0PARAM 0x80 | ||
59 | #define BM_PXP_S0PARAM_HEIGHT 0x000000FF | ||
60 | #define BP_PXP_S0PARAM_HEIGHT 0 | ||
61 | #define BM_PXP_S0PARAM_WIDTH 0x0000FF00 | ||
62 | #define BP_PXP_S0PARAM_WIDTH 8 | ||
63 | #define BM_PXP_S0PARAM_YBASE 0x00FF0000 | ||
64 | #define BP_PXP_S0PARAM_YBASE 16 | ||
65 | #define BM_PXP_S0PARAM_XBASE 0xFF000000 | ||
66 | #define BP_PXP_S0PARAM_XBASE 24 | ||
67 | |||
68 | #define HW_PXP_S0BACKGROUND 0x90 | ||
69 | |||
70 | #define HW_PXP_S0CROP 0xA0 | ||
71 | #define BM_PXP_S0CROP_HEIGHT 0x000000FF | ||
72 | #define BP_PXP_S0CROP_HEIGHT 0 | ||
73 | #define BM_PXP_S0CROP_WIDTH 0x0000FF00 | ||
74 | #define BP_PXP_S0CROP_WIDTH 8 | ||
75 | #define BM_PXP_S0CROP_YBASE 0x00FF0000 | ||
76 | #define BP_PXP_S0CROP_YBASE 16 | ||
77 | #define BM_PXP_S0CROP_XBASE 0xFF000000 | ||
78 | #define BP_PXP_S0CROP_XBASE 24 | ||
79 | |||
80 | #define HW_PXP_S0SCALE 0xB0 | ||
81 | #define BM_PXP_S0SCALE_XSCALE 0x00003FFF | ||
82 | #define BP_PXP_S0SCALE_XSCALE 0 | ||
83 | #define BM_PXP_S0SCALE_YSCALE 0x3FFF0000 | ||
84 | #define BP_PXP_S0SCALE_YSCALE 16 | ||
85 | |||
86 | #define HW_PXP_CSCCOEFF0 0xD0 | ||
87 | |||
88 | #define HW_PXP_CSCCOEFF1 0xE0 | ||
89 | |||
90 | #define HW_PXP_CSCCOEFF2 0xF0 | ||
91 | |||
92 | #define HW_PXP_S0COLORKEYLOW 0x180 | ||
93 | |||
94 | #define HW_PXP_S0COLORKEYHIGH 0x190 | ||
95 | |||
96 | #define HW_PXP_OL0 (0x200 + 0 * 0x40) | ||
97 | #define HW_PXP_OL1 (0x200 + 1 * 0x40) | ||
98 | #define HW_PXP_OL2 (0x200 + 2 * 0x40) | ||
99 | #define HW_PXP_OL3 (0x200 + 3 * 0x40) | ||
100 | #define HW_PXP_OL4 (0x200 + 4 * 0x40) | ||
101 | #define HW_PXP_OL5 (0x200 + 5 * 0x40) | ||
102 | #define HW_PXP_OL6 (0x200 + 6 * 0x40) | ||
103 | #define HW_PXP_OL7 (0x200 + 7 * 0x40) | ||
104 | |||
105 | #define HW_PXP_OLn 0x200 | ||
106 | |||
107 | #define HW_PXP_OL0SIZE (0x210 + 0 * 0x40) | ||
108 | #define HW_PXP_OL1SIZE (0x210 + 1 * 0x40) | ||
109 | #define HW_PXP_OL2SIZE (0x210 + 2 * 0x40) | ||
110 | #define HW_PXP_OL3SIZE (0x210 + 3 * 0x40) | ||
111 | #define HW_PXP_OL4SIZE (0x210 + 4 * 0x40) | ||
112 | #define HW_PXP_OL5SIZE (0x210 + 5 * 0x40) | ||
113 | #define HW_PXP_OL6SIZE (0x210 + 6 * 0x40) | ||
114 | #define HW_PXP_OL7SIZE (0x210 + 7 * 0x40) | ||
115 | |||
116 | #define HW_PXP_OLnSIZE 0x210 | ||
117 | #define BM_PXP_OLnSIZE_HEIGHT 0x000000FF | ||
118 | #define BP_PXP_OLnSIZE_HEIGHT 0 | ||
119 | #define BM_PXP_OLnSIZE_WIDTH 0x0000FF00 | ||
120 | #define BP_PXP_OLnSIZE_WIDTH 8 | ||
121 | |||
122 | #define HW_PXP_OL0PARAM (0x220 + 0 * 0x40) | ||
123 | #define HW_PXP_OL1PARAM (0x220 + 1 * 0x40) | ||
124 | #define HW_PXP_OL2PARAM (0x220 + 2 * 0x40) | ||
125 | #define HW_PXP_OL3PARAM (0x220 + 3 * 0x40) | ||
126 | #define HW_PXP_OL4PARAM (0x220 + 4 * 0x40) | ||
127 | #define HW_PXP_OL5PARAM (0x220 + 5 * 0x40) | ||
128 | #define HW_PXP_OL6PARAM (0x220 + 6 * 0x40) | ||
129 | #define HW_PXP_OL7PARAM (0x220 + 7 * 0x40) | ||
130 | |||
131 | #define HW_PXP_OLnPARAM 0x220 | ||
132 | #define BM_PXP_OLnPARAM_ENABLE 0x00000001 | ||
133 | #define BP_PXP_OLnPARAM_ENABLE 0 | ||
134 | #define BM_PXP_OLnPARAM_ALPHA_CNTL 0x00000006 | ||
135 | #define BP_PXP_OLnPARAM_ALPHA_CNTL 1 | ||
136 | #define BM_PXP_OLnPARAM_ENABLE_COLORKEY 0x00000008 | ||
137 | #define BM_PXP_OLnPARAM_FORMAT 0x000000F0 | ||
138 | #define BP_PXP_OLnPARAM_FORMAT 4 | ||
139 | #define BM_PXP_OLnPARAM_ALPHA 0x0000FF00 | ||
140 | #define BP_PXP_OLnPARAM_ALPHA 8 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-rtc.h b/arch/arm/mach-stmp378x/include/mach/regs-rtc.h new file mode 100644 index 000000000000..b8dbd6742d98 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-rtc.h | |||
@@ -0,0 +1,59 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define BM_RTC_PERSISTENT1_GENERAL 0xFFFFFFFF | ||
57 | #define BP_RTC_PERSISTENT1_GENERAL 0 | ||
58 | |||
59 | #define HW_RTC_VERSION 0xD0 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-saif.h b/arch/arm/mach-stmp378x/include/mach/regs-saif.h new file mode 100644 index 000000000000..6df41762c2a3 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-saif.h | |||
@@ -0,0 +1,21 @@ | |||
1 | /* | ||
2 | * stmp378x: SAIF 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_SAIF_SIZE 0x2000 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-spdif.h b/arch/arm/mach-stmp378x/include/mach/regs-spdif.h new file mode 100644 index 000000000000..801539848c28 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-spdif.h | |||
@@ -0,0 +1,49 @@ | |||
1 | /* | ||
2 | * stmp378x: SPDIF 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_SPDIF_BASE (STMP3XXX_REGS_BASE + 0x54000) | ||
22 | #define REGS_SPDIF_PHYS 0x80054000 | ||
23 | #define REGS_SPDIF_SIZE 0x2000 | ||
24 | |||
25 | #define HW_SPDIF_CTRL 0x0 | ||
26 | #define BM_SPDIF_CTRL_RUN 0x00000001 | ||
27 | #define BP_SPDIF_CTRL_RUN 0 | ||
28 | #define BM_SPDIF_CTRL_FIFO_ERROR_IRQ_EN 0x00000002 | ||
29 | #define BM_SPDIF_CTRL_FIFO_OVERFLOW_IRQ 0x00000004 | ||
30 | #define BM_SPDIF_CTRL_FIFO_UNDERFLOW_IRQ 0x00000008 | ||
31 | #define BM_SPDIF_CTRL_WORD_LENGTH 0x00000010 | ||
32 | #define BM_SPDIF_CTRL_CLKGATE 0x40000000 | ||
33 | #define BM_SPDIF_CTRL_SFTRST 0x80000000 | ||
34 | |||
35 | #define HW_SPDIF_STAT 0x10 | ||
36 | |||
37 | #define HW_SPDIF_FRAMECTRL 0x20 | ||
38 | |||
39 | #define HW_SPDIF_SRR 0x30 | ||
40 | #define BM_SPDIF_SRR_RATE 0x000FFFFF | ||
41 | #define BP_SPDIF_SRR_RATE 0 | ||
42 | #define BM_SPDIF_SRR_BASEMULT 0x70000000 | ||
43 | #define BP_SPDIF_SRR_BASEMULT 28 | ||
44 | |||
45 | #define HW_SPDIF_DEBUG 0x40 | ||
46 | |||
47 | #define HW_SPDIF_DATA 0x50 | ||
48 | |||
49 | #define HW_SPDIF_VERSION 0x60 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-ssp.h b/arch/arm/mach-stmp378x/include/mach/regs-ssp.h new file mode 100644 index 000000000000..28aacf0f58ed --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-ssp.h | |||
@@ -0,0 +1,102 @@ | |||
1 | /* | ||
2 | * stmp378x: 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_SSP1_BASE (STMP3XXX_REGS_BASE + 0x10000) | ||
22 | #define REGS_SSP1_PHYS 0x80010000 | ||
23 | #define REGS_SSP2_BASE (STMP3XXX_REGS_BASE + 0x34000) | ||
24 | #define REGS_SSP2_PHYS 0x80034000 | ||
25 | #define REGS_SSP_SIZE 0x2000 | ||
26 | |||
27 | #define HW_SSP_CTRL0 0x0 | ||
28 | #define BM_SSP_CTRL0_XFER_COUNT 0x0000FFFF | ||
29 | #define BP_SSP_CTRL0_XFER_COUNT 0 | ||
30 | #define BM_SSP_CTRL0_ENABLE 0x00010000 | ||
31 | #define BM_SSP_CTRL0_GET_RESP 0x00020000 | ||
32 | #define BM_SSP_CTRL0_LONG_RESP 0x00080000 | ||
33 | #define BM_SSP_CTRL0_WAIT_FOR_CMD 0x00100000 | ||
34 | #define BM_SSP_CTRL0_WAIT_FOR_IRQ 0x00200000 | ||
35 | #define BM_SSP_CTRL0_BUS_WIDTH 0x00C00000 | ||
36 | #define BP_SSP_CTRL0_BUS_WIDTH 22 | ||
37 | #define BM_SSP_CTRL0_DATA_XFER 0x01000000 | ||
38 | #define BM_SSP_CTRL0_READ 0x02000000 | ||
39 | #define BM_SSP_CTRL0_IGNORE_CRC 0x04000000 | ||
40 | #define BM_SSP_CTRL0_LOCK_CS 0x08000000 | ||
41 | #define BM_SSP_CTRL0_RUN 0x20000000 | ||
42 | #define BM_SSP_CTRL0_CLKGATE 0x40000000 | ||
43 | #define BM_SSP_CTRL0_SFTRST 0x80000000 | ||
44 | |||
45 | #define HW_SSP_CMD0 0x10 | ||
46 | #define BM_SSP_CMD0_CMD 0x000000FF | ||
47 | #define BP_SSP_CMD0_CMD 0 | ||
48 | #define BM_SSP_CMD0_BLOCK_COUNT 0x0000FF00 | ||
49 | #define BP_SSP_CMD0_BLOCK_COUNT 8 | ||
50 | #define BM_SSP_CMD0_BLOCK_SIZE 0x000F0000 | ||
51 | #define BP_SSP_CMD0_BLOCK_SIZE 16 | ||
52 | #define BM_SSP_CMD0_APPEND_8CYC 0x00100000 | ||
53 | #define BM_SSP_CMD1_CMD_ARG 0xFFFFFFFF | ||
54 | #define BP_SSP_CMD1_CMD_ARG 0 | ||
55 | |||
56 | #define HW_SSP_TIMING 0x50 | ||
57 | #define BM_SSP_TIMING_CLOCK_RATE 0x000000FF | ||
58 | #define BP_SSP_TIMING_CLOCK_RATE 0 | ||
59 | #define BM_SSP_TIMING_CLOCK_DIVIDE 0x0000FF00 | ||
60 | #define BP_SSP_TIMING_CLOCK_DIVIDE 8 | ||
61 | #define BM_SSP_TIMING_TIMEOUT 0xFFFF0000 | ||
62 | #define BP_SSP_TIMING_TIMEOUT 16 | ||
63 | |||
64 | #define HW_SSP_CTRL1 0x60 | ||
65 | #define BM_SSP_CTRL1_SSP_MODE 0x0000000F | ||
66 | #define BP_SSP_CTRL1_SSP_MODE 0 | ||
67 | #define BM_SSP_CTRL1_WORD_LENGTH 0x000000F0 | ||
68 | #define BP_SSP_CTRL1_WORD_LENGTH 4 | ||
69 | #define BM_SSP_CTRL1_POLARITY 0x00000200 | ||
70 | #define BM_SSP_CTRL1_PHASE 0x00000400 | ||
71 | #define BM_SSP_CTRL1_DMA_ENABLE 0x00002000 | ||
72 | #define BM_SSP_CTRL1_FIFO_OVERRUN_IRQ 0x00008000 | ||
73 | #define BM_SSP_CTRL1_RECV_TIMEOUT_IRQ_EN 0x00010000 | ||
74 | #define BM_SSP_CTRL1_RECV_TIMEOUT_IRQ 0x00020000 | ||
75 | #define BM_SSP_CTRL1_FIFO_UNDERRUN_IRQ 0x00200000 | ||
76 | #define BM_SSP_CTRL1_DATA_CRC_IRQ_EN 0x00400000 | ||
77 | #define BM_SSP_CTRL1_DATA_CRC_IRQ 0x00800000 | ||
78 | #define BM_SSP_CTRL1_DATA_TIMEOUT_IRQ_EN 0x01000000 | ||
79 | #define BM_SSP_CTRL1_DATA_TIMEOUT_IRQ 0x02000000 | ||
80 | #define BM_SSP_CTRL1_RESP_TIMEOUT_IRQ_EN 0x04000000 | ||
81 | #define BM_SSP_CTRL1_RESP_TIMEOUT_IRQ 0x08000000 | ||
82 | #define BM_SSP_CTRL1_RESP_ERR_IRQ_EN 0x10000000 | ||
83 | #define BM_SSP_CTRL1_RESP_ERR_IRQ 0x20000000 | ||
84 | #define BM_SSP_CTRL1_SDIO_IRQ 0x80000000 | ||
85 | |||
86 | #define HW_SSP_DATA 0x70 | ||
87 | |||
88 | #define HW_SSP_SDRESP0 0x80 | ||
89 | |||
90 | #define HW_SSP_SDRESP1 0x90 | ||
91 | |||
92 | #define HW_SSP_SDRESP2 0xA0 | ||
93 | |||
94 | #define HW_SSP_SDRESP3 0xB0 | ||
95 | |||
96 | #define HW_SSP_STATUS 0xC0 | ||
97 | #define BM_SSP_STATUS_FIFO_EMPTY 0x00000020 | ||
98 | #define BM_SSP_STATUS_TIMEOUT 0x00001000 | ||
99 | #define BM_SSP_STATUS_RESP_TIMEOUT 0x00004000 | ||
100 | #define BM_SSP_STATUS_RESP_ERR 0x00008000 | ||
101 | #define BM_SSP_STATUS_RESP_CRC_ERR 0x00010000 | ||
102 | #define BM_SSP_STATUS_CARD_DETECT 0x10000000 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-sydma.h b/arch/arm/mach-stmp378x/include/mach/regs-sydma.h new file mode 100644 index 000000000000..08343a8b5566 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-sydma.h | |||
@@ -0,0 +1,23 @@ | |||
1 | /* | ||
2 | * stmp378x: SYDMA 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_SYDMA_BASE (STMP3XXX_REGS_BASE + 0x26000) | ||
22 | #define REGS_SYDMA_PHYS 0x80026000 | ||
23 | #define REGS_SYDMA_SIZE 0x2000 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-tvenc.h b/arch/arm/mach-stmp378x/include/mach/regs-tvenc.h new file mode 100644 index 000000000000..7f895cb34350 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-tvenc.h | |||
@@ -0,0 +1,67 @@ | |||
1 | /* | ||
2 | * stmp378x: TVENC 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_TVENC_BASE (STMP3XXX_REGS_BASE + 0x38000) | ||
22 | #define REGS_TVENC_PHYS 0x80038000 | ||
23 | #define REGS_TVENC_SIZE 0x2000 | ||
24 | |||
25 | #define HW_TVENC_CTRL 0x0 | ||
26 | #define BM_TVENC_CTRL_CLKGATE 0x40000000 | ||
27 | #define BM_TVENC_CTRL_SFTRST 0x80000000 | ||
28 | |||
29 | #define HW_TVENC_CONFIG 0x10 | ||
30 | #define BM_TVENC_CONFIG_ENCD_MODE 0x00000007 | ||
31 | #define BP_TVENC_CONFIG_ENCD_MODE 0 | ||
32 | #define BM_TVENC_CONFIG_SYNC_MODE 0x00000070 | ||
33 | #define BP_TVENC_CONFIG_SYNC_MODE 4 | ||
34 | #define BM_TVENC_CONFIG_FSYNC_PHS 0x00000200 | ||
35 | #define BM_TVENC_CONFIG_CGAIN 0x0000C000 | ||
36 | #define BP_TVENC_CONFIG_CGAIN 14 | ||
37 | #define BM_TVENC_CONFIG_YGAIN_SEL 0x00030000 | ||
38 | #define BP_TVENC_CONFIG_YGAIN_SEL 16 | ||
39 | #define BM_TVENC_CONFIG_PAL_SHAPE 0x00100000 | ||
40 | |||
41 | #define HW_TVENC_SYNCOFFSET 0x30 | ||
42 | |||
43 | #define HW_TVENC_COLORSUB0 0xC0 | ||
44 | |||
45 | #define HW_TVENC_COLORBURST 0x140 | ||
46 | #define BM_TVENC_COLORBURST_PBA 0x00FF0000 | ||
47 | #define BP_TVENC_COLORBURST_PBA 16 | ||
48 | #define BM_TVENC_COLORBURST_NBA 0xFF000000 | ||
49 | #define BP_TVENC_COLORBURST_NBA 24 | ||
50 | |||
51 | #define HW_TVENC_MACROVISION0 0x150 | ||
52 | |||
53 | #define HW_TVENC_MACROVISION1 0x160 | ||
54 | |||
55 | #define HW_TVENC_MACROVISION2 0x170 | ||
56 | |||
57 | #define HW_TVENC_MACROVISION3 0x180 | ||
58 | |||
59 | #define HW_TVENC_MACROVISION4 0x190 | ||
60 | |||
61 | #define HW_TVENC_DACCTRL 0x1A0 | ||
62 | #define BM_TVENC_DACCTRL_RVAL 0x00000070 | ||
63 | #define BP_TVENC_DACCTRL_RVAL 4 | ||
64 | #define BM_TVENC_DACCTRL_DUMP_TOVDD1 0x00000100 | ||
65 | #define BM_TVENC_DACCTRL_PWRUP1 0x00001000 | ||
66 | #define BM_TVENC_DACCTRL_GAINUP 0x00040000 | ||
67 | #define BM_TVENC_DACCTRL_GAINDN 0x00080000 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-uartapp.h b/arch/arm/mach-stmp378x/include/mach/regs-uartapp.h new file mode 100644 index 000000000000..a251e68bb3a1 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-uartapp.h | |||
@@ -0,0 +1,87 @@ | |||
1 | /* | ||
2 | * stmp378x: 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_UARTAPP1_BASE (STMP3XXX_REGS_BASE + 0x6C000) | ||
22 | #define REGS_UARTAPP1_PHYS 0x8006C000 | ||
23 | #define REGS_UARTAPP2_BASE (STMP3XXX_REGS_BASE + 0x6E000) | ||
24 | #define REGS_UARTAPP2_PHYS 0x8006E000 | ||
25 | #define REGS_UARTAPP_SIZE 0x2000 | ||
26 | |||
27 | #define HW_UARTAPP_CTRL0 0x0 | ||
28 | #define BM_UARTAPP_CTRL0_XFER_COUNT 0x0000FFFF | ||
29 | #define BP_UARTAPP_CTRL0_XFER_COUNT 0 | ||
30 | #define BM_UARTAPP_CTRL0_RXTIMEOUT 0x07FF0000 | ||
31 | #define BP_UARTAPP_CTRL0_RXTIMEOUT 16 | ||
32 | #define BM_UARTAPP_CTRL0_RXTO_ENABLE 0x08000000 | ||
33 | #define BM_UARTAPP_CTRL0_RUN 0x20000000 | ||
34 | #define BM_UARTAPP_CTRL0_SFTRST 0x80000000 | ||
35 | #define BM_UARTAPP_CTRL1_XFER_COUNT 0x0000FFFF | ||
36 | #define BP_UARTAPP_CTRL1_XFER_COUNT 0 | ||
37 | #define BM_UARTAPP_CTRL1_RUN 0x10000000 | ||
38 | |||
39 | #define HW_UARTAPP_CTRL2 0x20 | ||
40 | #define BM_UARTAPP_CTRL2_UARTEN 0x00000001 | ||
41 | #define BP_UARTAPP_CTRL2_UARTEN 0 | ||
42 | #define BM_UARTAPP_CTRL2_TXE 0x00000100 | ||
43 | #define BM_UARTAPP_CTRL2_RXE 0x00000200 | ||
44 | #define BM_UARTAPP_CTRL2_RTS 0x00000800 | ||
45 | #define BM_UARTAPP_CTRL2_RTSEN 0x00004000 | ||
46 | #define BM_UARTAPP_CTRL2_CTSEN 0x00008000 | ||
47 | #define BM_UARTAPP_CTRL2_RXDMAE 0x01000000 | ||
48 | #define BM_UARTAPP_CTRL2_TXDMAE 0x02000000 | ||
49 | #define BM_UARTAPP_CTRL2_DMAONERR 0x04000000 | ||
50 | |||
51 | #define HW_UARTAPP_LINECTRL 0x30 | ||
52 | #define BM_UARTAPP_LINECTRL_BRK 0x00000001 | ||
53 | #define BP_UARTAPP_LINECTRL_BRK 0 | ||
54 | #define BM_UARTAPP_LINECTRL_PEN 0x00000002 | ||
55 | #define BM_UARTAPP_LINECTRL_EPS 0x00000004 | ||
56 | #define BM_UARTAPP_LINECTRL_STP2 0x00000008 | ||
57 | #define BM_UARTAPP_LINECTRL_FEN 0x00000010 | ||
58 | #define BM_UARTAPP_LINECTRL_WLEN 0x00000060 | ||
59 | #define BP_UARTAPP_LINECTRL_WLEN 5 | ||
60 | #define BM_UARTAPP_LINECTRL_SPS 0x00000080 | ||
61 | #define BM_UARTAPP_LINECTRL_BAUD_DIVFRAC 0x00003F00 | ||
62 | #define BP_UARTAPP_LINECTRL_BAUD_DIVFRAC 8 | ||
63 | #define BM_UARTAPP_LINECTRL_BAUD_DIVINT 0xFFFF0000 | ||
64 | #define BP_UARTAPP_LINECTRL_BAUD_DIVINT 16 | ||
65 | |||
66 | #define HW_UARTAPP_INTR 0x50 | ||
67 | #define BM_UARTAPP_INTR_CTSMIS 0x00000002 | ||
68 | #define BM_UARTAPP_INTR_RTIS 0x00000040 | ||
69 | #define BM_UARTAPP_INTR_CTSMIEN 0x00020000 | ||
70 | #define BM_UARTAPP_INTR_RXIEN 0x00100000 | ||
71 | #define BM_UARTAPP_INTR_RTIEN 0x00400000 | ||
72 | |||
73 | #define HW_UARTAPP_DATA 0x60 | ||
74 | |||
75 | #define HW_UARTAPP_STAT 0x70 | ||
76 | #define BM_UARTAPP_STAT_RXCOUNT 0x0000FFFF | ||
77 | #define BP_UARTAPP_STAT_RXCOUNT 0 | ||
78 | #define BM_UARTAPP_STAT_FERR 0x00010000 | ||
79 | #define BM_UARTAPP_STAT_PERR 0x00020000 | ||
80 | #define BM_UARTAPP_STAT_BERR 0x00040000 | ||
81 | #define BM_UARTAPP_STAT_OERR 0x00080000 | ||
82 | #define BM_UARTAPP_STAT_RXFE 0x01000000 | ||
83 | #define BM_UARTAPP_STAT_TXFF 0x02000000 | ||
84 | #define BM_UARTAPP_STAT_TXFE 0x08000000 | ||
85 | #define BM_UARTAPP_STAT_CTS 0x10000000 | ||
86 | |||
87 | #define HW_UARTAPP_VERSION 0x90 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-uartdbg.h b/arch/arm/mach-stmp378x/include/mach/regs-uartdbg.h new file mode 100644 index 000000000000..b810deb552a9 --- /dev/null +++ b/arch/arm/mach-stmp378x/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-stmp378x/include/mach/regs-usbctrl.h b/arch/arm/mach-stmp378x/include/mach/regs-usbctrl.h new file mode 100644 index 000000000000..25112c1aa608 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-usbctrl.h | |||
@@ -0,0 +1,40 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | ||
23 | #define REGS_USBCTRL_SIZE 0x2000 | ||
24 | |||
25 | #define HW_USBCTRL_USBCMD 0x140 | ||
26 | #define BM_USBCTRL_USBCMD_RS 0x00000001 | ||
27 | #define BP_USBCTRL_USBCMD_RS 0 | ||
28 | #define BM_USBCTRL_USBCMD_RST 0x00000002 | ||
29 | |||
30 | #define HW_USBCTRL_USBINTR 0x148 | ||
31 | #define BM_USBCTRL_USBINTR_UE 0x00000001 | ||
32 | #define BP_USBCTRL_USBINTR_UE 0 | ||
33 | |||
34 | #define HW_USBCTRL_PORTSC1 0x184 | ||
35 | #define BM_USBCTRL_PORTSC1_PHCD 0x00800000 | ||
36 | |||
37 | #define HW_USBCTRL_OTGSC 0x1A4 | ||
38 | #define BM_USBCTRL_OTGSC_ID 0x00000100 | ||
39 | #define BM_USBCTRL_OTGSC_IDIS 0x00010000 | ||
40 | #define BM_USBCTRL_OTGSC_IDIE 0x01000000 | ||
diff --git a/arch/arm/mach-stmp378x/include/mach/regs-usbphy.h b/arch/arm/mach-stmp378x/include/mach/regs-usbphy.h new file mode 100644 index 000000000000..11f3b732dc92 --- /dev/null +++ b/arch/arm/mach-stmp378x/include/mach/regs-usbphy.h | |||
@@ -0,0 +1,37 @@ | |||
1 | /* | ||
2 | * stmp378x: 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 | #define REGS_USBPHY_PHYS 0x8007C000 | ||
23 | #define REGS_USBPHY_SIZE 0x2000 | ||
24 | |||
25 | #define HW_USBPHY_PWD 0x0 | ||
26 | |||
27 | #define HW_USBPHY_CTRL 0x30 | ||
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 | ||