diff options
| author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-02-19 16:18:39 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-02-19 16:18:39 -0500 |
| commit | 59b8175c771040afcd4ad67022b0cc80c216b866 (patch) | |
| tree | 4ef5935bee1e342716d49b9d4b99e3fa835526e6 /include/asm-arm/hardware | |
| parent | 920841d8d1d61bc12b43f95a579a5374f6d98f81 (diff) | |
| parent | 3b0eb4a195a124567cd0dd6f700f8388def542c6 (diff) | |
Merge branch 'for-linus' of master.kernel.org:/home/rmk/linux-2.6-arm
* 'for-linus' of master.kernel.org:/home/rmk/linux-2.6-arm: (117 commits)
[ARM] 4058/2: iop32x: set ->broken_parity_status on n2100 onboard r8169 ports
[ARM] 4140/1: AACI stability add ac97 timeout and retries
[ARM] 4139/1: AACI record support
[ARM] 4138/1: AACI: multiple channel support for IRQ handling
[ARM] 4211/1: Provide a defconfig for ns9xxx
[ARM] 4210/1: base for new machine type "NetSilicon NS9360"
[ARM] 4222/1: S3C2443: Remove reference to missing S3C2443_PM
[ARM] 4221/1: S3C2443: DMA support
[ARM] 4220/1: S3C24XX: DMA system initialised from sysdev
[ARM] 4219/1: S3C2443: DMA source definitions
[ARM] 4218/1: S3C2412: fix CONFIG_CPU_S3C2412_ONLY wrt to S3C2443
[ARM] 4217/1: S3C24XX: remove the dma channel show at startup
[ARM] 4090/2: avoid clash between PXA and SA1111 defines
[ARM] 4216/1: add .gitignore entries for ARM specific files
[ARM] 4214/2: S3C2410: Add Armzone QT2410
[ARM] 4215/1: s3c2410 usb device: per-platform vbus_draw
[ARM] 4213/1: S3C2410 - Update definition of ADCTSC_XY_PST
[ARM] 4098/1: ARM: rtc_lock only used with rtc_cmos
[ARM] 4137/1: Add kexec support
[ARM] 4201/1: SMP barriers pair needed for the secondary boot process
...
Fix up conflict due to typedef removal in sound/arm/aaci.h
Diffstat (limited to 'include/asm-arm/hardware')
| -rw-r--r-- | include/asm-arm/hardware/arm_scu.h | 2 | ||||
| -rw-r--r-- | include/asm-arm/hardware/cache-l2x0.h | 56 | ||||
| -rw-r--r-- | include/asm-arm/hardware/gic.h | 5 | ||||
| -rw-r--r-- | include/asm-arm/hardware/iop3xx.h | 15 | ||||
| -rw-r--r-- | include/asm-arm/hardware/sa1111.h | 93 |
5 files changed, 112 insertions, 59 deletions
diff --git a/include/asm-arm/hardware/arm_scu.h b/include/asm-arm/hardware/arm_scu.h index 9903f60c84..7d28eb5a17 100644 --- a/include/asm-arm/hardware/arm_scu.h +++ b/include/asm-arm/hardware/arm_scu.h | |||
| @@ -1,6 +1,8 @@ | |||
| 1 | #ifndef ASMARM_HARDWARE_ARM_SCU_H | 1 | #ifndef ASMARM_HARDWARE_ARM_SCU_H |
| 2 | #define ASMARM_HARDWARE_ARM_SCU_H | 2 | #define ASMARM_HARDWARE_ARM_SCU_H |
| 3 | 3 | ||
| 4 | #include <asm/arch/scu.h> | ||
| 5 | |||
| 4 | /* | 6 | /* |
| 5 | * SCU registers | 7 | * SCU registers |
| 6 | */ | 8 | */ |
diff --git a/include/asm-arm/hardware/cache-l2x0.h b/include/asm-arm/hardware/cache-l2x0.h new file mode 100644 index 0000000000..54029a7403 --- /dev/null +++ b/include/asm-arm/hardware/cache-l2x0.h | |||
| @@ -0,0 +1,56 @@ | |||
| 1 | /* | ||
| 2 | * include/asm-arm/hardware/cache-l2x0.h | ||
| 3 | * | ||
| 4 | * Copyright (C) 2007 ARM Limited | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License version 2 as | ||
| 8 | * published by the Free Software Foundation. | ||
| 9 | * | ||
| 10 | * This program is distributed in the hope that it will be useful, | ||
| 11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 13 | * GNU General Public License for more details. | ||
| 14 | * | ||
| 15 | * You should have received a copy of the GNU General Public License | ||
| 16 | * along with this program; if not, write to the Free Software | ||
| 17 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 18 | */ | ||
| 19 | |||
| 20 | #ifndef __ASM_ARM_HARDWARE_L2X0_H | ||
| 21 | #define __ASM_ARM_HARDWARE_L2X0_H | ||
| 22 | |||
| 23 | #define L2X0_CACHE_ID 0x000 | ||
| 24 | #define L2X0_CACHE_TYPE 0x004 | ||
| 25 | #define L2X0_CTRL 0x100 | ||
| 26 | #define L2X0_AUX_CTRL 0x104 | ||
| 27 | #define L2X0_EVENT_CNT_CTRL 0x200 | ||
| 28 | #define L2X0_EVENT_CNT1_CFG 0x204 | ||
| 29 | #define L2X0_EVENT_CNT0_CFG 0x208 | ||
| 30 | #define L2X0_EVENT_CNT1_VAL 0x20C | ||
| 31 | #define L2X0_EVENT_CNT0_VAL 0x210 | ||
| 32 | #define L2X0_INTR_MASK 0x214 | ||
| 33 | #define L2X0_MASKED_INTR_STAT 0x218 | ||
| 34 | #define L2X0_RAW_INTR_STAT 0x21C | ||
| 35 | #define L2X0_INTR_CLEAR 0x220 | ||
| 36 | #define L2X0_CACHE_SYNC 0x730 | ||
| 37 | #define L2X0_INV_LINE_PA 0x770 | ||
| 38 | #define L2X0_INV_WAY 0x77C | ||
| 39 | #define L2X0_CLEAN_LINE_PA 0x7B0 | ||
| 40 | #define L2X0_CLEAN_LINE_IDX 0x7B8 | ||
| 41 | #define L2X0_CLEAN_WAY 0x7BC | ||
| 42 | #define L2X0_CLEAN_INV_LINE_PA 0x7F0 | ||
| 43 | #define L2X0_CLEAN_INV_LINE_IDX 0x7F8 | ||
| 44 | #define L2X0_CLEAN_INV_WAY 0x7FC | ||
| 45 | #define L2X0_LOCKDOWN_WAY_D 0x900 | ||
| 46 | #define L2X0_LOCKDOWN_WAY_I 0x904 | ||
| 47 | #define L2X0_TEST_OPERATION 0xF00 | ||
| 48 | #define L2X0_LINE_DATA 0xF10 | ||
| 49 | #define L2X0_LINE_TAG 0xF30 | ||
| 50 | #define L2X0_DEBUG_CTRL 0xF40 | ||
| 51 | |||
| 52 | #ifndef __ASSEMBLY__ | ||
| 53 | extern void __init l2x0_init(void __iomem *base, __u32 aux_val, __u32 aux_mask); | ||
| 54 | #endif | ||
| 55 | |||
| 56 | #endif | ||
diff --git a/include/asm-arm/hardware/gic.h b/include/asm-arm/hardware/gic.h index 3fa5eb70f6..966e428ad3 100644 --- a/include/asm-arm/hardware/gic.h +++ b/include/asm-arm/hardware/gic.h | |||
| @@ -33,8 +33,9 @@ | |||
| 33 | #define GIC_DIST_SOFTINT 0xf00 | 33 | #define GIC_DIST_SOFTINT 0xf00 |
| 34 | 34 | ||
| 35 | #ifndef __ASSEMBLY__ | 35 | #ifndef __ASSEMBLY__ |
| 36 | void gic_dist_init(void __iomem *base); | 36 | void gic_dist_init(unsigned int gic_nr, void __iomem *base, unsigned int irq_start); |
| 37 | void gic_cpu_init(void __iomem *base); | 37 | void gic_cpu_init(unsigned int gic_nr, void __iomem *base); |
| 38 | void gic_cascade_irq(unsigned int gic_nr, unsigned int irq); | ||
| 38 | void gic_raise_softirq(cpumask_t cpumask, unsigned int irq); | 39 | void gic_raise_softirq(cpumask_t cpumask, unsigned int irq); |
| 39 | #endif | 40 | #endif |
| 40 | 41 | ||
diff --git a/include/asm-arm/hardware/iop3xx.h b/include/asm-arm/hardware/iop3xx.h index 13ac8a4cd0..c91b546e20 100644 --- a/include/asm-arm/hardware/iop3xx.h +++ b/include/asm-arm/hardware/iop3xx.h | |||
| @@ -37,6 +37,13 @@ extern void gpio_line_set(int line, int value); | |||
| 37 | #define IOP3XX_PERIPHERAL_PHYS_BASE 0xffffe000 | 37 | #define IOP3XX_PERIPHERAL_PHYS_BASE 0xffffe000 |
| 38 | #define IOP3XX_PERIPHERAL_VIRT_BASE 0xfeffe000 | 38 | #define IOP3XX_PERIPHERAL_VIRT_BASE 0xfeffe000 |
| 39 | #define IOP3XX_PERIPHERAL_SIZE 0x00002000 | 39 | #define IOP3XX_PERIPHERAL_SIZE 0x00002000 |
| 40 | #define IOP3XX_PERIPHERAL_UPPER_PA (IOP3XX_PERIPHERAL_PHYS_BASE +\ | ||
| 41 | IOP3XX_PERIPHERAL_SIZE - 1) | ||
| 42 | #define IOP3XX_PERIPHERAL_UPPER_VA (IOP3XX_PERIPHERAL_VIRT_BASE +\ | ||
| 43 | IOP3XX_PERIPHERAL_SIZE - 1) | ||
| 44 | #define IOP3XX_PMMR_PHYS_TO_VIRT(addr) (u32) ((u32) addr -\ | ||
| 45 | (IOP3XX_PERIPHERAL_PHYS_BASE\ | ||
| 46 | - IOP3XX_PERIPHERAL_VIRT_BASE)) | ||
| 40 | #define IOP3XX_REG_ADDR(reg) (IOP3XX_PERIPHERAL_VIRT_BASE + (reg)) | 47 | #define IOP3XX_REG_ADDR(reg) (IOP3XX_PERIPHERAL_VIRT_BASE + (reg)) |
| 41 | 48 | ||
| 42 | /* Address Translation Unit */ | 49 | /* Address Translation Unit */ |
| @@ -258,12 +265,20 @@ extern void gpio_line_set(int line, int value); | |||
| 258 | #define IOP3XX_PCI_LOWER_IO_PA 0x90000000 | 265 | #define IOP3XX_PCI_LOWER_IO_PA 0x90000000 |
| 259 | #define IOP3XX_PCI_LOWER_IO_VA 0xfe000000 | 266 | #define IOP3XX_PCI_LOWER_IO_VA 0xfe000000 |
| 260 | #define IOP3XX_PCI_LOWER_IO_BA (*IOP3XX_OIOWTVR) | 267 | #define IOP3XX_PCI_LOWER_IO_BA (*IOP3XX_OIOWTVR) |
| 268 | #define IOP3XX_PCI_UPPER_IO_PA (IOP3XX_PCI_LOWER_IO_PA +\ | ||
| 269 | IOP3XX_PCI_IO_WINDOW_SIZE - 1) | ||
| 270 | #define IOP3XX_PCI_UPPER_IO_VA (IOP3XX_PCI_LOWER_IO_VA +\ | ||
| 271 | IOP3XX_PCI_IO_WINDOW_SIZE - 1) | ||
| 272 | #define IOP3XX_PCI_IO_PHYS_TO_VIRT(addr) (((u32) addr -\ | ||
| 273 | IOP3XX_PCI_LOWER_IO_PA) +\ | ||
| 274 | IOP3XX_PCI_LOWER_IO_VA) | ||
| 261 | 275 | ||
| 262 | 276 | ||
| 263 | #ifndef __ASSEMBLY__ | 277 | #ifndef __ASSEMBLY__ |
| 264 | void iop3xx_map_io(void); | 278 | void iop3xx_map_io(void); |
| 265 | void iop3xx_init_time(unsigned long); | 279 | void iop3xx_init_time(unsigned long); |
| 266 | unsigned long iop3xx_gettimeoffset(void); | 280 | unsigned long iop3xx_gettimeoffset(void); |
| 281 | void iop_init_cp6_handler(void); | ||
| 267 | 282 | ||
| 268 | extern struct platform_device iop3xx_i2c0_device; | 283 | extern struct platform_device iop3xx_i2c0_device; |
| 269 | extern struct platform_device iop3xx_i2c1_device; | 284 | extern struct platform_device iop3xx_i2c1_device; |
diff --git a/include/asm-arm/hardware/sa1111.h b/include/asm-arm/hardware/sa1111.h index 6aa0a5b75b..61b1d05c7d 100644 --- a/include/asm-arm/hardware/sa1111.h +++ b/include/asm-arm/hardware/sa1111.h | |||
| @@ -29,6 +29,9 @@ | |||
| 29 | #define _SA1111(x) ((x) + sa1111->resource.start) | 29 | #define _SA1111(x) ((x) + sa1111->resource.start) |
| 30 | #endif | 30 | #endif |
| 31 | 31 | ||
| 32 | #define sa1111_writel(val,addr) __raw_writel(val, addr) | ||
| 33 | #define sa1111_readl(addr) __raw_readl(addr) | ||
| 34 | |||
| 32 | /* | 35 | /* |
| 33 | * 26 bits of the SA-1110 address bus are available to the SA-1111. | 36 | * 26 bits of the SA-1110 address bus are available to the SA-1111. |
| 34 | * Use these when feeding target addresses to the DMA engines. | 37 | * Use these when feeding target addresses to the DMA engines. |
| @@ -45,14 +48,6 @@ | |||
| 45 | #define SA1111_SAC_DMA_MIN_XFER (0x800) | 48 | #define SA1111_SAC_DMA_MIN_XFER (0x800) |
| 46 | 49 | ||
| 47 | /* | 50 | /* |
| 48 | * SA1111 register definitions. | ||
| 49 | */ | ||
| 50 | #define __CCREG(x) __REGP(SA1111_VBASE + (x)) | ||
| 51 | |||
| 52 | #define sa1111_writel(val,addr) __raw_writel(val, addr) | ||
| 53 | #define sa1111_readl(addr) __raw_readl(addr) | ||
| 54 | |||
| 55 | /* | ||
| 56 | * System Bus Interface (SBI) | 51 | * System Bus Interface (SBI) |
| 57 | * | 52 | * |
| 58 | * Registers | 53 | * Registers |
| @@ -194,55 +189,37 @@ | |||
| 194 | * SADR Serial Audio Data Register (16 x 32-bit) | 189 | * SADR Serial Audio Data Register (16 x 32-bit) |
| 195 | */ | 190 | */ |
| 196 | 191 | ||
| 197 | #define _SACR0 _SA1111( 0x0600 ) | 192 | #define SA1111_SERAUDIO 0x0600 |
| 198 | #define _SACR1 _SA1111( 0x0604 ) | 193 | |
| 199 | #define _SACR2 _SA1111( 0x0608 ) | 194 | /* |
| 200 | #define _SASR0 _SA1111( 0x060c ) | 195 | * These are offsets from the above base. |
| 201 | #define _SASR1 _SA1111( 0x0610 ) | 196 | */ |
| 202 | #define _SASCR _SA1111( 0x0618 ) | 197 | #define SA1111_SACR0 0x00 |
| 203 | #define _L3_CAR _SA1111( 0x061c ) | 198 | #define SA1111_SACR1 0x04 |
| 204 | #define _L3_CDR _SA1111( 0x0620 ) | 199 | #define SA1111_SACR2 0x08 |
| 205 | #define _ACCAR _SA1111( 0x0624 ) | 200 | #define SA1111_SASR0 0x0c |
| 206 | #define _ACCDR _SA1111( 0x0628 ) | 201 | #define SA1111_SASR1 0x10 |
| 207 | #define _ACSAR _SA1111( 0x062c ) | 202 | #define SA1111_SASCR 0x18 |
| 208 | #define _ACSDR _SA1111( 0x0630 ) | 203 | #define SA1111_L3_CAR 0x1c |
| 209 | #define _SADTCS _SA1111( 0x0634 ) | 204 | #define SA1111_L3_CDR 0x20 |
| 210 | #define _SADTSA _SA1111( 0x0638 ) | 205 | #define SA1111_ACCAR 0x24 |
| 211 | #define _SADTCA _SA1111( 0x063c ) | 206 | #define SA1111_ACCDR 0x28 |
| 212 | #define _SADTSB _SA1111( 0x0640 ) | 207 | #define SA1111_ACSAR 0x2c |
| 213 | #define _SADTCB _SA1111( 0x0644 ) | 208 | #define SA1111_ACSDR 0x30 |
| 214 | #define _SADRCS _SA1111( 0x0648 ) | 209 | #define SA1111_SADTCS 0x34 |
| 215 | #define _SADRSA _SA1111( 0x064c ) | 210 | #define SA1111_SADTSA 0x38 |
| 216 | #define _SADRCA _SA1111( 0x0650 ) | 211 | #define SA1111_SADTCA 0x3c |
| 217 | #define _SADRSB _SA1111( 0x0654 ) | 212 | #define SA1111_SADTSB 0x40 |
| 218 | #define _SADRCB _SA1111( 0x0658 ) | 213 | #define SA1111_SADTCB 0x44 |
| 219 | #define _SAITR _SA1111( 0x065c ) | 214 | #define SA1111_SADRCS 0x48 |
| 220 | #define _SADR _SA1111( 0x0680 ) | 215 | #define SA1111_SADRSA 0x4c |
| 221 | 216 | #define SA1111_SADRCA 0x50 | |
| 222 | #define SACR0 __CCREG(0x0600) | 217 | #define SA1111_SADRSB 0x54 |
| 223 | #define SACR1 __CCREG(0x0604) | 218 | #define SA1111_SADRCB 0x58 |
| 224 | #define SACR2 __CCREG(0x0608) | 219 | #define SA1111_SAITR 0x5c |
| 225 | #define SASR0 __CCREG(0x060c) | 220 | #define SA1111_SADR 0x80 |
| 226 | #define SASR1 __CCREG(0x0610) | 221 | |
| 227 | #define SASCR __CCREG(0x0618) | 222 | #ifndef CONFIG_ARCH_PXA |
| 228 | #define L3_CAR __CCREG(0x061c) | ||
| 229 | #define L3_CDR __CCREG(0x0620) | ||
| 230 | #define ACCAR __CCREG(0x0624) | ||
| 231 | #define ACCDR __CCREG(0x0628) | ||
| 232 | #define ACSAR __CCREG(0x062c) | ||
| 233 | #define ACSDR __CCREG(0x0630) | ||
| 234 | #define SADTCS __CCREG(0x0634) | ||
| 235 | #define SADTSA __CCREG(0x0638) | ||
| 236 | #define SADTCA __CCREG(0x063c) | ||
| 237 | #define SADTSB __CCREG(0x0640) | ||
| 238 | #define SADTCB __CCREG(0x0644) | ||
| 239 | #define SADRCS __CCREG(0x0648) | ||
| 240 | #define SADRSA __CCREG(0x064c) | ||
| 241 | #define SADRCA __CCREG(0x0650) | ||
| 242 | #define SADRSB __CCREG(0x0654) | ||
| 243 | #define SADRCB __CCREG(0x0658) | ||
| 244 | #define SAITR __CCREG(0x065c) | ||
| 245 | #define SADR __CCREG(0x0680) | ||
| 246 | 223 | ||
| 247 | #define SACR0_ENB (1<<0) | 224 | #define SACR0_ENB (1<<0) |
| 248 | #define SACR0_BCKD (1<<2) | 225 | #define SACR0_BCKD (1<<2) |
| @@ -330,6 +307,8 @@ | |||
| 330 | #define SAITR_RDBDA (1<<10) | 307 | #define SAITR_RDBDA (1<<10) |
| 331 | #define SAITR_RDBDB (1<<11) | 308 | #define SAITR_RDBDB (1<<11) |
| 332 | 309 | ||
| 310 | #endif /* !CONFIG_ARCH_PXA */ | ||
| 311 | |||
| 333 | /* | 312 | /* |
| 334 | * General-Purpose I/O Interface | 313 | * General-Purpose I/O Interface |
| 335 | * | 314 | * |
