diff options
Diffstat (limited to 'arch/arm/mach-at91/include')
62 files changed, 1187 insertions, 3133 deletions
diff --git a/arch/arm/mach-at91/include/mach/at572d940hf.h b/arch/arm/mach-at91/include/mach/at572d940hf.h deleted file mode 100644 index 2d9b0af9c4d..00000000000 --- a/arch/arm/mach-at91/include/mach/at572d940hf.h +++ /dev/null @@ -1,123 +0,0 @@ -/* - * include/mach/at572d940hf.h - * - * Antonio R. Costa <costa.antonior@gmail.com> - * Copyright (C) 2008 Atmel - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - * - */ - -#ifndef AT572D940HF_H -#define AT572D940HF_H - -/* - * Peripheral identifiers/interrupts. - */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Peripherals */ -#define AT572D940HF_ID_PIOA	2	/* Parallel IO Controller A */ -#define AT572D940HF_ID_PIOB	3	/* Parallel IO Controller B */ -#define AT572D940HF_ID_PIOC	4	/* Parallel IO Controller C */ -#define AT572D940HF_ID_EMAC	5	/* MACB ethernet controller */ -#define AT572D940HF_ID_US0	6	/* USART 0 */ -#define AT572D940HF_ID_US1	7	/* USART 1 */ -#define AT572D940HF_ID_US2	8	/* USART 2 */ -#define AT572D940HF_ID_MCI	9	/* Multimedia Card Interface */ -#define AT572D940HF_ID_UDP	10	/* USB Device Port */ -#define AT572D940HF_ID_TWI0	11	/* Two-Wire Interface 0 */ -#define AT572D940HF_ID_SPI0	12	/* Serial Peripheral Interface 0 */ -#define AT572D940HF_ID_SPI1	13	/* Serial Peripheral Interface 1 */ -#define AT572D940HF_ID_SSC0	14	/* Serial Synchronous Controller 0 */ -#define AT572D940HF_ID_SSC1	15	/* Serial Synchronous Controller 1 */ -#define AT572D940HF_ID_SSC2	16	/* Serial Synchronous Controller 2 */ -#define AT572D940HF_ID_TC0	17	/* Timer Counter 0 */ -#define AT572D940HF_ID_TC1	18	/* Timer Counter 1 */ -#define AT572D940HF_ID_TC2	19	/* Timer Counter 2 */ -#define AT572D940HF_ID_UHP	20	/* USB Host port */ -#define AT572D940HF_ID_SSC3	21	/* Serial Synchronous Controller 3 */ -#define AT572D940HF_ID_TWI1	22	/* Two-Wire Interface 1 */ -#define AT572D940HF_ID_CAN0	23	/* CAN Controller 0 */ -#define AT572D940HF_ID_CAN1	24	/* CAN Controller 1 */ -#define AT572D940HF_ID_MHALT	25	/* mAgicV HALT line */ -#define AT572D940HF_ID_MSIRQ0	26	/* mAgicV SIRQ0 line */ -#define AT572D940HF_ID_MEXC	27	/* mAgicV exception line */ -#define AT572D940HF_ID_MEDMA	28	/* mAgicV end of DMA line */ -#define AT572D940HF_ID_IRQ0	29	/* External Interrupt Source (IRQ0) */ -#define AT572D940HF_ID_IRQ1	30	/* External Interrupt Source (IRQ1) */ -#define AT572D940HF_ID_IRQ2	31	/* External Interrupt Source (IRQ2) */ - - -/* - * User Peripheral physical base addresses. - */ -#define AT572D940HF_BASE_TCB	0xfffa0000 -#define AT572D940HF_BASE_TC0	0xfffa0000 -#define AT572D940HF_BASE_TC1	0xfffa0040 -#define AT572D940HF_BASE_TC2	0xfffa0080 -#define AT572D940HF_BASE_UDP	0xfffa4000 -#define AT572D940HF_BASE_MCI	0xfffa8000 -#define AT572D940HF_BASE_TWI0	0xfffac000 -#define AT572D940HF_BASE_US0	0xfffb0000 -#define AT572D940HF_BASE_US1	0xfffb4000 -#define AT572D940HF_BASE_US2	0xfffb8000 -#define AT572D940HF_BASE_SSC0	0xfffbc000 -#define AT572D940HF_BASE_SSC1	0xfffc0000 -#define AT572D940HF_BASE_SSC2	0xfffc4000 -#define AT572D940HF_BASE_SPI0	0xfffc8000 -#define AT572D940HF_BASE_SPI1	0xfffcc000 -#define AT572D940HF_BASE_SSC3	0xfffd0000 -#define AT572D940HF_BASE_TWI1	0xfffd4000 -#define AT572D940HF_BASE_EMAC	0xfffd8000 -#define AT572D940HF_BASE_CAN0	0xfffdc000 -#define AT572D940HF_BASE_CAN1	0xfffe0000 -#define AT91_BASE_SYS		0xffffea00 - - -/* - * System Peripherals (offset from AT91_BASE_SYS) - */ -#define AT91_SDRAMC	(0xffffea00 - AT91_BASE_SYS) -#define AT91_SMC	(0xffffec00 - AT91_BASE_SYS) -#define AT91_MATRIX	(0xffffee00 - AT91_BASE_SYS) -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS) -#define AT91_DBGU	(0xfffff200 - AT91_BASE_SYS) -#define AT91_PIOA	(0xfffff400 - AT91_BASE_SYS) -#define AT91_PIOB	(0xfffff600 - AT91_BASE_SYS) -#define AT91_PIOC	(0xfffff800 - AT91_BASE_SYS) -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS) -#define AT91_RSTC	(0xfffffd00 - AT91_BASE_SYS) -#define AT91_RTT	(0xfffffd20 - AT91_BASE_SYS) -#define AT91_PIT	(0xfffffd30 - AT91_BASE_SYS) -#define AT91_WDT	(0xfffffd40 - AT91_BASE_SYS) - -#define AT91_USART0	AT572D940HF_ID_US0 -#define AT91_USART1	AT572D940HF_ID_US1 -#define AT91_USART2	AT572D940HF_ID_US2 - - -/* - * Internal Memory. - */ -#define AT572D940HF_SRAM_BASE	0x00300000	/* Internal SRAM base address */ -#define AT572D940HF_SRAM_SIZE	(48 * SZ_1K)	/* Internal SRAM size (48Kb) */ - -#define AT572D940HF_ROM_BASE	0x00400000	/* Internal ROM base address */ -#define AT572D940HF_ROM_SIZE	SZ_32K		/* Internal ROM size (32Kb) */ - -#define AT572D940HF_UHP_BASE	0x00500000	/* USB Host controller */ - - -#endif diff --git a/arch/arm/mach-at91/include/mach/at572d940hf_matrix.h b/arch/arm/mach-at91/include/mach/at572d940hf_matrix.h deleted file mode 100644 index b6751df0948..00000000000 --- a/arch/arm/mach-at91/include/mach/at572d940hf_matrix.h +++ /dev/null @@ -1,123 +0,0 @@ -/* - * include/mach//at572d940hf_matrix.h - * - * Antonio R. Costa <costa.antonior@gmail.com> - * Copyright (C) 2008 Atmel - * - * Copyright (C) 2005 SAN People - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -#ifndef AT572D940HF_MATRIX_H -#define AT572D940HF_MATRIX_H - -#define AT91_MATRIX_MCFG0	(AT91_MATRIX + 0x00)	/* Master Configuration Register 0 */ -#define AT91_MATRIX_MCFG1	(AT91_MATRIX + 0x04)	/* Master Configuration Register 1 */ -#define AT91_MATRIX_MCFG2	(AT91_MATRIX + 0x08)	/* Master Configuration Register 2 */ -#define AT91_MATRIX_MCFG3	(AT91_MATRIX + 0x0C)	/* Master Configuration Register 3 */ -#define AT91_MATRIX_MCFG4	(AT91_MATRIX + 0x10)	/* Master Configuration Register 4 */ -#define AT91_MATRIX_MCFG5	(AT91_MATRIX + 0x14)	/* Master Configuration Register 5 */ - -#define		AT91_MATRIX_ULBT	(7 << 0)	/* Undefined Length Burst Type */ -#define			AT91_MATRIX_ULBT_INFINITE	(0 << 0) -#define			AT91_MATRIX_ULBT_SINGLE		(1 << 0) -#define			AT91_MATRIX_ULBT_FOUR		(2 << 0) -#define			AT91_MATRIX_ULBT_EIGHT		(3 << 0) -#define			AT91_MATRIX_ULBT_SIXTEEN	(4 << 0) - -#define AT91_MATRIX_SCFG0	(AT91_MATRIX + 0x40)	/* Slave Configuration Register 0 */ -#define AT91_MATRIX_SCFG1	(AT91_MATRIX + 0x44)	/* Slave Configuration Register 1 */ -#define AT91_MATRIX_SCFG2	(AT91_MATRIX + 0x48)	/* Slave Configuration Register 2 */ -#define AT91_MATRIX_SCFG3	(AT91_MATRIX + 0x4C)	/* Slave Configuration Register 3 */ -#define AT91_MATRIX_SCFG4	(AT91_MATRIX + 0x50)	/* Slave Configuration Register 4 */ -#define		AT91_MATRIX_SLOT_CYCLE		(0xff << 0)	/* Maximum Number of Allowed Cycles for a Burst */ -#define		AT91_MATRIX_DEFMSTR_TYPE	(3    << 16)	/* Default Master Type */ -#define			AT91_MATRIX_DEFMSTR_TYPE_NONE	(0 << 16) -#define			AT91_MATRIX_DEFMSTR_TYPE_LAST	(1 << 16) -#define			AT91_MATRIX_DEFMSTR_TYPE_FIXED	(2 << 16) -#define		AT91_MATRIX_FIXED_DEFMSTR	(0x7  << 18)	/* Fixed Index of Default Master */ -#define		AT91_MATRIX_ARBT		(3    << 24)	/* Arbitration Type */ -#define			AT91_MATRIX_ARBT_ROUND_ROBIN	(0 << 24) -#define			AT91_MATRIX_ARBT_FIXED_PRIORITY	(1 << 24) - -#define AT91_MATRIX_PRAS0	(AT91_MATRIX + 0x80)	/* Priority Register A for Slave 0 */ -#define AT91_MATRIX_PRAS1	(AT91_MATRIX + 0x88)	/* Priority Register A for Slave 1 */ -#define AT91_MATRIX_PRAS2	(AT91_MATRIX + 0x90)	/* Priority Register A for Slave 2 */ -#define AT91_MATRIX_PRAS3	(AT91_MATRIX + 0x98)	/* Priority Register A for Slave 3 */ -#define AT91_MATRIX_PRAS4	(AT91_MATRIX + 0xA0)	/* Priority Register A for Slave 4 */ - -#define		AT91_MATRIX_M0PR		(3 << 0)	/* Master 0 Priority */ -#define		AT91_MATRIX_M1PR		(3 << 4)	/* Master 1 Priority */ -#define		AT91_MATRIX_M2PR		(3 << 8)	/* Master 2 Priority */ -#define		AT91_MATRIX_M3PR		(3 << 12)	/* Master 3 Priority */ -#define		AT91_MATRIX_M4PR		(3 << 16)	/* Master 4 Priority */ -#define		AT91_MATRIX_M5PR		(3 << 20)	/* Master 5 Priority */ -#define		AT91_MATRIX_M6PR		(3 << 24)	/* Master 6 Priority */ - -#define AT91_MATRIX_MRCR	(AT91_MATRIX + 0x100)	/* Master Remap Control Register */ -#define		AT91_MATRIX_RCB0		(1 << 0)	/* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */ -#define		AT91_MATRIX_RCB1		(1 << 1)	/* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */ - -#define AT91_MATRIX_SFR0	(AT91_MATRIX + 0x110)	/* Special Function Register 0 */ -#define AT91_MATRIX_SFR1	(AT91_MATRIX + 0x114)	/* Special Function Register 1 */ -#define AT91_MATRIX_SFR2	(AT91_MATRIX + 0x118)	/* Special Function Register 2 */ -#define AT91_MATRIX_SFR3	(AT91_MATRIX + 0x11C)	/* Special Function Register 3 */ -#define AT91_MATRIX_SFR4	(AT91_MATRIX + 0x120)	/* Special Function Register 4 */ -#define AT91_MATRIX_SFR5	(AT91_MATRIX + 0x124)	/* Special Function Register 5 */ -#define AT91_MATRIX_SFR6	(AT91_MATRIX + 0x128)	/* Special Function Register 6 */ -#define AT91_MATRIX_SFR7	(AT91_MATRIX + 0x12C)	/* Special Function Register 7 */ -#define AT91_MATRIX_SFR8	(AT91_MATRIX + 0x130)	/* Special Function Register 8 */ -#define AT91_MATRIX_SFR9	(AT91_MATRIX + 0x134)	/* Special Function Register 9 */ -#define AT91_MATRIX_SFR10	(AT91_MATRIX + 0x138)	/* Special Function Register 10 */ -#define AT91_MATRIX_SFR11	(AT91_MATRIX + 0x13C)	/* Special Function Register 11 */ -#define AT91_MATRIX_SFR12	(AT91_MATRIX + 0x140)	/* Special Function Register 12 */ -#define AT91_MATRIX_SFR13	(AT91_MATRIX + 0x144)	/* Special Function Register 13 */ -#define AT91_MATRIX_SFR14	(AT91_MATRIX + 0x148)	/* Special Function Register 14 */ -#define AT91_MATRIX_SFR15	(AT91_MATRIX + 0x14C)	/* Special Function Register 15 */ - - -/* - * The following registers / bits are not defined in the Datasheet (Revision A) - */ - -#define AT91_MATRIX_TCR		(AT91_MATRIX + 0x100)	/* TCM Configuration Register */ -#define		AT91_MATRIX_ITCM_SIZE		(0xf << 0)	/* Size of ITCM enabled memory block */ -#define			AT91_MATRIX_ITCM_0		(0 << 0) -#define			AT91_MATRIX_ITCM_16		(5 << 0) -#define			AT91_MATRIX_ITCM_32		(6 << 0) -#define			AT91_MATRIX_ITCM_64		(7 << 0) -#define		AT91_MATRIX_DTCM_SIZE		(0xf << 4)	/* Size of DTCM enabled memory block */ -#define			AT91_MATRIX_DTCM_0		(0 << 4) -#define			AT91_MATRIX_DTCM_16		(5 << 4) -#define			AT91_MATRIX_DTCM_32		(6 << 4) -#define			AT91_MATRIX_DTCM_64		(7 << 4) - -#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x11C)	/* EBI Chip Select Assignment Register */ -#define		AT91_MATRIX_CS1A		(1 << 1)	/* Chip Select 1 Assignment */ -#define			AT91_MATRIX_CS1A_SMC		(0 << 1) -#define			AT91_MATRIX_CS1A_SDRAMC		(1 << 1) -#define		AT91_MATRIX_CS3A		(1 << 3)	/* Chip Select 3 Assignment */ -#define			AT91_MATRIX_CS3A_SMC		(0 << 3) -#define			AT91_MATRIX_CS3A_SMC_SMARTMEDIA	(1 << 3) -#define		AT91_MATRIX_CS4A		(1 << 4)	/* Chip Select 4 Assignment */ -#define			AT91_MATRIX_CS4A_SMC		(0 << 4) -#define			AT91_MATRIX_CS4A_SMC_CF1	(1 << 4) -#define		AT91_MATRIX_CS5A		(1 << 5)	/* Chip Select 5 Assignment */ -#define			AT91_MATRIX_CS5A_SMC		(0 << 5) -#define			AT91_MATRIX_CS5A_SMC_CF2	(1 << 5) -#define		AT91_MATRIX_DBPUC		(1 << 8)	/* Data Bus Pull-up Configuration */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_adc.h b/arch/arm/mach-at91/include/mach/at91_adc.h deleted file mode 100644 index 8e7ed5c9081..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_adc.h +++ /dev/null @@ -1,61 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_adc.h - * - * Copyright (C) SAN People - * - * Analog-to-Digital Converter (ADC) registers. - * Based on AT91SAM9260 datasheet revision D. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_ADC_H -#define AT91_ADC_H - -#define AT91_ADC_CR		0x00		/* Control Register */ -#define		AT91_ADC_SWRST		(1 << 0)	/* Software Reset */ -#define		AT91_ADC_START		(1 << 1)	/* Start Conversion */ - -#define AT91_ADC_MR		0x04		/* Mode Register */ -#define		AT91_ADC_TRGEN		(1 << 0)	/* Trigger Enable */ -#define		AT91_ADC_TRGSEL		(7 << 1)	/* Trigger Selection */ -#define			AT91_ADC_TRGSEL_TC0		(0 << 1) -#define			AT91_ADC_TRGSEL_TC1		(1 << 1) -#define			AT91_ADC_TRGSEL_TC2		(2 << 1) -#define			AT91_ADC_TRGSEL_EXTERNAL	(6 << 1) -#define		AT91_ADC_LOWRES		(1 << 4)	/* Low Resolution */ -#define		AT91_ADC_SLEEP		(1 << 5)	/* Sleep Mode */ -#define		AT91_ADC_PRESCAL	(0x3f << 8)	/* Prescalar Rate Selection */ -#define			AT91_ADC_PRESCAL_(x)	((x) << 8) -#define		AT91_ADC_STARTUP	(0x1f << 16)	/* Startup Up Time */ -#define			AT91_ADC_STARTUP_(x)	((x) << 16) -#define		AT91_ADC_SHTIM		(0xf  << 24)	/* Sample & Hold Time */ -#define			AT91_ADC_SHTIM_(x)	((x) << 24) - -#define AT91_ADC_CHER		0x10		/* Channel Enable Register */ -#define AT91_ADC_CHDR		0x14		/* Channel Disable Register */ -#define AT91_ADC_CHSR		0x18		/* Channel Status Register */ -#define		AT91_ADC_CH(n)		(1 << (n))	/* Channel Number */ - -#define AT91_ADC_SR		0x1C		/* Status Register */ -#define		AT91_ADC_EOC(n)		(1 << (n))	/* End of Conversion on Channel N */ -#define		AT91_ADC_OVRE(n)	(1 << ((n) + 8))/* Overrun Error on Channel N */ -#define		AT91_ADC_DRDY		(1 << 16)	/* Data Ready */ -#define		AT91_ADC_GOVRE		(1 << 17)	/* General Overrun Error */ -#define		AT91_ADC_ENDRX		(1 << 18)	/* End of RX Buffer */ -#define		AT91_ADC_RXFUFF		(1 << 19)	/* RX Buffer Full */ - -#define AT91_ADC_LCDR		0x20		/* Last Converted Data Register */ -#define		AT91_ADC_LDATA		(0x3ff) - -#define AT91_ADC_IER		0x24		/* Interrupt Enable Register */ -#define AT91_ADC_IDR		0x28		/* Interrupt Disable Register */ -#define AT91_ADC_IMR		0x2C		/* Interrupt Mask Register */ - -#define AT91_ADC_CHR(n)		(0x30 + ((n) * 4))	/* Channel Data Register N */ -#define		AT91_ADC_DATA		(0x3ff) - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_aic.h b/arch/arm/mach-at91/include/mach/at91_aic.h deleted file mode 100644 index 03566799d3b..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_aic.h +++ /dev/null @@ -1,53 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_aic.h - * - * Copyright (C) 2005 Ivan Kokshaysky - * Copyright (C) SAN People - * - * Advanced Interrupt Controller (AIC) - System peripherals registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_AIC_H -#define AT91_AIC_H - -#define AT91_AIC_SMR(n)		(AT91_AIC + ((n) * 4))	/* Source Mode Registers 0-31 */ -#define		AT91_AIC_PRIOR		(7 << 0)		/* Priority Level */ -#define		AT91_AIC_SRCTYPE	(3 << 5)		/* Interrupt Source Type */ -#define			AT91_AIC_SRCTYPE_LOW		(0 << 5) -#define			AT91_AIC_SRCTYPE_FALLING	(1 << 5) -#define			AT91_AIC_SRCTYPE_HIGH		(2 << 5) -#define			AT91_AIC_SRCTYPE_RISING		(3 << 5) - -#define AT91_AIC_SVR(n)		(AT91_AIC + 0x80 + ((n) * 4))	/* Source Vector Registers 0-31 */ -#define AT91_AIC_IVR		(AT91_AIC + 0x100)	/* Interrupt Vector Register */ -#define AT91_AIC_FVR		(AT91_AIC + 0x104)	/* Fast Interrupt Vector Register */ -#define AT91_AIC_ISR		(AT91_AIC + 0x108)	/* Interrupt Status Register */ -#define		AT91_AIC_IRQID		(0x1f << 0)		/* Current Interrupt Identifier */ - -#define AT91_AIC_IPR		(AT91_AIC + 0x10c)	/* Interrupt Pending Register */ -#define AT91_AIC_IMR		(AT91_AIC + 0x110)	/* Interrupt Mask Register */ -#define AT91_AIC_CISR		(AT91_AIC + 0x114)	/* Core Interrupt Status Register */ -#define		AT91_AIC_NFIQ		(1 << 0)		/* nFIQ Status */ -#define		AT91_AIC_NIRQ		(1 << 1)		/* nIRQ Status */ - -#define AT91_AIC_IECR		(AT91_AIC + 0x120)	/* Interrupt Enable Command Register */ -#define AT91_AIC_IDCR		(AT91_AIC + 0x124)	/* Interrupt Disable Command Register */ -#define AT91_AIC_ICCR		(AT91_AIC + 0x128)	/* Interrupt Clear Command Register */ -#define AT91_AIC_ISCR		(AT91_AIC + 0x12c)	/* Interrupt Set Command Register */ -#define AT91_AIC_EOICR		(AT91_AIC + 0x130)	/* End of Interrupt Command Register */ -#define AT91_AIC_SPU		(AT91_AIC + 0x134)	/* Spurious Interrupt Vector Register */ -#define AT91_AIC_DCR		(AT91_AIC + 0x138)	/* Debug Control Register */ -#define		AT91_AIC_DCR_PROT	(1 << 0)		/* Protection Mode */ -#define		AT91_AIC_DCR_GMSK	(1 << 1)		/* General Mask */ - -#define AT91_AIC_FFER		(AT91_AIC + 0x140)	/* Fast Forcing Enable Register [SAM9 only] */ -#define AT91_AIC_FFDR		(AT91_AIC + 0x144)	/* Fast Forcing Disable Register [SAM9 only] */ -#define AT91_AIC_FFSR		(AT91_AIC + 0x148)	/* Fast Forcing Status Register [SAM9 only] */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_dbgu.h b/arch/arm/mach-at91/include/mach/at91_dbgu.h index 6dcaa771687..3b5948566e5 100644 --- a/arch/arm/mach-at91/include/mach/at91_dbgu.h +++ b/arch/arm/mach-at91/include/mach/at91_dbgu.h @@ -16,22 +16,22 @@  #ifndef AT91_DBGU_H  #define AT91_DBGU_H -#ifdef AT91_DBGU -#define AT91_DBGU_CR		(AT91_DBGU + 0x00)	/* Control Register */ -#define AT91_DBGU_MR		(AT91_DBGU + 0x04)	/* Mode Register */ -#define AT91_DBGU_IER		(AT91_DBGU + 0x08)	/* Interrupt Enable Register */ +#if !defined(CONFIG_ARCH_AT91X40) +#define AT91_DBGU_CR		(0x00)	/* Control Register */ +#define AT91_DBGU_MR		(0x04)	/* Mode Register */ +#define AT91_DBGU_IER		(0x08)	/* Interrupt Enable Register */  #define		AT91_DBGU_TXRDY		(1 << 1)		/* Transmitter Ready */  #define		AT91_DBGU_TXEMPTY	(1 << 9)		/* Transmitter Empty */ -#define AT91_DBGU_IDR		(AT91_DBGU + 0x0c)	/* Interrupt Disable Register */ -#define AT91_DBGU_IMR		(AT91_DBGU + 0x10)	/* Interrupt Mask Register */ -#define AT91_DBGU_SR		(AT91_DBGU + 0x14)	/* Status Register */ -#define AT91_DBGU_RHR		(AT91_DBGU + 0x18)	/* Receiver Holding Register */ -#define AT91_DBGU_THR		(AT91_DBGU + 0x1c)	/* Transmitter Holding Register */ -#define AT91_DBGU_BRGR		(AT91_DBGU + 0x20)	/* Baud Rate Generator Register */ +#define AT91_DBGU_IDR		(0x0c)	/* Interrupt Disable Register */ +#define AT91_DBGU_IMR		(0x10)	/* Interrupt Mask Register */ +#define AT91_DBGU_SR		(0x14)	/* Status Register */ +#define AT91_DBGU_RHR		(0x18)	/* Receiver Holding Register */ +#define AT91_DBGU_THR		(0x1c)	/* Transmitter Holding Register */ +#define AT91_DBGU_BRGR		(0x20)	/* Baud Rate Generator Register */ -#define AT91_DBGU_CIDR		(AT91_DBGU + 0x40)	/* Chip ID Register */ -#define AT91_DBGU_EXID		(AT91_DBGU + 0x44)	/* Chip ID Extension Register */ -#define AT91_DBGU_FNR		(AT91_DBGU + 0x48)	/* Force NTRST Register [SAM9 only] */ +#define AT91_DBGU_CIDR		(0x40)	/* Chip ID Register */ +#define AT91_DBGU_EXID		(0x44)	/* Chip ID Extension Register */ +#define AT91_DBGU_FNR		(0x48)	/* Force NTRST Register [SAM9 only] */  #define		AT91_DBGU_FNTRST	(1 << 0)		/* Force NTRST */  #endif /* AT91_DBGU */ diff --git a/arch/arm/mach-at91/include/mach/at91_matrix.h b/arch/arm/mach-at91/include/mach/at91_matrix.h new file mode 100644 index 00000000000..f8996c95413 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91_matrix.h @@ -0,0 +1,23 @@ +/* + * Copyright (C) 2011 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> + * + * Under GPLv2 + */ + +#ifndef __MACH_AT91_MATRIX_H__ +#define __MACH_AT91_MATRIX_H__ + +#ifndef __ASSEMBLY__ +extern void __iomem *at91_matrix_base; + +#define at91_matrix_read(field) \ +	__raw_readl(at91_matrix_base + field) + +#define at91_matrix_write(field, value) \ +	__raw_writel(value, at91_matrix_base + field) + +#else +.extern at91_matrix_base +#endif + +#endif /* __MACH_AT91_MATRIX_H__ */ diff --git a/arch/arm/mach-at91/include/mach/at91_mci.h b/arch/arm/mach-at91/include/mach/at91_mci.h deleted file mode 100644 index 57f8ee15494..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_mci.h +++ /dev/null @@ -1,113 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_mci.h - * - * Copyright (C) 2005 Ivan Kokshaysky - * Copyright (C) SAN People - * - * MultiMedia Card Interface (MCI) registers. - * Based on AT91RM9200 datasheet revision F. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_MCI_H -#define AT91_MCI_H - -#define AT91_MCI_CR		0x00		/* Control Register */ -#define		AT91_MCI_MCIEN		(1 <<  0)	/* Multi-Media Interface Enable */ -#define		AT91_MCI_MCIDIS		(1 <<  1)	/* Multi-Media Interface Disable */ -#define		AT91_MCI_PWSEN		(1 <<  2)	/* Power Save Mode Enable */ -#define		AT91_MCI_PWSDIS		(1 <<  3)	/* Power Save Mode Disable */ -#define		AT91_MCI_SWRST		(1 <<  7)	/* Software Reset */ - -#define AT91_MCI_MR		0x04		/* Mode Register */ -#define		AT91_MCI_CLKDIV		(0xff  <<  0)	/* Clock Divider */ -#define		AT91_MCI_PWSDIV		(7     <<  8)	/* Power Saving Divider */ -#define		AT91_MCI_RDPROOF	(1     << 11)	/* Read Proof Enable [SAM926[03] only] */ -#define		AT91_MCI_WRPROOF	(1     << 12)	/* Write Proof Enable [SAM926[03] only] */ -#define		AT91_MCI_PDCFBYTE	(1     << 13)	/* PDC Force Byte Transfer [SAM926[03] only] */ -#define		AT91_MCI_PDCPADV	(1     << 14)	/* PDC Padding Value */ -#define		AT91_MCI_PDCMODE	(1     << 15)	/* PDC-orientated Mode */ -#define		AT91_MCI_BLKLEN		(0xfff << 18)	/* Data Block Length */ - -#define AT91_MCI_DTOR		0x08		/* Data Timeout Register */ -#define		AT91_MCI_DTOCYC		(0xf << 0)	/* Data Timeout Cycle Number */ -#define		AT91_MCI_DTOMUL		(7   << 4)	/* Data Timeout Multiplier */ -#define		AT91_MCI_DTOMUL_1		(0 <<  4) -#define		AT91_MCI_DTOMUL_16		(1 <<  4) -#define		AT91_MCI_DTOMUL_128		(2 <<  4) -#define		AT91_MCI_DTOMUL_256		(3 <<  4) -#define		AT91_MCI_DTOMUL_1K		(4 <<  4) -#define		AT91_MCI_DTOMUL_4K		(5 <<  4) -#define		AT91_MCI_DTOMUL_64K		(6 <<  4) -#define		AT91_MCI_DTOMUL_1M		(7 <<  4) - -#define AT91_MCI_SDCR		0x0c		/* SD Card Register */ -#define		AT91_MCI_SDCSEL		(3 << 0)	/* SD Card Selector */ -#define		AT91_MCI_SDCBUS		(1 << 7)	/* 1-bit or 4-bit bus */ - -#define AT91_MCI_ARGR		0x10		/* Argument Register */ - -#define AT91_MCI_CMDR		0x14		/* Command Register */ -#define		AT91_MCI_CMDNB		(0x3f << 0)	/* Command Number */ -#define		AT91_MCI_RSPTYP		(3    << 6)	/* Response Type */ -#define			AT91_MCI_RSPTYP_NONE	(0 <<  6) -#define			AT91_MCI_RSPTYP_48	(1 <<  6) -#define			AT91_MCI_RSPTYP_136	(2 <<  6) -#define		AT91_MCI_SPCMD		(7    << 8)	/* Special Command */ -#define			AT91_MCI_SPCMD_NONE	(0 <<  8) -#define			AT91_MCI_SPCMD_INIT	(1 <<  8) -#define			AT91_MCI_SPCMD_SYNC	(2 <<  8) -#define			AT91_MCI_SPCMD_ICMD	(4 <<  8) -#define			AT91_MCI_SPCMD_IRESP	(5 <<  8) -#define		AT91_MCI_OPDCMD		(1 << 11)	/* Open Drain Command */ -#define		AT91_MCI_MAXLAT		(1 << 12)	/* Max Latency for Command to Response */ -#define		AT91_MCI_TRCMD		(3 << 16)	/* Transfer Command */ -#define			AT91_MCI_TRCMD_NONE	(0 << 16) -#define			AT91_MCI_TRCMD_START	(1 << 16) -#define			AT91_MCI_TRCMD_STOP	(2 << 16) -#define		AT91_MCI_TRDIR		(1 << 18)	/* Transfer Direction */ -#define		AT91_MCI_TRTYP		(3 << 19)	/* Transfer Type */ -#define			AT91_MCI_TRTYP_BLOCK	(0 << 19) -#define			AT91_MCI_TRTYP_MULTIPLE	(1 << 19) -#define			AT91_MCI_TRTYP_STREAM	(2 << 19) - -#define AT91_MCI_BLKR		0x18		/* Block Register */ -#define		AT91_MCI_BLKR_BCNT(n)	((0xffff & (n)) << 0)	/* Block count */ -#define		AT91_MCI_BLKR_BLKLEN(n)	((0xffff & (n)) << 16)	/* Block length */ - -#define AT91_MCI_RSPR(n)	(0x20 + ((n) * 4))	/* Response Registers 0-3 */ -#define AT91_MCR_RDR		0x30		/* Receive Data Register */ -#define AT91_MCR_TDR		0x34		/* Transmit Data Register */ - -#define AT91_MCI_SR		0x40		/* Status Register */ -#define		AT91_MCI_CMDRDY		(1 <<  0)	/* Command Ready */ -#define		AT91_MCI_RXRDY		(1 <<  1)	/* Receiver Ready */ -#define		AT91_MCI_TXRDY		(1 <<  2)	/* Transmit Ready */ -#define		AT91_MCI_BLKE		(1 <<  3)	/* Data Block Ended */ -#define		AT91_MCI_DTIP		(1 <<  4)	/* Data Transfer in Progress */ -#define		AT91_MCI_NOTBUSY	(1 <<  5)	/* Data Not Busy */ -#define		AT91_MCI_ENDRX		(1 <<  6)	/* End of RX Buffer */ -#define		AT91_MCI_ENDTX		(1 <<  7)	/* End fo TX Buffer */ -#define		AT91_MCI_SDIOIRQA	(1 <<  8)	/* SDIO Interrupt for Slot A */ -#define		AT91_MCI_SDIOIRQB	(1 <<  9)	/* SDIO Interrupt for Slot B */ -#define		AT91_MCI_RXBUFF		(1 << 14)	/* RX Buffer Full */ -#define		AT91_MCI_TXBUFE		(1 << 15)	/* TX Buffer Empty */ -#define		AT91_MCI_RINDE		(1 << 16)	/* Response Index Error */ -#define		AT91_MCI_RDIRE		(1 << 17)	/* Response Direction Error */ -#define		AT91_MCI_RCRCE		(1 << 18)	/* Response CRC Error */ -#define		AT91_MCI_RENDE		(1 << 19)	/* Response End Bit Error */ -#define		AT91_MCI_RTOE		(1 << 20)	/* Reponse Time-out Error */ -#define		AT91_MCI_DCRCE		(1 << 21)	/* Data CRC Error */ -#define		AT91_MCI_DTOE		(1 << 22)	/* Data Time-out Error */ -#define		AT91_MCI_OVRE		(1 << 30)	/* Overrun */ -#define		AT91_MCI_UNRE		(1 << 31)	/* Underrun */ - -#define AT91_MCI_IER		0x44		/* Interrupt Enable Register */ -#define AT91_MCI_IDR		0x48		/* Interrupt Disable Register */ -#define AT91_MCI_IMR		0x4c		/* Interrupt Mask Register */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_pio.h b/arch/arm/mach-at91/include/mach/at91_pio.h index c6a31bf8a5c..732b11c37f1 100644 --- a/arch/arm/mach-at91/include/mach/at91_pio.h +++ b/arch/arm/mach-at91/include/mach/at91_pio.h @@ -40,10 +40,35 @@  #define PIO_PUER	0x64	/* Pull-up Enable Register */  #define PIO_PUSR	0x68	/* Pull-up Status Register */  #define PIO_ASR		0x70	/* Peripheral A Select Register */ +#define PIO_ABCDSR1	0x70	/* Peripheral ABCD Select Register 1 [some sam9 only] */  #define PIO_BSR		0x74	/* Peripheral B Select Register */ +#define PIO_ABCDSR2	0x74	/* Peripheral ABCD Select Register 2 [some sam9 only] */  #define PIO_ABSR	0x78	/* AB Status Register */ +#define PIO_IFSCDR	0x80	/* Input Filter Slow Clock Disable Register */ +#define PIO_IFSCER	0x84	/* Input Filter Slow Clock Enable Register */ +#define PIO_IFSCSR	0x88	/* Input Filter Slow Clock Status Register */ +#define PIO_SCDR	0x8c	/* Slow Clock Divider Debouncing Register */ +#define		PIO_SCDR_DIV	(0x3fff <<  0)		/* Slow Clock Divider Mask */ +#define PIO_PPDDR	0x90	/* Pad Pull-down Disable Register */ +#define PIO_PPDER	0x94	/* Pad Pull-down Enable Register */ +#define PIO_PPDSR	0x98	/* Pad Pull-down Status Register */  #define PIO_OWER	0xa0	/* Output Write Enable Register */  #define PIO_OWDR	0xa4	/* Output Write Disable Register */  #define PIO_OWSR	0xa8	/* Output Write Status Register */ +#define PIO_AIMER	0xb0	/* Additional Interrupt Modes Enable Register */ +#define PIO_AIMDR	0xb4	/* Additional Interrupt Modes Disable Register */ +#define PIO_AIMMR	0xb8	/* Additional Interrupt Modes Mask Register */ +#define PIO_ESR		0xc0	/* Edge Select Register */ +#define PIO_LSR		0xc4	/* Level Select Register */ +#define PIO_ELSR	0xc8	/* Edge/Level Status Register */ +#define PIO_FELLSR	0xd0	/* Falling Edge/Low Level Select Register */ +#define PIO_REHLSR	0xd4	/* Rising Edge/ High Level Select Register */ +#define PIO_FRLHSR	0xd8	/* Fall/Rise - Low/High Status Register */ +#define PIO_SCHMITT	0x100	/* Schmitt Trigger Register */ + +#define ABCDSR_PERIPH_A	0x0 +#define ABCDSR_PERIPH_B	0x1 +#define ABCDSR_PERIPH_C	0x2 +#define ABCDSR_PERIPH_D	0x3  #endif diff --git a/arch/arm/mach-at91/include/mach/at91_pit.h b/arch/arm/mach-at91/include/mach/at91_pit.h deleted file mode 100644 index 974d0bd05b5..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_pit.h +++ /dev/null @@ -1,32 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_pit.h - * - * Copyright (C) 2007 Andrew Victor - * Copyright (C) 2007 Atmel Corporation. - * - * Periodic Interval Timer (PIT) - System peripherals regsters. - * Based on AT91SAM9261 datasheet revision D. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_PIT_H -#define AT91_PIT_H - -#define AT91_PIT_MR		(AT91_PIT + 0x00)	/* Mode Register */ -#define		AT91_PIT_PITIEN		(1 << 25)		/* Timer Interrupt Enable */ -#define		AT91_PIT_PITEN		(1 << 24)		/* Timer Enabled */ -#define		AT91_PIT_PIV		(0xfffff)		/* Periodic Interval Value */ - -#define AT91_PIT_SR		(AT91_PIT + 0x04)	/* Status Register */ -#define		AT91_PIT_PITS		(1 << 0)		/* Timer Status */ - -#define AT91_PIT_PIVR		(AT91_PIT + 0x08)	/* Periodic Interval Value Register */ -#define AT91_PIT_PIIR		(AT91_PIT + 0x0c)	/* Periodic Interval Image Register */ -#define		AT91_PIT_PICNT		(0xfff << 20)		/* Interval Counter */ -#define		AT91_PIT_CPIV		(0xfffff)		/* Inverval Value */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_pmc.h b/arch/arm/mach-at91/include/mach/at91_pmc.h deleted file mode 100644 index e46f93e34aa..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_pmc.h +++ /dev/null @@ -1,133 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_pmc.h - * - * Copyright (C) 2005 Ivan Kokshaysky - * Copyright (C) SAN People - * - * Power Management Controller (PMC) - System peripherals registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_PMC_H -#define AT91_PMC_H - -#define	AT91_PMC_SCER		(AT91_PMC + 0x00)	/* System Clock Enable Register */ -#define	AT91_PMC_SCDR		(AT91_PMC + 0x04)	/* System Clock Disable Register */ - -#define	AT91_PMC_SCSR		(AT91_PMC + 0x08)	/* System Clock Status Register */ -#define		AT91_PMC_PCK		(1 <<  0)		/* Processor Clock */ -#define		AT91RM9200_PMC_UDP	(1 <<  1)		/* USB Devcice Port Clock [AT91RM9200 only] */ -#define		AT91RM9200_PMC_MCKUDP	(1 <<  2)		/* USB Device Port Master Clock Automatic Disable on Suspend [AT91RM9200 only] */ -#define		AT91CAP9_PMC_DDR	(1 <<  2)		/* DDR Clock [CAP9 revC & some SAM9 only] */ -#define		AT91RM9200_PMC_UHP	(1 <<  4)		/* USB Host Port Clock [AT91RM9200 only] */ -#define		AT91SAM926x_PMC_UHP	(1 <<  6)		/* USB Host Port Clock [AT91SAM926x only] */ -#define		AT91CAP9_PMC_UHP	(1 <<  6)		/* USB Host Port Clock [AT91CAP9 only] */ -#define		AT91SAM926x_PMC_UDP	(1 <<  7)		/* USB Devcice Port Clock [AT91SAM926x only] */ -#define		AT91_PMC_PCK0		(1 <<  8)		/* Programmable Clock 0 */ -#define		AT91_PMC_PCK1		(1 <<  9)		/* Programmable Clock 1 */ -#define		AT91_PMC_PCK2		(1 << 10)		/* Programmable Clock 2 */ -#define		AT91_PMC_PCK3		(1 << 11)		/* Programmable Clock 3 */ -#define		AT91_PMC_PCK4		(1 << 12)		/* Programmable Clock 4 [AT572D940HF only] */ -#define		AT91_PMC_HCK0		(1 << 16)		/* AHB Clock (USB host) [AT91SAM9261 only] */ -#define		AT91_PMC_HCK1		(1 << 17)		/* AHB Clock (LCD) [AT91SAM9261 only] */ - -#define	AT91_PMC_PCER		(AT91_PMC + 0x10)	/* Peripheral Clock Enable Register */ -#define	AT91_PMC_PCDR		(AT91_PMC + 0x14)	/* Peripheral Clock Disable Register */ -#define	AT91_PMC_PCSR		(AT91_PMC + 0x18)	/* Peripheral Clock Status Register */ - -#define	AT91_CKGR_UCKR		(AT91_PMC + 0x1C)	/* UTMI Clock Register [some SAM9, CAP9] */ -#define		AT91_PMC_UPLLEN		(1   << 16)		/* UTMI PLL Enable */ -#define		AT91_PMC_UPLLCOUNT	(0xf << 20)		/* UTMI PLL Start-up Time */ -#define		AT91_PMC_BIASEN		(1   << 24)		/* UTMI BIAS Enable */ -#define		AT91_PMC_BIASCOUNT	(0xf << 28)		/* UTMI BIAS Start-up Time */ - -#define	AT91_CKGR_MOR		(AT91_PMC + 0x20)	/* Main Oscillator Register [not on SAM9RL] */ -#define		AT91_PMC_MOSCEN		(1    << 0)		/* Main Oscillator Enable */ -#define		AT91_PMC_OSCBYPASS	(1    << 1)		/* Oscillator Bypass [SAM9x, CAP9] */ -#define		AT91_PMC_OSCOUNT	(0xff << 8)		/* Main Oscillator Start-up Time */ - -#define	AT91_CKGR_MCFR		(AT91_PMC + 0x24)	/* Main Clock Frequency Register */ -#define		AT91_PMC_MAINF		(0xffff <<  0)		/* Main Clock Frequency */ -#define		AT91_PMC_MAINRDY	(1	<< 16)		/* Main Clock Ready */ - -#define	AT91_CKGR_PLLAR		(AT91_PMC + 0x28)	/* PLL A Register */ -#define	AT91_CKGR_PLLBR		(AT91_PMC + 0x2c)	/* PLL B Register */ -#define		AT91_PMC_DIV		(0xff  <<  0)		/* Divider */ -#define		AT91_PMC_PLLCOUNT	(0x3f  <<  8)		/* PLL Counter */ -#define		AT91_PMC_OUT		(3     << 14)		/* PLL Clock Frequency Range */ -#define		AT91_PMC_MUL		(0x7ff << 16)		/* PLL Multiplier */ -#define		AT91_PMC_USBDIV		(3     << 28)		/* USB Divisor (PLLB only) */ -#define			AT91_PMC_USBDIV_1		(0 << 28) -#define			AT91_PMC_USBDIV_2		(1 << 28) -#define			AT91_PMC_USBDIV_4		(2 << 28) -#define		AT91_PMC_USB96M		(1     << 28)		/* Divider by 2 Enable (PLLB only) */ - -#define	AT91_PMC_MCKR		(AT91_PMC + 0x30)	/* Master Clock Register */ -#define		AT91_PMC_CSS		(3 <<  0)		/* Master Clock Selection */ -#define			AT91_PMC_CSS_SLOW		(0 << 0) -#define			AT91_PMC_CSS_MAIN		(1 << 0) -#define			AT91_PMC_CSS_PLLA		(2 << 0) -#define			AT91_PMC_CSS_PLLB		(3 << 0) -#define			AT91_PMC_CSS_UPLL		(3 << 0)	/* [some SAM9 only] */ -#define		AT91_PMC_PRES		(7 <<  2)		/* Master Clock Prescaler */ -#define			AT91_PMC_PRES_1			(0 << 2) -#define			AT91_PMC_PRES_2			(1 << 2) -#define			AT91_PMC_PRES_4			(2 << 2) -#define			AT91_PMC_PRES_8			(3 << 2) -#define			AT91_PMC_PRES_16		(4 << 2) -#define			AT91_PMC_PRES_32		(5 << 2) -#define			AT91_PMC_PRES_64		(6 << 2) -#define		AT91_PMC_MDIV		(3 <<  8)		/* Master Clock Division */ -#define			AT91RM9200_PMC_MDIV_1		(0 << 8)	/* [AT91RM9200 only] */ -#define			AT91RM9200_PMC_MDIV_2		(1 << 8) -#define			AT91RM9200_PMC_MDIV_3		(2 << 8) -#define			AT91RM9200_PMC_MDIV_4		(3 << 8) -#define			AT91SAM9_PMC_MDIV_1		(0 << 8)	/* [SAM9,CAP9 only] */ -#define			AT91SAM9_PMC_MDIV_2		(1 << 8) -#define			AT91SAM9_PMC_MDIV_4		(2 << 8) -#define			AT91SAM9_PMC_MDIV_6		(3 << 8)	/* [some SAM9 only] */ -#define			AT91SAM9_PMC_MDIV_3		(3 << 8)	/* [some SAM9 only] */ -#define		AT91_PMC_PDIV		(1 << 12)		/* Processor Clock Division [some SAM9 only] */ -#define			AT91_PMC_PDIV_1			(0 << 12) -#define			AT91_PMC_PDIV_2			(1 << 12) -#define		AT91_PMC_PLLADIV2	(1 << 12)		/* PLLA divisor by 2 [some SAM9 only] */ -#define			AT91_PMC_PLLADIV2_OFF		(0 << 12) -#define			AT91_PMC_PLLADIV2_ON		(1 << 12) - -#define	AT91_PMC_USB		(AT91_PMC + 0x38)	/* USB Clock Register [some SAM9 only] */ -#define		AT91_PMC_USBS		(0x1 <<  0)		/* USB OHCI Input clock selection */ -#define			AT91_PMC_USBS_PLLA		(0 << 0) -#define			AT91_PMC_USBS_UPLL		(1 << 0) -#define		AT91_PMC_OHCIUSBDIV	(0xF <<  8)		/* Divider for USB OHCI Clock */ - -#define	AT91_PMC_PCKR(n)	(AT91_PMC + 0x40 + ((n) * 4))	/* Programmable Clock 0-N Registers */ -#define		AT91_PMC_CSSMCK		(0x1 <<  8)		/* CSS or Master Clock Selection */ -#define			AT91_PMC_CSSMCK_CSS		(0 << 8) -#define			AT91_PMC_CSSMCK_MCK		(1 << 8) - -#define	AT91_PMC_IER		(AT91_PMC + 0x60)	/* Interrupt Enable Register */ -#define	AT91_PMC_IDR		(AT91_PMC + 0x64)	/* Interrupt Disable Register */ -#define	AT91_PMC_SR		(AT91_PMC + 0x68)	/* Status Register */ -#define		AT91_PMC_MOSCS		(1 <<  0)		/* MOSCS Flag */ -#define		AT91_PMC_LOCKA		(1 <<  1)		/* PLLA Lock */ -#define		AT91_PMC_LOCKB		(1 <<  2)		/* PLLB Lock */ -#define		AT91_PMC_MCKRDY		(1 <<  3)		/* Master Clock */ -#define		AT91_PMC_LOCKU		(1 <<  6)		/* UPLL Lock [some SAM9, AT91CAP9 only] */ -#define		AT91_PMC_OSCSEL		(1 <<  7)		/* Slow Clock Oscillator [AT91CAP9 revC only] */ -#define		AT91_PMC_PCK0RDY	(1 <<  8)		/* Programmable Clock 0 */ -#define		AT91_PMC_PCK1RDY	(1 <<  9)		/* Programmable Clock 1 */ -#define		AT91_PMC_PCK2RDY	(1 << 10)		/* Programmable Clock 2 */ -#define		AT91_PMC_PCK3RDY	(1 << 11)		/* Programmable Clock 3 */ -#define	AT91_PMC_IMR		(AT91_PMC + 0x6c)	/* Interrupt Mask Register */ - -#define AT91_PMC_PROT		(AT91_PMC + 0xe4)	/* Protect Register [AT91CAP9 revC only] */ -#define		AT91_PMC_PROTKEY	0x504d4301	/* Activation Code */ - -#define AT91_PMC_VER		(AT91_PMC + 0xfc)	/* PMC Module Version [AT91CAP9 only] */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_ramc.h b/arch/arm/mach-at91/include/mach/at91_ramc.h new file mode 100644 index 00000000000..d8aeb278614 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91_ramc.h @@ -0,0 +1,32 @@ +/* + * Header file for the Atmel RAM Controller + * + * Copyright (C) 2011 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> + * + * Under GPLv2 only + */ + +#ifndef __AT91_RAMC_H__ +#define __AT91_RAMC_H__ + +#ifndef __ASSEMBLY__ +extern void __iomem *at91_ramc_base[]; + +#define at91_ramc_read(id, field) \ +	__raw_readl(at91_ramc_base[id] + field) + +#define at91_ramc_write(id, field, value) \ +	__raw_writel(value, at91_ramc_base[id] + field) +#else +.extern at91_ramc_base +#endif + +#define AT91_MEMCTRL_MC		0 +#define AT91_MEMCTRL_SDRAMC	1 +#define AT91_MEMCTRL_DDRSDR	2 + +#include <mach/at91rm9200_sdramc.h> +#include <mach/at91sam9_ddrsdr.h> +#include <mach/at91sam9_sdramc.h> + +#endif /* __AT91_RAMC_H__ */ diff --git a/arch/arm/mach-at91/include/mach/at91_rstc.h b/arch/arm/mach-at91/include/mach/at91_rstc.h deleted file mode 100644 index cbd2bf052c1..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_rstc.h +++ /dev/null @@ -1,41 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_rstc.h - * - * Copyright (C) 2007 Andrew Victor - * Copyright (C) 2007 Atmel Corporation. - * - * Reset Controller (RSTC) - System peripherals regsters. - * Based on AT91SAM9261 datasheet revision D. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_RSTC_H -#define AT91_RSTC_H - -#define AT91_RSTC_CR		(AT91_RSTC + 0x00)	/* Reset Controller Control Register */ -#define		AT91_RSTC_PROCRST	(1 << 0)		/* Processor Reset */ -#define		AT91_RSTC_PERRST	(1 << 2)		/* Peripheral Reset */ -#define		AT91_RSTC_EXTRST	(1 << 3)		/* External Reset */ -#define		AT91_RSTC_KEY		(0xa5 << 24)		/* KEY Password */ - -#define AT91_RSTC_SR		(AT91_RSTC + 0x04)	/* Reset Controller Status Register */ -#define		AT91_RSTC_URSTS		(1 << 0)		/* User Reset Status */ -#define		AT91_RSTC_RSTTYP	(7 << 8)		/* Reset Type */ -#define			AT91_RSTC_RSTTYP_GENERAL	(0 << 8) -#define			AT91_RSTC_RSTTYP_WAKEUP		(1 << 8) -#define			AT91_RSTC_RSTTYP_WATCHDOG	(2 << 8) -#define			AT91_RSTC_RSTTYP_SOFTWARE	(3 << 8) -#define			AT91_RSTC_RSTTYP_USER	(4 << 8) -#define		AT91_RSTC_NRSTL		(1 << 16)		/* NRST Pin Level */ -#define		AT91_RSTC_SRCMP		(1 << 17)		/* Software Reset Command in Progress */ - -#define AT91_RSTC_MR		(AT91_RSTC + 0x08)	/* Reset Controller Mode Register */ -#define		AT91_RSTC_URSTEN	(1 << 0)		/* User Reset Enable */ -#define		AT91_RSTC_URSTIEN	(1 << 4)		/* User Reset Interrupt Enable */ -#define		AT91_RSTC_ERSTL		(0xf << 8)		/* External Reset Length */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_rtc.h b/arch/arm/mach-at91/include/mach/at91_rtc.h deleted file mode 100644 index e56f4701a3e..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_rtc.h +++ /dev/null @@ -1,75 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_rtc.h - * - * Copyright (C) 2005 Ivan Kokshaysky - * Copyright (C) SAN People - * - * Real Time Clock (RTC) - System peripheral registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_RTC_H -#define AT91_RTC_H - -#define	AT91_RTC_CR		(AT91_RTC + 0x00)	/* Control Register */ -#define		AT91_RTC_UPDTIM		(1 <<  0)		/* Update Request Time Register */ -#define		AT91_RTC_UPDCAL		(1 <<  1)		/* Update Request Calendar Register */ -#define		AT91_RTC_TIMEVSEL	(3 <<  8)		/* Time Event Selection */ -#define			AT91_RTC_TIMEVSEL_MINUTE	(0 << 8) -#define			AT91_RTC_TIMEVSEL_HOUR		(1 << 8) -#define			AT91_RTC_TIMEVSEL_DAY24		(2 << 8) -#define			AT91_RTC_TIMEVSEL_DAY12		(3 << 8) -#define		AT91_RTC_CALEVSEL	(3 << 16)		/* Calendar Event Selection */ -#define			AT91_RTC_CALEVSEL_WEEK		(0 << 16) -#define			AT91_RTC_CALEVSEL_MONTH		(1 << 16) -#define			AT91_RTC_CALEVSEL_YEAR		(2 << 16) - -#define	AT91_RTC_MR		(AT91_RTC + 0x04)	/* Mode Register */ -#define			AT91_RTC_HRMOD		(1 <<  0)		/* 12/24 Hour Mode */ - -#define	AT91_RTC_TIMR		(AT91_RTC + 0x08)	/* Time Register */ -#define		AT91_RTC_SEC		(0x7f <<  0)		/* Current Second */ -#define		AT91_RTC_MIN		(0x7f <<  8)		/* Current Minute */ -#define		AT91_RTC_HOUR		(0x3f << 16)		/* Current Hour */ -#define		AT91_RTC_AMPM		(1    << 22)		/* Ante Meridiem Post Meridiem Indicator */ - -#define	AT91_RTC_CALR		(AT91_RTC + 0x0c)	/* Calendar Register */ -#define		AT91_RTC_CENT		(0x7f <<  0)		/* Current Century */ -#define		AT91_RTC_YEAR		(0xff <<  8)		/* Current Year */ -#define		AT91_RTC_MONTH		(0x1f << 16)		/* Current Month */ -#define		AT91_RTC_DAY		(7    << 21)		/* Current Day */ -#define		AT91_RTC_DATE		(0x3f << 24)		/* Current Date */ - -#define	AT91_RTC_TIMALR		(AT91_RTC + 0x10)	/* Time Alarm Register */ -#define		AT91_RTC_SECEN		(1 <<  7)		/* Second Alarm Enable */ -#define		AT91_RTC_MINEN		(1 << 15)		/* Minute Alarm Enable */ -#define		AT91_RTC_HOUREN		(1 << 23)		/* Hour Alarm Enable */ - -#define	AT91_RTC_CALALR		(AT91_RTC + 0x14)	/* Calendar Alarm Register */ -#define		AT91_RTC_MTHEN		(1 << 23)		/* Month Alarm Enable */ -#define		AT91_RTC_DATEEN		(1 << 31)		/* Date Alarm Enable */ - -#define	AT91_RTC_SR		(AT91_RTC + 0x18)	/* Status Register */ -#define		AT91_RTC_ACKUPD		(1 <<  0)		/* Acknowledge for Update */ -#define		AT91_RTC_ALARM		(1 <<  1)		/* Alarm Flag */ -#define		AT91_RTC_SECEV		(1 <<  2)		/* Second Event */ -#define		AT91_RTC_TIMEV		(1 <<  3)		/* Time Event */ -#define		AT91_RTC_CALEV		(1 <<  4)		/* Calendar Event */ - -#define	AT91_RTC_SCCR		(AT91_RTC + 0x1c)	/* Status Clear Command Register */ -#define	AT91_RTC_IER		(AT91_RTC + 0x20)	/* Interrupt Enable Register */ -#define	AT91_RTC_IDR		(AT91_RTC + 0x24)	/* Interrupt Disable Register */ -#define	AT91_RTC_IMR		(AT91_RTC + 0x28)	/* Interrupt Mask Register */ - -#define	AT91_RTC_VER		(AT91_RTC + 0x2c)	/* Valid Entry Register */ -#define		AT91_RTC_NVTIM		(1 <<  0)		/* Non valid Time */ -#define		AT91_RTC_NVCAL		(1 <<  1)		/* Non valid Calendar */ -#define		AT91_RTC_NVTIMALR	(1 <<  2)		/* Non valid Time Alarm */ -#define		AT91_RTC_NVCALALR	(1 <<  3)		/* Non valid Calendar Alarm */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_shdwc.h b/arch/arm/mach-at91/include/mach/at91_shdwc.h deleted file mode 100644 index c4ce07e8a8f..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_shdwc.h +++ /dev/null @@ -1,38 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_shdwc.h - * - * Copyright (C) 2007 Andrew Victor - * Copyright (C) 2007 Atmel Corporation. - * - * Shutdown Controller (SHDWC) - System peripherals regsters. - * Based on AT91SAM9261 datasheet revision D. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_SHDWC_H -#define AT91_SHDWC_H - -#define AT91_SHDW_CR		(AT91_SHDWC + 0x00)	/* Shut Down Control Register */ -#define		AT91_SHDW_SHDW		(1    << 0)		/* Shut Down command */ -#define		AT91_SHDW_KEY		(0xa5 << 24)		/* KEY Password */ - -#define AT91_SHDW_MR		(AT91_SHDWC + 0x04)	/* Shut Down Mode Register */ -#define		AT91_SHDW_WKMODE0	(3 << 0)		/* Wake-up 0 Mode Selection */ -#define			AT91_SHDW_WKMODE0_NONE		0 -#define			AT91_SHDW_WKMODE0_HIGH		1 -#define			AT91_SHDW_WKMODE0_LOW		2 -#define			AT91_SHDW_WKMODE0_ANYLEVEL	3 -#define		AT91_SHDW_CPTWK0	(0xf << 4)		/* Counter On Wake Up 0 */ -#define			AT91_SHDW_CPTWK0_(x)	((x) << 4) -#define		AT91_SHDW_RTTWKEN	(1   << 16)		/* Real Time Timer Wake-up Enable */ - -#define AT91_SHDW_SR		(AT91_SHDWC + 0x08)	/* Shut Down Status Register */ -#define		AT91_SHDW_WAKEUP0	(1 <<  0)		/* Wake-up 0 Status */ -#define		AT91_SHDW_RTTWK		(1 << 16)		/* Real-time Timer Wake-up */ -#define		AT91_SHDW_RTCWK		(1 << 17)		/* Real-time Clock Wake-up [SAM9RL] */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_spi.h b/arch/arm/mach-at91/include/mach/at91_spi.h deleted file mode 100644 index 2f6ba0c5636..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_spi.h +++ /dev/null @@ -1,81 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_spi.h - * - * Copyright (C) 2005 Ivan Kokshaysky - * Copyright (C) SAN People - * - * Serial Peripheral Interface (SPI) registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_SPI_H -#define AT91_SPI_H - -#define AT91_SPI_CR			0x00		/* Control Register */ -#define		AT91_SPI_SPIEN		(1 <<  0)		/* SPI Enable */ -#define		AT91_SPI_SPIDIS		(1 <<  1)		/* SPI Disable */ -#define		AT91_SPI_SWRST		(1 <<  7)		/* SPI Software Reset */ -#define		AT91_SPI_LASTXFER	(1 << 24)		/* Last Transfer [SAM9261 only] */ - -#define AT91_SPI_MR			0x04		/* Mode Register */ -#define		AT91_SPI_MSTR		(1    <<  0)		/* Master/Slave Mode */ -#define		AT91_SPI_PS		(1    <<  1)		/* Peripheral Select */ -#define			AT91_SPI_PS_FIXED	(0 << 1) -#define			AT91_SPI_PS_VARIABLE	(1 << 1) -#define		AT91_SPI_PCSDEC		(1    <<  2)		/* Chip Select Decode */ -#define		AT91_SPI_DIV32		(1    <<  3)		/* Clock Selection [AT91RM9200 only] */ -#define		AT91_SPI_MODFDIS	(1    <<  4)		/* Mode Fault Detection */ -#define		AT91_SPI_LLB		(1    <<  7)		/* Local Loopback Enable */ -#define		AT91_SPI_PCS		(0xf  << 16)		/* Peripheral Chip Select */ -#define		AT91_SPI_DLYBCS		(0xff << 24)		/* Delay Between Chip Selects */ - -#define AT91_SPI_RDR		0x08			/* Receive Data Register */ -#define		AT91_SPI_RD		(0xffff <<  0)		/* Receive Data */ -#define		AT91_SPI_PCS		(0xf	<< 16)		/* Peripheral Chip Select */ - -#define AT91_SPI_TDR		0x0c			/* Transmit Data Register */ -#define		AT91_SPI_TD		(0xffff <<  0)		/* Transmit Data */ -#define		AT91_SPI_PCS		(0xf	<< 16)		/* Peripheral Chip Select */ -#define		AT91_SPI_LASTXFER	(1	<< 24)		/* Last Transfer [SAM9261 only] */ - -#define AT91_SPI_SR		0x10			/* Status Register */ -#define		AT91_SPI_RDRF		(1 <<  0)		/* Receive Data Register Full */ -#define		AT91_SPI_TDRE		(1 <<  1)		/* Transmit Data Register Full */ -#define		AT91_SPI_MODF		(1 <<  2)		/* Mode Fault Error */ -#define		AT91_SPI_OVRES		(1 <<  3)		/* Overrun Error Status */ -#define		AT91_SPI_ENDRX		(1 <<  4)		/* End of RX buffer */ -#define		AT91_SPI_ENDTX		(1 <<  5)		/* End of TX buffer */ -#define		AT91_SPI_RXBUFF		(1 <<  6)		/* RX Buffer Full */ -#define		AT91_SPI_TXBUFE		(1 <<  7)		/* TX Buffer Empty */ -#define		AT91_SPI_NSSR		(1 <<  8)		/* NSS Rising [SAM9261 only] */ -#define		AT91_SPI_TXEMPTY	(1 <<  9)		/* Transmission Register Empty [SAM9261 only] */ -#define		AT91_SPI_SPIENS		(1 << 16)		/* SPI Enable Status */ - -#define AT91_SPI_IER		0x14			/* Interrupt Enable Register */ -#define AT91_SPI_IDR		0x18			/* Interrupt Disable Register */ -#define AT91_SPI_IMR		0x1c			/* Interrupt Mask Register */ - -#define AT91_SPI_CSR(n)		(0x30 + ((n) * 4))	/* Chip Select Registers 0-3 */ -#define		AT91_SPI_CPOL		(1    <<  0)		/* Clock Polarity */ -#define		AT91_SPI_NCPHA		(1    <<  1)		/* Clock Phase */ -#define		AT91_SPI_CSAAT		(1    <<  3)		/* Chip Select Active After Transfer [SAM9261 only] */ -#define		AT91_SPI_BITS		(0xf  <<  4)		/* Bits Per Transfer */ -#define			AT91_SPI_BITS_8		(0 << 4) -#define			AT91_SPI_BITS_9		(1 << 4) -#define			AT91_SPI_BITS_10	(2 << 4) -#define			AT91_SPI_BITS_11	(3 << 4) -#define			AT91_SPI_BITS_12	(4 << 4) -#define			AT91_SPI_BITS_13	(5 << 4) -#define			AT91_SPI_BITS_14	(6 << 4) -#define			AT91_SPI_BITS_15	(7 << 4) -#define			AT91_SPI_BITS_16	(8 << 4) -#define		AT91_SPI_SCBR		(0xff <<  8)		/* Serial Clock Baud Rate */ -#define		AT91_SPI_DLYBS		(0xff << 16)		/* Delay before SPCK */ -#define		AT91_SPI_DLYBCT		(0xff << 24)		/* Delay between Consecutive Transfers */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_ssc.h b/arch/arm/mach-at91/include/mach/at91_ssc.h deleted file mode 100644 index a81114c11c7..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_ssc.h +++ /dev/null @@ -1,106 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_ssc.h - * - * Copyright (C) SAN People - * - * Serial Synchronous Controller (SSC) registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_SSC_H -#define AT91_SSC_H - -#define AT91_SSC_CR		0x00	/* Control Register */ -#define		AT91_SSC_RXEN		(1 <<  0)	/* Receive Enable */ -#define		AT91_SSC_RXDIS		(1 <<  1)	/* Receive Disable */ -#define		AT91_SSC_TXEN		(1 <<  8)	/* Transmit Enable */ -#define		AT91_SSC_TXDIS		(1 <<  9)	/* Transmit Disable */ -#define		AT91_SSC_SWRST		(1 << 15)	/* Software Reset */ - -#define AT91_SSC_CMR		0x04	/* Clock Mode Register */ -#define		AT91_SSC_CMR_DIV	(0xfff << 0)	/* Clock Divider */ - -#define AT91_SSC_RCMR		0x10	/* Receive Clock Mode Register */ -#define		AT91_SSC_CKS		(3    <<  0)	/* Clock Selection */ -#define			AT91_SSC_CKS_DIV		(0 << 0) -#define			AT91_SSC_CKS_CLOCK		(1 << 0) -#define			AT91_SSC_CKS_PIN		(2 << 0) -#define		AT91_SSC_CKO		(7    <<  2)	/* Clock Output Mode Selection */ -#define			AT91_SSC_CKO_NONE		(0 << 2) -#define			AT91_SSC_CKO_CONTINUOUS		(1 << 2) -#define		AT91_SSC_CKI		(1    <<  5)	/* Clock Inversion */ -#define			AT91_SSC_CKI_FALLING		(0 << 5) -#define			AT91_SSC_CK_RISING		(1 << 5) -#define		AT91_SSC_CKG		(1    <<  6)	/* Receive Clock Gating Selection [AT91SAM9261 only] */ -#define			AT91_SSC_CKG_NONE		(0 << 6) -#define			AT91_SSC_CKG_RFLOW		(1 << 6) -#define			AT91_SSC_CKG_RFHIGH		(2 << 6) -#define		AT91_SSC_START		(0xf  <<  8)	/* Start Selection */ -#define			AT91_SSC_START_CONTINUOUS	(0 << 8) -#define			AT91_SSC_START_TX_RX		(1 << 8) -#define			AT91_SSC_START_LOW_RF		(2 << 8) -#define			AT91_SSC_START_HIGH_RF		(3 << 8) -#define			AT91_SSC_START_FALLING_RF	(4 << 8) -#define			AT91_SSC_START_RISING_RF	(5 << 8) -#define			AT91_SSC_START_LEVEL_RF		(6 << 8) -#define			AT91_SSC_START_EDGE_RF		(7 << 8) -#define		AT91_SSC_STOP		(1    << 12)	/* Receive Stop Selection [AT91SAM9261 only] */ -#define		AT91_SSC_STTDLY		(0xff << 16)	/* Start Delay */ -#define		AT91_SSC_PERIOD		(0xff << 24)	/* Period Divider Selection */ - -#define AT91_SSC_RFMR		0x14	/* Receive Frame Mode Register */ -#define		AT91_SSC_DATALEN	(0x1f <<  0)	/* Data Length */ -#define		AT91_SSC_LOOP		(1    <<  5)	/* Loop Mode */ -#define		AT91_SSC_MSBF		(1    <<  7)	/* Most Significant Bit First */ -#define		AT91_SSC_DATNB		(0xf  <<  8)	/* Data Number per Frame */ -#define		AT91_SSC_FSLEN		(0xf  << 16)	/* Frame Sync Length */ -#define		AT91_SSC_FSOS		(7    << 20)	/* Frame Sync Output Selection */ -#define			AT91_SSC_FSOS_NONE		(0 << 20) -#define			AT91_SSC_FSOS_NEGATIVE		(1 << 20) -#define			AT91_SSC_FSOS_POSITIVE		(2 << 20) -#define			AT91_SSC_FSOS_LOW		(3 << 20) -#define			AT91_SSC_FSOS_HIGH		(4 << 20) -#define			AT91_SSC_FSOS_TOGGLE		(5 << 20) -#define		AT91_SSC_FSEDGE		(1    << 24)	/* Frame Sync Edge Detection */ -#define			AT91_SSC_FSEDGE_POSITIVE	(0 << 24) -#define			AT91_SSC_FSEDGE_NEGATIVE	(1 << 24) - -#define AT91_SSC_TCMR		0x18	/* Transmit Clock Mode Register */ -#define AT91_SSC_TFMR		0x1c	/* Transmit Fram Mode Register */ -#define		AT91_SSC_DATDEF		(1 <<  5)	/* Data Default Value */ -#define		AT91_SSC_FSDEN		(1 << 23)	/* Frame Sync Data Enable */ - -#define AT91_SSC_RHR		0x20	/* Receive Holding Register */ -#define AT91_SSC_THR		0x24	/* Transmit Holding Register */ -#define AT91_SSC_RSHR		0x30	/* Receive Sync Holding Register */ -#define AT91_SSC_TSHR		0x34	/* Transmit Sync Holding Register */ - -#define AT91_SSC_RC0R		0x38	/* Receive Compare 0 Register [AT91SAM9261 only] */ -#define AT91_SSC_RC1R		0x3c	/* Receive Compare 1 Register [AT91SAM9261 only] */ - -#define AT91_SSC_SR		0x40	/* Status Register */ -#define		AT91_SSC_TXRDY		(1 <<  0)	/* Transmit Ready */ -#define		AT91_SSC_TXEMPTY	(1 <<  1)	/* Transmit Empty */ -#define		AT91_SSC_ENDTX		(1 <<  2)	/* End of Transmission */ -#define		AT91_SSC_TXBUFE		(1 <<  3)	/* Transmit Buffer Empty */ -#define		AT91_SSC_RXRDY		(1 <<  4)	/* Receive Ready */ -#define		AT91_SSC_OVRUN		(1 <<  5)	/* Receive Overrun */ -#define		AT91_SSC_ENDRX		(1 <<  6)	/* End of Reception */ -#define		AT91_SSC_RXBUFF		(1 <<  7)	/* Receive Buffer Full */ -#define		AT91_SSC_CP0		(1 <<  8)	/* Compare 0 [AT91SAM9261 only] */ -#define		AT91_SSC_CP1		(1 <<  9)	/* Compare 1 [AT91SAM9261 only] */ -#define		AT91_SSC_TXSYN		(1 << 10)	/* Transmit Sync */ -#define		AT91_SSC_RXSYN		(1 << 11)	/* Receive Sync */ -#define		AT91_SSC_TXENA		(1 << 16)	/* Transmit Enable */ -#define		AT91_SSC_RXENA		(1 << 17)	/* Receive Enable */ - -#define AT91_SSC_IER		0x44	/* Interrupt Enable Register */ -#define AT91_SSC_IDR		0x48	/* Interrupt Disable Register */ -#define AT91_SSC_IMR		0x4c	/* Interrupt Mask Register */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_st.h b/arch/arm/mach-at91/include/mach/at91_st.h index 8847173e410..67fdbd13c3e 100644 --- a/arch/arm/mach-at91/include/mach/at91_st.h +++ b/arch/arm/mach-at91/include/mach/at91_st.h @@ -16,34 +16,46 @@  #ifndef AT91_ST_H  #define AT91_ST_H -#define	AT91_ST_CR		(AT91_ST + 0x00)	/* Control Register */ +#ifndef __ASSEMBLY__ +extern void __iomem *at91_st_base; + +#define at91_st_read(field) \ +	__raw_readl(at91_st_base + field) + +#define at91_st_write(field, value) \ +	__raw_writel(value, at91_st_base + field) +#else +.extern at91_st_base +#endif + +#define	AT91_ST_CR		0x00			/* Control Register */  #define 	AT91_ST_WDRST		(1 << 0)		/* Watchdog Timer Restart */ -#define	AT91_ST_PIMR		(AT91_ST + 0x04)	/* Period Interval Mode Register */ +#define	AT91_ST_PIMR		0x04			/* Period Interval Mode Register */  #define		AT91_ST_PIV		(0xffff <<  0)		/* Period Interval Value */ -#define	AT91_ST_WDMR		(AT91_ST + 0x08)	/* Watchdog Mode Register */ +#define	AT91_ST_WDMR		0x08			/* Watchdog Mode Register */  #define		AT91_ST_WDV		(0xffff <<  0)		/* Watchdog Counter Value */  #define		AT91_ST_RSTEN		(1	<< 16)		/* Reset Enable */  #define		AT91_ST_EXTEN		(1	<< 17)		/* External Signal Assertion Enable */ -#define	AT91_ST_RTMR		(AT91_ST + 0x0c)	/* Real-time Mode Register */ +#define	AT91_ST_RTMR		0x0c			/* Real-time Mode Register */  #define		AT91_ST_RTPRES		(0xffff <<  0)		/* Real-time Prescalar Value */ -#define	AT91_ST_SR		(AT91_ST + 0x10)	/* Status Register */ +#define	AT91_ST_SR		0x10			/* Status Register */  #define		AT91_ST_PITS		(1 << 0)		/* Period Interval Timer Status */  #define		AT91_ST_WDOVF		(1 << 1) 		/* Watchdog Overflow */  #define		AT91_ST_RTTINC		(1 << 2) 		/* Real-time Timer Increment */  #define		AT91_ST_ALMS		(1 << 3) 		/* Alarm Status */ -#define	AT91_ST_IER		(AT91_ST + 0x14)	/* Interrupt Enable Register */ -#define	AT91_ST_IDR		(AT91_ST + 0x18)	/* Interrupt Disable Register */ -#define	AT91_ST_IMR		(AT91_ST + 0x1c)	/* Interrupt Mask Register */ +#define	AT91_ST_IER		0x14			/* Interrupt Enable Register */ +#define	AT91_ST_IDR		0x18			/* Interrupt Disable Register */ +#define	AT91_ST_IMR		0x1c			/* Interrupt Mask Register */ -#define	AT91_ST_RTAR		(AT91_ST + 0x20)	/* Real-time Alarm Register */ +#define	AT91_ST_RTAR		0x20			/* Real-time Alarm Register */  #define		AT91_ST_ALMV		(0xfffff << 0)		/* Alarm Value */ -#define	AT91_ST_CRTR		(AT91_ST + 0x24)	/* Current Real-time Register */ +#define	AT91_ST_CRTR		0x24			/* Current Real-time Register */  #define		AT91_ST_CRTV		(0xfffff << 0)		/* Current Real-Time Value */  #endif diff --git a/arch/arm/mach-at91/include/mach/at91_tc.h b/arch/arm/mach-at91/include/mach/at91_tc.h deleted file mode 100644 index 46a317fd716..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_tc.h +++ /dev/null @@ -1,146 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_tc.h - * - * Copyright (C) SAN People - * - * Timer/Counter Unit (TC) registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_TC_H -#define AT91_TC_H - -#define AT91_TC_BCR		0xc0		/* TC Block Control Register */ -#define		AT91_TC_SYNC		(1 << 0)	/* Synchro Command */ - -#define AT91_TC_BMR		0xc4		/* TC Block Mode Register */ -#define		AT91_TC_TC0XC0S		(3 << 0)	/* External Clock Signal 0 Selection */ -#define			AT91_TC_TC0XC0S_TCLK0		(0 << 0) -#define			AT91_TC_TC0XC0S_NONE		(1 << 0) -#define			AT91_TC_TC0XC0S_TIOA1		(2 << 0) -#define			AT91_TC_TC0XC0S_TIOA2		(3 << 0) -#define		AT91_TC_TC1XC1S		(3 << 2)	/* External Clock Signal 1 Selection */ -#define			AT91_TC_TC1XC1S_TCLK1		(0 << 2) -#define			AT91_TC_TC1XC1S_NONE		(1 << 2) -#define			AT91_TC_TC1XC1S_TIOA0		(2 << 2) -#define			AT91_TC_TC1XC1S_TIOA2		(3 << 2) -#define		AT91_TC_TC2XC2S		(3 << 4)	/* External Clock Signal 2 Selection */ -#define			AT91_TC_TC2XC2S_TCLK2		(0 << 4) -#define			AT91_TC_TC2XC2S_NONE		(1 << 4) -#define			AT91_TC_TC2XC2S_TIOA0		(2 << 4) -#define			AT91_TC_TC2XC2S_TIOA1		(3 << 4) - - -#define AT91_TC_CCR		0x00		/* Channel Control Register */ -#define		AT91_TC_CLKEN		(1 << 0)	/* Counter Clock Enable Command */ -#define		AT91_TC_CLKDIS		(1 << 1)	/* Counter CLock Disable Command */ -#define		AT91_TC_SWTRG		(1 << 2)	/* Software Trigger Command */ - -#define AT91_TC_CMR		0x04		/* Channel Mode Register */ -#define		AT91_TC_TCCLKS		(7 << 0)	/* Capture/Waveform Mode: Clock Selection */ -#define			AT91_TC_TIMER_CLOCK1		(0 << 0) -#define			AT91_TC_TIMER_CLOCK2		(1 << 0) -#define			AT91_TC_TIMER_CLOCK3		(2 << 0) -#define			AT91_TC_TIMER_CLOCK4		(3 << 0) -#define			AT91_TC_TIMER_CLOCK5		(4 << 0) -#define			AT91_TC_XC0			(5 << 0) -#define			AT91_TC_XC1			(6 << 0) -#define			AT91_TC_XC2			(7 << 0) -#define		AT91_TC_CLKI		(1 << 3)	/* Capture/Waveform Mode: Clock Invert */ -#define		AT91_TC_BURST		(3 << 4)	/* Capture/Waveform Mode: Burst Signal Selection */ -#define		AT91_TC_LDBSTOP		(1 << 6)	/* Capture Mode: Counter Clock Stopped with TB Loading */ -#define		AT91_TC_LDBDIS		(1 << 7)	/* Capture Mode: Counter Clock Disable with RB Loading */ -#define		AT91_TC_ETRGEDG		(3 << 8)	/* Capture Mode: External Trigger Edge Selection */ -#define		AT91_TC_ABETRG		(1 << 10)	/* Capture Mode: TIOA or TIOB External Trigger Selection */ -#define		AT91_TC_CPCTRG		(1 << 14)	/* Capture Mode: RC Compare Trigger Enable */ -#define		AT91_TC_WAVE		(1 << 15)	/* Capture/Waveform mode */ -#define		AT91_TC_LDRA		(3 << 16)	/* Capture Mode: RA Loading Selection */ -#define		AT91_TC_LDRB		(3 << 18)	/* Capture Mode: RB Loading Selection */ - -#define		AT91_TC_CPCSTOP		(1 <<  6)	/* Waveform Mode: Counter Clock Stopped with RC Compare */ -#define		AT91_TC_CPCDIS		(1 <<  7)	/* Waveform Mode: Counter Clock Disable with RC Compare */ -#define		AT91_TC_EEVTEDG		(3 <<  8)	/* Waveform Mode: External Event Edge Selection */ -#define			AT91_TC_EEVTEDG_NONE		(0 << 8) -#define			AT91_TC_EEVTEDG_RISING		(1 << 8) -#define			AT91_TC_EEVTEDG_FALLING		(2 << 8) -#define			AT91_TC_EEVTEDG_BOTH		(3 << 8) -#define		AT91_TC_EEVT		(3 << 10)	/* Waveform Mode: External Event Selection */ -#define			AT91_TC_EEVT_TIOB		(0 << 10) -#define			AT91_TC_EEVT_XC0		(1 << 10) -#define			AT91_TC_EEVT_XC1		(2 << 10) -#define			AT91_TC_EEVT_XC2		(3 << 10) -#define		AT91_TC_ENETRG		(1 << 12)	/* Waveform Mode: External Event Trigger Enable */ -#define		AT91_TC_WAVESEL		(3 << 13)	/* Waveform Mode: Waveform Selection */ -#define			AT91_TC_WAVESEL_UP		(0 << 13) -#define			AT91_TC_WAVESEL_UP_AUTO		(2 << 13) -#define			AT91_TC_WAVESEL_UPDOWN		(1 << 13) -#define			AT91_TC_WAVESEL_UPDOWN_AUTO	(3 << 13) -#define		AT91_TC_ACPA		(3 << 16)	/* Waveform Mode: RA Compare Effect on TIOA */ -#define			AT91_TC_ACPA_NONE		(0 << 16) -#define			AT91_TC_ACPA_SET		(1 << 16) -#define			AT91_TC_ACPA_CLEAR		(2 << 16) -#define			AT91_TC_ACPA_TOGGLE		(3 << 16) -#define		AT91_TC_ACPC		(3 << 18)	/* Waveform Mode: RC Compre Effect on TIOA */ -#define			AT91_TC_ACPC_NONE		(0 << 18) -#define			AT91_TC_ACPC_SET		(1 << 18) -#define			AT91_TC_ACPC_CLEAR		(2 << 18) -#define			AT91_TC_ACPC_TOGGLE		(3 << 18) -#define		AT91_TC_AEEVT		(3 << 20)	/* Waveform Mode: External Event Effect on TIOA */ -#define			AT91_TC_AEEVT_NONE		(0 << 20) -#define			AT91_TC_AEEVT_SET		(1 << 20) -#define			AT91_TC_AEEVT_CLEAR		(2 << 20) -#define			AT91_TC_AEEVT_TOGGLE		(3 << 20) -#define		AT91_TC_ASWTRG		(3 << 22)	/* Waveform Mode: Software Trigger Effect on TIOA */ -#define			AT91_TC_ASWTRG_NONE		(0 << 22) -#define			AT91_TC_ASWTRG_SET		(1 << 22) -#define			AT91_TC_ASWTRG_CLEAR		(2 << 22) -#define			AT91_TC_ASWTRG_TOGGLE		(3 << 22) -#define		AT91_TC_BCPB		(3 << 24)	/* Waveform Mode: RB Compare Effect on TIOB */ -#define			AT91_TC_BCPB_NONE		(0 << 24) -#define			AT91_TC_BCPB_SET		(1 << 24) -#define			AT91_TC_BCPB_CLEAR		(2 << 24) -#define			AT91_TC_BCPB_TOGGLE		(3 << 24) -#define		AT91_TC_BCPC		(3 << 26)	/* Waveform Mode: RC Compare Effect on TIOB */ -#define			AT91_TC_BCPC_NONE		(0 << 26) -#define			AT91_TC_BCPC_SET		(1 << 26) -#define			AT91_TC_BCPC_CLEAR		(2 << 26) -#define			AT91_TC_BCPC_TOGGLE		(3 << 26) -#define		AT91_TC_BEEVT		(3 << 28)	/* Waveform Mode: External Event Effect on TIOB */ -#define			AT91_TC_BEEVT_NONE		(0 << 28) -#define			AT91_TC_BEEVT_SET		(1 << 28) -#define			AT91_TC_BEEVT_CLEAR		(2 << 28) -#define			AT91_TC_BEEVT_TOGGLE		(3 << 28) -#define		AT91_TC_BSWTRG		(3 << 30)	/* Waveform Mode: Software Trigger Effect on TIOB */ -#define			AT91_TC_BSWTRG_NONE		(0 << 30) -#define			AT91_TC_BSWTRG_SET		(1 << 30) -#define			AT91_TC_BSWTRG_CLEAR		(2 << 30) -#define			AT91_TC_BSWTRG_TOGGLE		(3 << 30) - -#define AT91_TC_CV		0x10		/* Counter Value */ -#define AT91_TC_RA		0x14		/* Register A */ -#define AT91_TC_RB		0x18		/* Register B */ -#define AT91_TC_RC		0x1c		/* Register C */ - -#define AT91_TC_SR		0x20		/* Status Register */ -#define		AT91_TC_COVFS		(1 <<  0)	/* Counter Overflow Status */ -#define		AT91_TC_LOVRS		(1 <<  1)	/* Load Overrun Status */ -#define		AT91_TC_CPAS		(1 <<  2)	/* RA Compare Status */ -#define		AT91_TC_CPBS		(1 <<  3)	/* RB Compare Status */ -#define		AT91_TC_CPCS		(1 <<  4)	/* RC Compare Status */ -#define		AT91_TC_LDRAS		(1 <<  5)	/* RA Loading Status */ -#define		AT91_TC_LDRBS		(1 <<  6)	/* RB Loading Status */ -#define		AT91_TC_ETRGS		(1 <<  7)	/* External Trigger Status */ -#define		AT91_TC_CLKSTA		(1 << 16)	/* Clock Enabling Status */ -#define		AT91_TC_MTIOA		(1 << 17)	/* TIOA Mirror */ -#define		AT91_TC_MTIOB		(1 << 18)	/* TIOB Mirror */ - -#define AT91_TC_IER		0x24		/* Interrupt Enable Register */ -#define AT91_TC_IDR		0x28		/* Interrupt Disable Register */ -#define AT91_TC_IMR		0x2c		/* Interrupt Mask Register */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91_twi.h b/arch/arm/mach-at91/include/mach/at91_twi.h deleted file mode 100644 index bb2880f6ba3..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_twi.h +++ /dev/null @@ -1,68 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_twi.h - * - * Copyright (C) 2005 Ivan Kokshaysky - * Copyright (C) SAN People - * - * Two-wire Interface (TWI) registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_TWI_H -#define AT91_TWI_H - -#define	AT91_TWI_CR		0x00		/* Control Register */ -#define		AT91_TWI_START		(1 <<  0)	/* Send a Start Condition */ -#define		AT91_TWI_STOP		(1 <<  1)	/* Send a Stop Condition */ -#define		AT91_TWI_MSEN		(1 <<  2)	/* Master Transfer Enable */ -#define		AT91_TWI_MSDIS		(1 <<  3)	/* Master Transfer Disable */ -#define		AT91_TWI_SVEN		(1 <<  4)	/* Slave Transfer Enable [SAM9260 only] */ -#define		AT91_TWI_SVDIS		(1 <<  5)	/* Slave Transfer Disable [SAM9260 only] */ -#define		AT91_TWI_SWRST		(1 <<  7)	/* Software Reset */ - -#define	AT91_TWI_MMR		0x04		/* Master Mode Register */ -#define		AT91_TWI_IADRSZ		(3    <<  8)	/* Internal Device Address Size */ -#define			AT91_TWI_IADRSZ_NO		(0 << 8) -#define			AT91_TWI_IADRSZ_1		(1 << 8) -#define			AT91_TWI_IADRSZ_2		(2 << 8) -#define			AT91_TWI_IADRSZ_3		(3 << 8) -#define		AT91_TWI_MREAD		(1    << 12)	/* Master Read Direction */ -#define		AT91_TWI_DADR		(0x7f << 16)	/* Device Address */ - -#define	AT91_TWI_SMR		0x08		/* Slave Mode Register [SAM9260 only] */ -#define		AT91_TWI_SADR		(0x7f << 16)	/* Slave Address */ - -#define	AT91_TWI_IADR		0x0c		/* Internal Address Register */ - -#define	AT91_TWI_CWGR		0x10		/* Clock Waveform Generator Register */ -#define		AT91_TWI_CLDIV		(0xff <<  0)	/* Clock Low Divisor */ -#define		AT91_TWI_CHDIV		(0xff <<  8)	/* Clock High Divisor */ -#define		AT91_TWI_CKDIV		(7    << 16)	/* Clock Divider */ - -#define	AT91_TWI_SR		0x20		/* Status Register */ -#define		AT91_TWI_TXCOMP		(1 <<  0)	/* Transmission Complete */ -#define		AT91_TWI_RXRDY		(1 <<  1)	/* Receive Holding Register Ready */ -#define		AT91_TWI_TXRDY		(1 <<  2)	/* Transmit Holding Register Ready */ -#define		AT91_TWI_SVREAD		(1 <<  3)	/* Slave Read [SAM9260 only] */ -#define		AT91_TWI_SVACC		(1 <<  4)	/* Slave Access [SAM9260 only] */ -#define		AT91_TWI_GACC		(1 <<  5)	/* General Call Access [SAM9260 only] */ -#define		AT91_TWI_OVRE		(1 <<  6)	/* Overrun Error [AT91RM9200 only] */ -#define		AT91_TWI_UNRE		(1 <<  7)	/* Underrun Error [AT91RM9200 only] */ -#define		AT91_TWI_NACK		(1 <<  8)	/* Not Acknowledged */ -#define		AT91_TWI_ARBLST		(1 <<  9)	/* Arbitration Lost [SAM9260 only] */ -#define		AT91_TWI_SCLWS		(1 << 10)	/* Clock Wait State [SAM9260 only] */ -#define		AT91_TWI_EOSACC		(1 << 11)	/* End of Slave Address [SAM9260 only] */ - -#define	AT91_TWI_IER		0x24		/* Interrupt Enable Register */ -#define	AT91_TWI_IDR		0x28		/* Interrupt Disable Register */ -#define	AT91_TWI_IMR		0x2c		/* Interrupt Mask Register */ -#define	AT91_TWI_RHR		0x30		/* Receive Holding Register */ -#define	AT91_TWI_THR		0x34		/* Transmit Holding Register */ - -#endif - diff --git a/arch/arm/mach-at91/include/mach/at91_wdt.h b/arch/arm/mach-at91/include/mach/at91_wdt.h deleted file mode 100644 index fecc2e9f0ca..00000000000 --- a/arch/arm/mach-at91/include/mach/at91_wdt.h +++ /dev/null @@ -1,37 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91_wdt.h - * - * Copyright (C) 2007 Andrew Victor - * Copyright (C) 2007 Atmel Corporation. - * - * Watchdog Timer (WDT) - System peripherals regsters. - * Based on AT91SAM9261 datasheet revision D. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91_WDT_H -#define AT91_WDT_H - -#define AT91_WDT_CR		(AT91_WDT + 0x00)	/* Watchdog Control Register */ -#define		AT91_WDT_WDRSTT		(1    << 0)		/* Restart */ -#define		AT91_WDT_KEY		(0xa5 << 24)		/* KEY Password */ - -#define AT91_WDT_MR		(AT91_WDT + 0x04)	/* Watchdog Mode Register */ -#define		AT91_WDT_WDV		(0xfff << 0)		/* Counter Value */ -#define		AT91_WDT_WDFIEN		(1     << 12)		/* Fault Interrupt Enable */ -#define		AT91_WDT_WDRSTEN	(1     << 13)		/* Reset Processor */ -#define		AT91_WDT_WDRPROC	(1     << 14)		/* Timer Restart */ -#define		AT91_WDT_WDDIS		(1     << 15)		/* Watchdog Disable */ -#define		AT91_WDT_WDD		(0xfff << 16)		/* Delta Value */ -#define		AT91_WDT_WDDBGHLT	(1     << 28)		/* Debug Halt */ -#define		AT91_WDT_WDIDLEHLT	(1     << 29)		/* Idle Halt */ - -#define AT91_WDT_SR		(AT91_WDT + 0x08)	/* Watchdog Status Register */ -#define		AT91_WDT_WDUNF		(1 << 0)		/* Watchdog Underflow */ -#define		AT91_WDT_WDERR		(1 << 1)		/* Watchdog Error */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91cap9.h b/arch/arm/mach-at91/include/mach/at91cap9.h deleted file mode 100644 index 9c6af973748..00000000000 --- a/arch/arm/mach-at91/include/mach/at91cap9.h +++ /dev/null @@ -1,128 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91cap9.h - * - *  Copyright (C) 2007 Stelian Pop <stelian.pop@leadtechdesign.com> - *  Copyright (C) 2007 Lead Tech Design <www.leadtechdesign.com> - *  Copyright (C) 2007 Atmel Corporation. - * - * Common definitions. - * Based on AT91CAP9 datasheet revision B (Preliminary). - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91CAP9_H -#define AT91CAP9_H - -/* - * Peripheral identifiers/interrupts. - */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Peripherals */ -#define AT91CAP9_ID_PIOABCD	2	/* Parallel IO Controller A, B, C and D */ -#define AT91CAP9_ID_MPB0	3	/* MP Block Peripheral 0 */ -#define AT91CAP9_ID_MPB1	4	/* MP Block Peripheral 1 */ -#define AT91CAP9_ID_MPB2	5	/* MP Block Peripheral 2 */ -#define AT91CAP9_ID_MPB3	6	/* MP Block Peripheral 3 */ -#define AT91CAP9_ID_MPB4	7	/* MP Block Peripheral 4 */ -#define AT91CAP9_ID_US0		8	/* USART 0 */ -#define AT91CAP9_ID_US1		9	/* USART 1 */ -#define AT91CAP9_ID_US2		10	/* USART 2 */ -#define AT91CAP9_ID_MCI0	11	/* Multimedia Card Interface 0 */ -#define AT91CAP9_ID_MCI1	12	/* Multimedia Card Interface 1 */ -#define AT91CAP9_ID_CAN		13	/* CAN */ -#define AT91CAP9_ID_TWI		14	/* Two-Wire Interface */ -#define AT91CAP9_ID_SPI0	15	/* Serial Peripheral Interface 0 */ -#define AT91CAP9_ID_SPI1	16	/* Serial Peripheral Interface 0 */ -#define AT91CAP9_ID_SSC0	17	/* Serial Synchronous Controller 0 */ -#define AT91CAP9_ID_SSC1	18	/* Serial Synchronous Controller 1 */ -#define AT91CAP9_ID_AC97C	19	/* AC97 Controller */ -#define AT91CAP9_ID_TCB		20	/* Timer Counter 0, 1 and 2 */ -#define AT91CAP9_ID_PWMC	21	/* Pulse Width Modulation Controller */ -#define AT91CAP9_ID_EMAC	22	/* Ethernet */ -#define AT91CAP9_ID_AESTDES	23	/* Advanced Encryption Standard, Triple DES */ -#define AT91CAP9_ID_ADC		24	/* Analog-to-Digital Converter */ -#define AT91CAP9_ID_ISI		25	/* Image Sensor Interface */ -#define AT91CAP9_ID_LCDC	26	/* LCD Controller */ -#define AT91CAP9_ID_DMA		27	/* DMA Controller */ -#define AT91CAP9_ID_UDPHS	28	/* USB High Speed Device Port */ -#define AT91CAP9_ID_UHP		29	/* USB Host Port */ -#define AT91CAP9_ID_IRQ0	30	/* Advanced Interrupt Controller (IRQ0) */ -#define AT91CAP9_ID_IRQ1	31	/* Advanced Interrupt Controller (IRQ1) */ - -/* - * User Peripheral physical base addresses. - */ -#define AT91CAP9_BASE_UDPHS		0xfff78000 -#define AT91CAP9_BASE_TCB0		0xfff7c000 -#define AT91CAP9_BASE_TC0		0xfff7c000 -#define AT91CAP9_BASE_TC1		0xfff7c040 -#define AT91CAP9_BASE_TC2		0xfff7c080 -#define AT91CAP9_BASE_MCI0		0xfff80000 -#define AT91CAP9_BASE_MCI1		0xfff84000 -#define AT91CAP9_BASE_TWI		0xfff88000 -#define AT91CAP9_BASE_US0		0xfff8c000 -#define AT91CAP9_BASE_US1		0xfff90000 -#define AT91CAP9_BASE_US2		0xfff94000 -#define AT91CAP9_BASE_SSC0		0xfff98000 -#define AT91CAP9_BASE_SSC1		0xfff9c000 -#define AT91CAP9_BASE_AC97C		0xfffa0000 -#define AT91CAP9_BASE_SPI0		0xfffa4000 -#define AT91CAP9_BASE_SPI1		0xfffa8000 -#define AT91CAP9_BASE_CAN		0xfffac000 -#define AT91CAP9_BASE_PWMC		0xfffb8000 -#define AT91CAP9_BASE_EMAC		0xfffbc000 -#define AT91CAP9_BASE_ADC		0xfffc0000 -#define AT91CAP9_BASE_ISI		0xfffc4000 -#define AT91_BASE_SYS			0xffffe200 - -/* - * System Peripherals (offset from AT91_BASE_SYS) - */ -#define AT91_ECC	(0xffffe200 - AT91_BASE_SYS) -#define AT91_BCRAMC	(0xffffe400 - AT91_BASE_SYS) -#define AT91_DDRSDRC0	(0xffffe600 - AT91_BASE_SYS) -#define AT91_SMC	(0xffffe800 - AT91_BASE_SYS) -#define AT91_MATRIX	(0xffffea00 - AT91_BASE_SYS) -#define AT91_CCFG	(0xffffeb10 - AT91_BASE_SYS) -#define AT91_DMA	(0xffffec00 - AT91_BASE_SYS) -#define AT91_DBGU	(0xffffee00 - AT91_BASE_SYS) -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS) -#define AT91_PIOA	(0xfffff200 - AT91_BASE_SYS) -#define AT91_PIOB	(0xfffff400 - AT91_BASE_SYS) -#define AT91_PIOC	(0xfffff600 - AT91_BASE_SYS) -#define AT91_PIOD	(0xfffff800 - AT91_BASE_SYS) -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS) -#define AT91_RSTC	(0xfffffd00 - AT91_BASE_SYS) -#define AT91_SHDWC	(0xfffffd10 - AT91_BASE_SYS) -#define AT91_RTT	(0xfffffd20 - AT91_BASE_SYS) -#define AT91_PIT	(0xfffffd30 - AT91_BASE_SYS) -#define AT91_WDT	(0xfffffd40 - AT91_BASE_SYS) -#define AT91_GPBR	(cpu_is_at91cap9_revB() ?	\ -			(0xfffffd50 - AT91_BASE_SYS) :	\ -			(0xfffffd60 - AT91_BASE_SYS)) - -#define AT91_USART0	AT91CAP9_BASE_US0 -#define AT91_USART1	AT91CAP9_BASE_US1 -#define AT91_USART2	AT91CAP9_BASE_US2 - - -/* - * Internal Memory. - */ -#define AT91CAP9_SRAM_BASE	0x00100000	/* Internal SRAM base address */ -#define AT91CAP9_SRAM_SIZE	(32 * SZ_1K)	/* Internal SRAM size (32Kb) */ - -#define AT91CAP9_ROM_BASE	0x00400000	/* Internal ROM base address */ -#define AT91CAP9_ROM_SIZE	(32 * SZ_1K)	/* Internal ROM size (32Kb) */ - -#define AT91CAP9_LCDC_BASE	0x00500000	/* LCD Controller */ -#define AT91CAP9_UDPHS_FIFO	0x00600000	/* USB High Speed Device Port */ -#define AT91CAP9_UHP_BASE	0x00700000	/* USB Host controller */ - -#define CONFIG_DRAM_BASE	AT91_CHIPSELECT_6 - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h b/arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h deleted file mode 100644 index 976f4a6c335..00000000000 --- a/arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h +++ /dev/null @@ -1,108 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91cap9_ddrsdr.h - * - *  (C) 2008 Andrew Victor - * - * DDR/SDR Controller (DDRSDRC) - System peripherals registers. - * Based on AT91CAP9 datasheet revision B. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91CAP9_DDRSDR_H -#define AT91CAP9_DDRSDR_H - -#define AT91_DDRSDRC_MR		0x00	/* Mode Register */ -#define		AT91_DDRSDRC_MODE	(0xf << 0)		/* Command Mode */ -#define			AT91_DDRSDRC_MODE_NORMAL		0 -#define			AT91_DDRSDRC_MODE_NOP		1 -#define			AT91_DDRSDRC_MODE_PRECHARGE	2 -#define			AT91_DDRSDRC_MODE_LMR		3 -#define			AT91_DDRSDRC_MODE_REFRESH	4 -#define			AT91_DDRSDRC_MODE_EXT_LMR	5 -#define			AT91_DDRSDRC_MODE_DEEP		6 - -#define AT91_DDRSDRC_RTR	0x04	/* Refresh Timer Register */ -#define		AT91_DDRSDRC_COUNT	(0xfff << 0)		/* Refresh Timer Counter */ - -#define AT91_DDRSDRC_CR		0x08	/* Configuration Register */ -#define		AT91_DDRSDRC_NC		(3 << 0)		/* Number of Column Bits */ -#define			AT91_DDRSDRC_NC_SDR8	(0 << 0) -#define			AT91_DDRSDRC_NC_SDR9	(1 << 0) -#define			AT91_DDRSDRC_NC_SDR10	(2 << 0) -#define			AT91_DDRSDRC_NC_SDR11	(3 << 0) -#define			AT91_DDRSDRC_NC_DDR9	(0 << 0) -#define			AT91_DDRSDRC_NC_DDR10	(1 << 0) -#define			AT91_DDRSDRC_NC_DDR11	(2 << 0) -#define			AT91_DDRSDRC_NC_DDR12	(3 << 0) -#define		AT91_DDRSDRC_NR		(3 << 2)		/* Number of Row Bits */ -#define			AT91_DDRSDRC_NR_11	(0 << 2) -#define			AT91_DDRSDRC_NR_12	(1 << 2) -#define			AT91_DDRSDRC_NR_13	(2 << 2) -#define		AT91_DDRSDRC_CAS	(7 << 4)		/* CAS Latency */ -#define			AT91_DDRSDRC_CAS_2	(2 << 4) -#define			AT91_DDRSDRC_CAS_3	(3 << 4) -#define			AT91_DDRSDRC_CAS_25	(6 << 4) -#define		AT91_DDRSDRC_DLL	(1 << 7)		/* Reset DLL */ -#define		AT91_DDRSDRC_DICDS	(1 << 8)		/* Output impedance control */ - -#define AT91_DDRSDRC_T0PR	0x0C	/* Timing 0 Register */ -#define		AT91_DDRSDRC_TRAS	(0xf <<  0)		/* Active to Precharge delay */ -#define		AT91_DDRSDRC_TRCD	(0xf <<  4)		/* Row to Column delay */ -#define		AT91_DDRSDRC_TWR	(0xf <<  8)		/* Write recovery delay */ -#define		AT91_DDRSDRC_TRC	(0xf << 12)		/* Row cycle delay */ -#define		AT91_DDRSDRC_TRP	(0xf << 16)		/* Row precharge delay */ -#define		AT91_DDRSDRC_TRRD	(0xf << 20)		/* Active BankA to BankB */ -#define		AT91_DDRSDRC_TWTR	(1   << 24)		/* Internal Write to Read delay */ -#define		AT91_DDRSDRC_TMRD	(0xf << 28)		/* Load mode to active/refresh delay */ - -#define AT91_DDRSDRC_T1PR	0x10	/* Timing 1 Register */ -#define		AT91_DDRSDRC_TRFC	(0x1f << 0)		/* Row Cycle Delay */ -#define		AT91_DDRSDRC_TXSNR	(0xff << 8)		/* Exit self-refresh to non-read */ -#define		AT91_DDRSDRC_TXSRD	(0xff << 16)		/* Exit self-refresh to read */ -#define		AT91_DDRSDRC_TXP	(0xf  << 24)		/* Exit power-down delay */ - -#define AT91_DDRSDRC_LPR	0x18	/* Low Power Register */ -#define		AT91_DDRSDRC_LPCB		(3 << 0)	/* Low-power Configurations */ -#define			AT91_DDRSDRC_LPCB_DISABLE		0 -#define			AT91_DDRSDRC_LPCB_SELF_REFRESH		1 -#define			AT91_DDRSDRC_LPCB_POWER_DOWN		2 -#define			AT91_DDRSDRC_LPCB_DEEP_POWER_DOWN	3 -#define		AT91_DDRSDRC_CLKFR		(1 << 2)	/* Clock Frozen */ -#define		AT91_DDRSDRC_PASR		(7 << 4)	/* Partial Array Self Refresh */ -#define		AT91_DDRSDRC_TCSR		(3 << 8)	/* Temperature Compensated Self Refresh */ -#define		AT91_DDRSDRC_DS			(3 << 10)	/* Drive Strength */ -#define		AT91_DDRSDRC_TIMEOUT		(3 << 12)	/* Time to define when Low Power Mode is enabled */ -#define			AT91_DDRSDRC_TIMEOUT_0_CLK_CYCLES	(0 << 12) -#define			AT91_DDRSDRC_TIMEOUT_64_CLK_CYCLES	(1 << 12) -#define			AT91_DDRSDRC_TIMEOUT_128_CLK_CYCLES	(2 << 12) - -#define AT91_DDRSDRC_MDR	0x1C	/* Memory Device Register */ -#define		AT91_DDRSDRC_MD		(3 << 0)		/* Memory Device Type */ -#define			AT91_DDRSDRC_MD_SDR		0 -#define			AT91_DDRSDRC_MD_LOW_POWER_SDR	1 -#define			AT91_DDRSDRC_MD_DDR		2 -#define			AT91_DDRSDRC_MD_LOW_POWER_DDR	3 - -#define AT91_DDRSDRC_DLLR	0x20	/* DLL Information Register */ -#define		AT91_DDRSDRC_MDINC	(1 << 0)		/* Master Delay increment */ -#define		AT91_DDRSDRC_MDDEC	(1 << 1)		/* Master Delay decrement */ -#define		AT91_DDRSDRC_MDOVF	(1 << 2)		/* Master Delay Overflow */ -#define		AT91_DDRSDRC_SDCOVF	(1 << 3)		/* Slave Delay Correction Overflow */ -#define		AT91_DDRSDRC_SDCUDF	(1 << 4)		/* Slave Delay Correction Underflow */ -#define		AT91_DDRSDRC_SDERF	(1 << 5)		/* Slave Delay Correction error */ -#define		AT91_DDRSDRC_MDVAL	(0xff <<  8)		/* Master Delay value */ -#define		AT91_DDRSDRC_SDVAL	(0xff << 16)		/* Slave Delay value */ -#define		AT91_DDRSDRC_SDCVAL	(0xff << 24)		/* Slave Delay Correction value */ - -/* Register access macros */ -#define at91_ramc_read(num, reg) \ -	at91_sys_read(AT91_DDRSDRC##num + reg) -#define at91_ramc_write(num, reg, value) \ -	at91_sys_write(AT91_DDRSDRC##num + reg, value) - - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91cap9_matrix.h b/arch/arm/mach-at91/include/mach/at91cap9_matrix.h deleted file mode 100644 index 4b9d4aff4b4..00000000000 --- a/arch/arm/mach-at91/include/mach/at91cap9_matrix.h +++ /dev/null @@ -1,137 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91cap9_matrix.h - * - *  Copyright (C) 2007 Stelian Pop <stelian.pop@leadtechdesign.com> - *  Copyright (C) 2007 Lead Tech Design <www.leadtechdesign.com> - *  Copyright (C) 2006 Atmel Corporation. - * - * Memory Controllers (MATRIX, EBI) - System peripherals registers. - * Based on AT91CAP9 datasheet revision B (Preliminary). - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91CAP9_MATRIX_H -#define AT91CAP9_MATRIX_H - -#define AT91_MATRIX_MCFG0	(AT91_MATRIX + 0x00)	/* Master Configuration Register 0 */ -#define AT91_MATRIX_MCFG1	(AT91_MATRIX + 0x04)	/* Master Configuration Register 1 */ -#define AT91_MATRIX_MCFG2	(AT91_MATRIX + 0x08)	/* Master Configuration Register 2 */ -#define AT91_MATRIX_MCFG3	(AT91_MATRIX + 0x0C)	/* Master Configuration Register 3 */ -#define AT91_MATRIX_MCFG4	(AT91_MATRIX + 0x10)	/* Master Configuration Register 4 */ -#define AT91_MATRIX_MCFG5	(AT91_MATRIX + 0x14)	/* Master Configuration Register 5 */ -#define AT91_MATRIX_MCFG6	(AT91_MATRIX + 0x18)	/* Master Configuration Register 6 */ -#define AT91_MATRIX_MCFG7	(AT91_MATRIX + 0x1C)	/* Master Configuration Register 7 */ -#define AT91_MATRIX_MCFG8	(AT91_MATRIX + 0x20)	/* Master Configuration Register 8 */ -#define AT91_MATRIX_MCFG9	(AT91_MATRIX + 0x24)	/* Master Configuration Register 9 */ -#define AT91_MATRIX_MCFG10	(AT91_MATRIX + 0x28)	/* Master Configuration Register 10 */ -#define AT91_MATRIX_MCFG11	(AT91_MATRIX + 0x2C)	/* Master Configuration Register 11 */ -#define		AT91_MATRIX_ULBT	(7 << 0)	/* Undefined Length Burst Type */ -#define			AT91_MATRIX_ULBT_INFINITE	(0 << 0) -#define			AT91_MATRIX_ULBT_SINGLE		(1 << 0) -#define			AT91_MATRIX_ULBT_FOUR		(2 << 0) -#define			AT91_MATRIX_ULBT_EIGHT		(3 << 0) -#define			AT91_MATRIX_ULBT_SIXTEEN	(4 << 0) - -#define AT91_MATRIX_SCFG0	(AT91_MATRIX + 0x40)	/* Slave Configuration Register 0 */ -#define AT91_MATRIX_SCFG1	(AT91_MATRIX + 0x44)	/* Slave Configuration Register 1 */ -#define AT91_MATRIX_SCFG2	(AT91_MATRIX + 0x48)	/* Slave Configuration Register 2 */ -#define AT91_MATRIX_SCFG3	(AT91_MATRIX + 0x4C)	/* Slave Configuration Register 3 */ -#define AT91_MATRIX_SCFG4	(AT91_MATRIX + 0x50)	/* Slave Configuration Register 4 */ -#define AT91_MATRIX_SCFG5	(AT91_MATRIX + 0x54)	/* Slave Configuration Register 5 */ -#define AT91_MATRIX_SCFG6	(AT91_MATRIX + 0x58)	/* Slave Configuration Register 6 */ -#define AT91_MATRIX_SCFG7	(AT91_MATRIX + 0x5C)	/* Slave Configuration Register 7 */ -#define AT91_MATRIX_SCFG8	(AT91_MATRIX + 0x60)	/* Slave Configuration Register 8 */ -#define AT91_MATRIX_SCFG9	(AT91_MATRIX + 0x64)	/* Slave Configuration Register 9 */ -#define		AT91_MATRIX_SLOT_CYCLE		(0xff << 0)	/* Maximum Number of Allowed Cycles for a Burst */ -#define		AT91_MATRIX_DEFMSTR_TYPE	(3    << 16)	/* Default Master Type */ -#define			AT91_MATRIX_DEFMSTR_TYPE_NONE	(0 << 16) -#define			AT91_MATRIX_DEFMSTR_TYPE_LAST	(1 << 16) -#define			AT91_MATRIX_DEFMSTR_TYPE_FIXED	(2 << 16) -#define		AT91_MATRIX_FIXED_DEFMSTR	(0xf  << 18)	/* Fixed Index of Default Master */ -#define		AT91_MATRIX_ARBT		(3    << 24)	/* Arbitration Type */ -#define			AT91_MATRIX_ARBT_ROUND_ROBIN	(0 << 24) -#define			AT91_MATRIX_ARBT_FIXED_PRIORITY	(1 << 24) - -#define AT91_MATRIX_PRAS0	(AT91_MATRIX + 0x80)	/* Priority Register A for Slave 0 */ -#define AT91_MATRIX_PRBS0	(AT91_MATRIX + 0x84)	/* Priority Register B for Slave 0 */ -#define AT91_MATRIX_PRAS1	(AT91_MATRIX + 0x88)	/* Priority Register A for Slave 1 */ -#define AT91_MATRIX_PRBS1	(AT91_MATRIX + 0x8C)	/* Priority Register B for Slave 1 */ -#define AT91_MATRIX_PRAS2	(AT91_MATRIX + 0x90)	/* Priority Register A for Slave 2 */ -#define AT91_MATRIX_PRBS2	(AT91_MATRIX + 0x94)	/* Priority Register B for Slave 2 */ -#define AT91_MATRIX_PRAS3	(AT91_MATRIX + 0x98)	/* Priority Register A for Slave 3 */ -#define AT91_MATRIX_PRBS3	(AT91_MATRIX + 0x9C)	/* Priority Register B for Slave 3 */ -#define AT91_MATRIX_PRAS4	(AT91_MATRIX + 0xA0)	/* Priority Register A for Slave 4 */ -#define AT91_MATRIX_PRBS4	(AT91_MATRIX + 0xA4)	/* Priority Register B for Slave 4 */ -#define AT91_MATRIX_PRAS5	(AT91_MATRIX + 0xA8)	/* Priority Register A for Slave 5 */ -#define AT91_MATRIX_PRBS5	(AT91_MATRIX + 0xAC)	/* Priority Register B for Slave 5 */ -#define AT91_MATRIX_PRAS6	(AT91_MATRIX + 0xB0)	/* Priority Register A for Slave 6 */ -#define AT91_MATRIX_PRBS6	(AT91_MATRIX + 0xB4)	/* Priority Register B for Slave 6 */ -#define AT91_MATRIX_PRAS7	(AT91_MATRIX + 0xB8)	/* Priority Register A for Slave 7 */ -#define AT91_MATRIX_PRBS7	(AT91_MATRIX + 0xBC)	/* Priority Register B for Slave 7 */ -#define AT91_MATRIX_PRAS8	(AT91_MATRIX + 0xC0)	/* Priority Register A for Slave 8 */ -#define AT91_MATRIX_PRBS8	(AT91_MATRIX + 0xC4)	/* Priority Register B for Slave 8 */ -#define AT91_MATRIX_PRAS9	(AT91_MATRIX + 0xC8)	/* Priority Register A for Slave 9 */ -#define AT91_MATRIX_PRBS9	(AT91_MATRIX + 0xCC)	/* Priority Register B for Slave 9 */ -#define		AT91_MATRIX_M0PR		(3 << 0)	/* Master 0 Priority */ -#define		AT91_MATRIX_M1PR		(3 << 4)	/* Master 1 Priority */ -#define		AT91_MATRIX_M2PR		(3 << 8)	/* Master 2 Priority */ -#define		AT91_MATRIX_M3PR		(3 << 12)	/* Master 3 Priority */ -#define		AT91_MATRIX_M4PR		(3 << 16)	/* Master 4 Priority */ -#define		AT91_MATRIX_M5PR		(3 << 20)	/* Master 5 Priority */ -#define		AT91_MATRIX_M6PR		(3 << 24)	/* Master 6 Priority */ -#define		AT91_MATRIX_M7PR		(3 << 28)	/* Master 7 Priority */ -#define		AT91_MATRIX_M8PR		(3 << 0)	/* Master 8 Priority (in Register B) */ -#define		AT91_MATRIX_M9PR		(3 << 4)	/* Master 9 Priority (in Register B) */ -#define		AT91_MATRIX_M10PR		(3 << 8)	/* Master 10 Priority (in Register B) */ -#define		AT91_MATRIX_M11PR		(3 << 12)	/* Master 11 Priority (in Register B) */ - -#define AT91_MATRIX_MRCR	(AT91_MATRIX + 0x100)	/* Master Remap Control Register */ -#define		AT91_MATRIX_RCB0		(1 << 0)	/* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */ -#define		AT91_MATRIX_RCB1		(1 << 1)	/* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */ -#define		AT91_MATRIX_RCB2		(1 << 2) -#define		AT91_MATRIX_RCB3		(1 << 3) -#define		AT91_MATRIX_RCB4		(1 << 4) -#define		AT91_MATRIX_RCB5		(1 << 5) -#define		AT91_MATRIX_RCB6		(1 << 6) -#define		AT91_MATRIX_RCB7		(1 << 7) -#define		AT91_MATRIX_RCB8		(1 << 8) -#define		AT91_MATRIX_RCB9		(1 << 9) -#define		AT91_MATRIX_RCB10		(1 << 10) -#define		AT91_MATRIX_RCB11		(1 << 11) - -#define AT91_MPBS0_SFR		(AT91_MATRIX + 0x114)	/* MPBlock Slave 0 Special Function Register */ -#define AT91_MPBS1_SFR		(AT91_MATRIX + 0x11C)	/* MPBlock Slave 1 Special Function Register */ - -#define AT91_MATRIX_UDPHS	(AT91_MATRIX + 0x118)	/* USBHS Special Function Register [AT91CAP9 only] */ -#define		AT91_MATRIX_SELECT_UDPHS	(0 << 31)	/* select High Speed UDP */ -#define		AT91_MATRIX_SELECT_UDP		(1 << 31)	/* select standard UDP */ -#define		AT91_MATRIX_UDPHS_BYPASS_LOCK	(1 << 30)	/* bypass lock bit */ - -#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x120)	/* EBI Chip Select Assignment Register */ -#define		AT91_MATRIX_EBI_CS1A		(1 << 1)	/* Chip Select 1 Assignment */ -#define			AT91_MATRIX_EBI_CS1A_SMC		(0 << 1) -#define			AT91_MATRIX_EBI_CS1A_BCRAMC		(1 << 1) -#define		AT91_MATRIX_EBI_CS3A		(1 << 3)	/* Chip Select 3 Assignment */ -#define			AT91_MATRIX_EBI_CS3A_SMC		(0 << 3) -#define			AT91_MATRIX_EBI_CS3A_SMC_SMARTMEDIA	(1 << 3) -#define		AT91_MATRIX_EBI_CS4A		(1 << 4)	/* Chip Select 4 Assignment */ -#define			AT91_MATRIX_EBI_CS4A_SMC		(0 << 4) -#define			AT91_MATRIX_EBI_CS4A_SMC_CF1		(1 << 4) -#define		AT91_MATRIX_EBI_CS5A		(1 << 5)	/* Chip Select 5 Assignment */ -#define			AT91_MATRIX_EBI_CS5A_SMC		(0 << 5) -#define			AT91_MATRIX_EBI_CS5A_SMC_CF2		(1 << 5) -#define		AT91_MATRIX_EBI_DBPUC		(1 << 8)	/* Data Bus Pull-up Configuration */ -#define		AT91_MATRIX_EBI_DQSPDC		(1 << 9)	/* Data Qualifier Strobe Pull-Down Configuration */ -#define		AT91_MATRIX_EBI_VDDIOMSEL	(1 << 16)	/* Memory voltage selection */ -#define			AT91_MATRIX_EBI_VDDIOMSEL_1_8V		(0 << 16) -#define			AT91_MATRIX_EBI_VDDIOMSEL_3_3V		(1 << 16) - -#define AT91_MPBS2_SFR		(AT91_MATRIX + 0x12C)	/* MPBlock Slave 2 Special Function Register */ -#define AT91_MPBS3_SFR		(AT91_MATRIX + 0x130)	/* MPBlock Slave 3 Special Function Register */ -#define AT91_APB_SFR		(AT91_MATRIX + 0x134)	/* APB Bridge Special Function Register */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91rm9200.h b/arch/arm/mach-at91/include/mach/at91rm9200.h index 78983155a07..e67317c6776 100644 --- a/arch/arm/mach-at91/include/mach/at91rm9200.h +++ b/arch/arm/mach-at91/include/mach/at91rm9200.h @@ -19,8 +19,6 @@  /*   * Peripheral identifiers/interrupts.   */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Peripheral */  #define AT91RM9200_ID_PIOA	2	/* Parallel IO Controller A */  #define AT91RM9200_ID_PIOB	3	/* Parallel IO Controller B */  #define AT91RM9200_ID_PIOC	4	/* Parallel IO Controller C */ @@ -76,29 +74,19 @@  #define AT91RM9200_BASE_SSC1	0xfffd4000  #define AT91RM9200_BASE_SSC2	0xfffd8000  #define AT91RM9200_BASE_SPI	0xfffe0000 -#define AT91_BASE_SYS		0xfffff000  /* - * System Peripherals (offset from AT91_BASE_SYS) + * System Peripherals   */ -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS)	/* Advanced Interrupt Controller */ -#define AT91_DBGU	(0xfffff200 - AT91_BASE_SYS)	/* Debug Unit */ -#define AT91_PIOA	(0xfffff400 - AT91_BASE_SYS)	/* PIO Controller A */ -#define AT91_PIOB	(0xfffff600 - AT91_BASE_SYS)	/* PIO Controller B */ -#define AT91_PIOC	(0xfffff800 - AT91_BASE_SYS)	/* PIO Controller C */ -#define AT91_PIOD	(0xfffffa00 - AT91_BASE_SYS)	/* PIO Controller D */ -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS)	/* Power Management Controller */ -#define AT91_ST		(0xfffffd00 - AT91_BASE_SYS)	/* System Timer */ -#define AT91_RTC	(0xfffffe00 - AT91_BASE_SYS)	/* Real-Time Clock */ -#define AT91_MC		(0xffffff00 - AT91_BASE_SYS)	/* Memory Controllers */ - -#define AT91_USART0	AT91RM9200_BASE_US0 -#define AT91_USART1	AT91RM9200_BASE_US1 -#define AT91_USART2	AT91RM9200_BASE_US2 -#define AT91_USART3	AT91RM9200_BASE_US3 - -#define AT91_MATRIX	0	/* not supported */ +#define AT91RM9200_BASE_DBGU	AT91_BASE_DBGU0	/* Debug Unit */ +#define AT91RM9200_BASE_PIOA	0xfffff400	/* PIO Controller A */ +#define AT91RM9200_BASE_PIOB	0xfffff600	/* PIO Controller B */ +#define AT91RM9200_BASE_PIOC	0xfffff800	/* PIO Controller C */ +#define AT91RM9200_BASE_PIOD	0xfffffa00	/* PIO Controller D */ +#define AT91RM9200_BASE_ST	0xfffffd00	/* System Timer */ +#define AT91RM9200_BASE_RTC	0xfffffe00	/* Real-Time Clock */ +#define AT91RM9200_BASE_MC	0xffffff00	/* Memory Controllers */  /*   * Internal Memory. diff --git a/arch/arm/mach-at91/include/mach/at91rm9200_emac.h b/arch/arm/mach-at91/include/mach/at91rm9200_emac.h deleted file mode 100644 index b8260cd8041..00000000000 --- a/arch/arm/mach-at91/include/mach/at91rm9200_emac.h +++ /dev/null @@ -1,138 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/at91rm9200_emac.h - * - * Copyright (C) 2005 Ivan Kokshaysky - * Copyright (C) SAN People - * - * Ethernet MAC registers. - * Based on AT91RM9200 datasheet revision E. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ - -#ifndef AT91RM9200_EMAC_H -#define AT91RM9200_EMAC_H - -#define	AT91_EMAC_CTL		0x00	/* Control Register */ -#define		AT91_EMAC_LB		(1 <<  0)	/* Loopback */ -#define		AT91_EMAC_LBL		(1 <<  1)	/* Loopback Local */ -#define		AT91_EMAC_RE		(1 <<  2)	/* Receive Enable */ -#define		AT91_EMAC_TE		(1 <<  3)	/* Transmit Enable */ -#define		AT91_EMAC_MPE		(1 <<  4)	/* Management Port Enable */ -#define		AT91_EMAC_CSR		(1 <<  5)	/* Clear Statistics Registers */ -#define		AT91_EMAC_INCSTAT	(1 <<  6)	/* Increment Statistics Registers */ -#define		AT91_EMAC_WES		(1 <<  7)	/* Write Enable for Statistics Registers */ -#define		AT91_EMAC_BP		(1 <<  8)	/* Back Pressure */ - -#define	AT91_EMAC_CFG		0x04	/* Configuration Register */ -#define		AT91_EMAC_SPD		(1 <<  0)	/* Speed */ -#define		AT91_EMAC_FD		(1 <<  1)	/* Full Duplex */ -#define		AT91_EMAC_BR		(1 <<  2)	/* Bit Rate */ -#define		AT91_EMAC_CAF		(1 <<  4)	/* Copy All Frames */ -#define		AT91_EMAC_NBC		(1 <<  5)	/* No Broadcast */ -#define		AT91_EMAC_MTI		(1 <<  6)	/* Multicast Hash Enable */ -#define		AT91_EMAC_UNI		(1 <<  7)	/* Unicast Hash Enable */ -#define		AT91_EMAC_BIG		(1 <<  8)	/* Receive 1522 Bytes */ -#define		AT91_EMAC_EAE		(1 <<  9)	/* External Address Match Enable */ -#define		AT91_EMAC_CLK		(3 << 10)	/* MDC Clock Divisor */ -#define		AT91_EMAC_CLK_DIV8		(0 << 10) -#define		AT91_EMAC_CLK_DIV16		(1 << 10) -#define		AT91_EMAC_CLK_DIV32		(2 << 10) -#define		AT91_EMAC_CLK_DIV64		(3 << 10) -#define		AT91_EMAC_RTY		(1 << 12)	/* Retry Test */ -#define		AT91_EMAC_RMII		(1 << 13)	/* Reduce MII (RMII) */ - -#define	AT91_EMAC_SR		0x08	/* Status Register */ -#define		AT91_EMAC_SR_LINK	(1 <<  0)	/* Link */ -#define		AT91_EMAC_SR_MDIO	(1 <<  1)	/* MDIO pin */ -#define		AT91_EMAC_SR_IDLE	(1 <<  2)	/* PHY idle */ - -#define	AT91_EMAC_TAR		0x0c	/* Transmit Address Register */ - -#define	AT91_EMAC_TCR		0x10	/* Transmit Control Register */ -#define		AT91_EMAC_LEN		(0x7ff << 0)	/* Transmit Frame Length */ -#define		AT91_EMAC_NCRC		(1     << 15)	/* No CRC */ - -#define	AT91_EMAC_TSR		0x14	/* Transmit Status Register */ -#define		AT91_EMAC_TSR_OVR	(1 <<  0)	/* Transmit Buffer Overrun */ -#define		AT91_EMAC_TSR_COL	(1 <<  1)	/* Collision Occurred */ -#define		AT91_EMAC_TSR_RLE	(1 <<  2)	/* Retry Limit Exceeded */ -#define		AT91_EMAC_TSR_IDLE	(1 <<  3)	/* Transmitter Idle */ -#define		AT91_EMAC_TSR_BNQ	(1 <<  4)	/* Transmit Buffer not Queued */ -#define		AT91_EMAC_TSR_COMP	(1 <<  5)	/* Transmit Complete */ -#define		AT91_EMAC_TSR_UND	(1 <<  6)	/* Transmit Underrun */ - -#define	AT91_EMAC_RBQP		0x18	/* Receive Buffer Queue Pointer */ - -#define	AT91_EMAC_RSR		0x20	/* Receive Status Register */ -#define		AT91_EMAC_RSR_BNA	(1 <<  0)	/* Buffer Not Available */ -#define		AT91_EMAC_RSR_REC	(1 <<  1)	/* Frame Received */ -#define		AT91_EMAC_RSR_OVR	(1 <<  2)	/* RX Overrun */ - -#define	AT91_EMAC_ISR		0x24	/* Interrupt Status Register */ -#define		AT91_EMAC_DONE		(1 <<  0)	/* Management Done */ -#define		AT91_EMAC_RCOM		(1 <<  1)	/* Receive Complete */ -#define		AT91_EMAC_RBNA		(1 <<  2)	/* Receive Buffer Not Available */ -#define		AT91_EMAC_TOVR		(1 <<  3)	/* Transmit Buffer Overrun */ -#define		AT91_EMAC_TUND		(1 <<  4)	/* Transmit Buffer Underrun */ -#define		AT91_EMAC_RTRY		(1 <<  5)	/* Retry Limit */ -#define		AT91_EMAC_TBRE		(1 <<  6)	/* Transmit Buffer Register Empty */ -#define		AT91_EMAC_TCOM		(1 <<  7)	/* Transmit Complete */ -#define		AT91_EMAC_TIDLE		(1 <<  8)	/* Transmit Idle */ -#define		AT91_EMAC_LINK		(1 <<  9)	/* Link */ -#define		AT91_EMAC_ROVR		(1 << 10)	/* RX Overrun */ -#define		AT91_EMAC_ABT		(1 << 11)	/* Abort */ - -#define	AT91_EMAC_IER		0x28	/* Interrupt Enable Register */ -#define	AT91_EMAC_IDR		0x2c	/* Interrupt Disable Register */ -#define	AT91_EMAC_IMR		0x30	/* Interrupt Mask Register */ - -#define	AT91_EMAC_MAN		0x34	/* PHY Maintenance Register */ -#define		AT91_EMAC_DATA		(0xffff << 0)	/* MDIO Data */ -#define		AT91_EMAC_REGA		(0x1f	<< 18)	/* MDIO Register */ -#define		AT91_EMAC_PHYA		(0x1f	<< 23)	/* MDIO PHY Address */ -#define		AT91_EMAC_RW		(3	<< 28)	/* Read/Write operation */ -#define			AT91_EMAC_RW_W		(1 << 28) -#define			AT91_EMAC_RW_R		(2 << 28) -#define		AT91_EMAC_MAN_802_3	0x40020000	/* IEEE 802.3 value */ - -/* - * Statistics Registers. - */ -#define AT91_EMAC_FRA		0x40	/* Frames Transmitted OK */ -#define AT91_EMAC_SCOL		0x44	/* Single Collision Frame */ -#define AT91_EMAC_MCOL		0x48	/* Multiple Collision Frame */ -#define AT91_EMAC_OK		0x4c	/* Frames Received OK */ -#define AT91_EMAC_SEQE		0x50	/* Frame Check Sequence Error */ -#define AT91_EMAC_ALE		0x54	/* Alignmemt Error */ -#define AT91_EMAC_DTE		0x58	/* Deffered Transmission Frame */ -#define AT91_EMAC_LCOL		0x5c	/* Late Collision */ -#define AT91_EMAC_ECOL		0x60	/* Excessive Collision */ -#define AT91_EMAC_TUE		0x64	/* Transmit Underrun Error */ -#define AT91_EMAC_CSE		0x68	/* Carrier Sense Error */ -#define AT91_EMAC_DRFC		0x6c	/* Discard RX Frame */ -#define AT91_EMAC_ROV		0x70	/* Receive Overrun */ -#define AT91_EMAC_CDE		0x74	/* Code Error */ -#define AT91_EMAC_ELR		0x78	/* Excessive Length Error */ -#define AT91_EMAC_RJB		0x7c	/* Receive Jabber */ -#define AT91_EMAC_USF		0x80	/* Undersize Frame */ -#define AT91_EMAC_SQEE		0x84	/* SQE Test Error */ - -/* - * Address Registers. - */ -#define AT91_EMAC_HSL		0x90	/* Hash Address Low [31:0] */ -#define AT91_EMAC_HSH		0x94	/* Hash Address High [63:32] */ -#define AT91_EMAC_SA1L		0x98	/* Specific Address 1 Low, bytes 0-3 */ -#define AT91_EMAC_SA1H		0x9c	/* Specific Address 1 High, bytes 4-5 */ -#define AT91_EMAC_SA2L		0xa0	/* Specific Address 2 Low, bytes 0-3 */ -#define AT91_EMAC_SA2H		0xa4	/* Specific Address 2 High, bytes 4-5 */ -#define AT91_EMAC_SA3L		0xa8	/* Specific Address 3 Low, bytes 0-3 */ -#define AT91_EMAC_SA3H		0xac	/* Specific Address 3 High, bytes 4-5 */ -#define AT91_EMAC_SA4L		0xb0	/* Specific Address 4 Low, bytes 0-3 */ -#define AT91_EMAC_SA4H		0xb4	/* Specific Address 4 High, bytes 4-5 */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/at91rm9200_mc.h b/arch/arm/mach-at91/include/mach/at91rm9200_mc.h index d34e4ed8934..aeaadfb452a 100644 --- a/arch/arm/mach-at91/include/mach/at91rm9200_mc.h +++ b/arch/arm/mach-at91/include/mach/at91rm9200_mc.h @@ -17,10 +17,10 @@  #define AT91RM9200_MC_H  /* Memory Controller */ -#define AT91_MC_RCR		(AT91_MC + 0x00)	/* MC Remap Control Register */ +#define AT91_MC_RCR		0x00			/* MC Remap Control Register */  #define		AT91_MC_RCB		(1 <<  0)		/* Remap Command Bit */ -#define AT91_MC_ASR		(AT91_MC + 0x04)	/* MC Abort Status Register */ +#define AT91_MC_ASR		0x04			/* MC Abort Status Register */  #define		AT91_MC_UNADD		(1 <<  0)		/* Undefined Address Abort Status */  #define		AT91_MC_MISADD		(1 <<  1)		/* Misaligned Address Abort Status */  #define		AT91_MC_ABTSZ		(3 <<  8)		/* Abort Size Status */ @@ -40,16 +40,16 @@  #define		AT91_MC_SVMST2		(1 << 26)		/* Saved UHP Abort Source */  #define		AT91_MC_SVMST3		(1 << 27)		/* Saved EMAC Abort Source */ -#define AT91_MC_AASR		(AT91_MC + 0x08)	/* MC Abort Address Status Register */ +#define AT91_MC_AASR		0x08			/* MC Abort Address Status Register */ -#define AT91_MC_MPR		(AT91_MC + 0x0c)	/* MC Master Priority Register */ +#define AT91_MC_MPR		0x0c			/* MC Master Priority Register */  #define		AT91_MPR_MSTP0		(7 <<  0)		/* ARM920T Priority */  #define		AT91_MPR_MSTP1		(7 <<  4)		/* PDC Priority */  #define		AT91_MPR_MSTP2		(7 <<  8)		/* UHP Priority */  #define		AT91_MPR_MSTP3		(7 << 12)		/* EMAC Priority */  /* External Bus Interface (EBI) registers */ -#define AT91_EBI_CSA		(AT91_MC + 0x60)	/* Chip Select Assignment Register */ +#define AT91_EBI_CSA		0x60			/* Chip Select Assignment Register */  #define		AT91_EBI_CS0A		(1 << 0)		/* Chip Select 0 Assignment */  #define			AT91_EBI_CS0A_SMC		(0 << 0)  #define			AT91_EBI_CS0A_BFC		(1 << 0) @@ -66,7 +66,7 @@  #define		AT91_EBI_DBPUC		(1 << 0)		/* Data Bus Pull-Up Configuration */  /* Static Memory Controller (SMC) registers */ -#define	AT91_SMC_CSR(n)		(AT91_MC + 0x70 + ((n) * 4))/* SMC Chip Select Register */ +#define	AT91_SMC_CSR(n)		(0x70 + ((n) * 4))	/* SMC Chip Select Register */  #define		AT91_SMC_NWS		(0x7f <<  0)		/* Number of Wait States */  #define			AT91_SMC_NWS_(x)	((x) << 0)  #define		AT91_SMC_WSEN		(1    <<  7)		/* Wait State Enable */ @@ -87,52 +87,8 @@  #define		AT91_SMC_RWHOLD		(7 << 28)		/* Read & Write Signal Hold Time */  #define			AT91_SMC_RWHOLD_(x)	((x) << 28) -/* SDRAM Controller registers */ -#define AT91_SDRAMC_MR		(AT91_MC + 0x90)	/* Mode Register */ -#define		AT91_SDRAMC_MODE	(0xf << 0)		/* Command Mode */ -#define			AT91_SDRAMC_MODE_NORMAL		(0 << 0) -#define			AT91_SDRAMC_MODE_NOP		(1 << 0) -#define			AT91_SDRAMC_MODE_PRECHARGE	(2 << 0) -#define			AT91_SDRAMC_MODE_LMR		(3 << 0) -#define			AT91_SDRAMC_MODE_REFRESH	(4 << 0) -#define		AT91_SDRAMC_DBW		(1   << 4)		/* Data Bus Width */ -#define			AT91_SDRAMC_DBW_32	(0 << 4) -#define			AT91_SDRAMC_DBW_16	(1 << 4) - -#define AT91_SDRAMC_TR		(AT91_MC + 0x94)	/* Refresh Timer Register */ -#define		AT91_SDRAMC_COUNT	(0xfff << 0)		/* Refresh Timer Count */ - -#define AT91_SDRAMC_CR		(AT91_MC + 0x98)	/* Configuration Register */ -#define		AT91_SDRAMC_NC		(3   <<  0)		/* Number of Column Bits */ -#define			AT91_SDRAMC_NC_8	(0 << 0) -#define			AT91_SDRAMC_NC_9	(1 << 0) -#define			AT91_SDRAMC_NC_10	(2 << 0) -#define			AT91_SDRAMC_NC_11	(3 << 0) -#define		AT91_SDRAMC_NR		(3   <<  2)		/* Number of Row Bits */ -#define			AT91_SDRAMC_NR_11	(0 << 2) -#define			AT91_SDRAMC_NR_12	(1 << 2) -#define			AT91_SDRAMC_NR_13	(2 << 2) -#define		AT91_SDRAMC_NB		(1   <<  4)		/* Number of Banks */ -#define			AT91_SDRAMC_NB_2	(0 << 4) -#define			AT91_SDRAMC_NB_4	(1 << 4) -#define		AT91_SDRAMC_CAS		(3   <<  5)		/* CAS Latency */ -#define			AT91_SDRAMC_CAS_2	(2 << 5) -#define		AT91_SDRAMC_TWR		(0xf <<  7)		/* Write Recovery Delay */ -#define		AT91_SDRAMC_TRC		(0xf << 11)		/* Row Cycle Delay */ -#define		AT91_SDRAMC_TRP		(0xf << 15)		/* Row Precharge Delay */ -#define		AT91_SDRAMC_TRCD	(0xf << 19)		/* Row to Column Delay */ -#define		AT91_SDRAMC_TRAS	(0xf << 23)		/* Active to Precharge Delay */ -#define		AT91_SDRAMC_TXSR	(0xf << 27)		/* Exit Self Refresh to Active Delay */ - -#define AT91_SDRAMC_SRR		(AT91_MC + 0x9c)	/* Self Refresh Register */ -#define AT91_SDRAMC_LPR		(AT91_MC + 0xa0)	/* Low Power Register */ -#define AT91_SDRAMC_IER		(AT91_MC + 0xa4)	/* Interrupt Enable Register */ -#define AT91_SDRAMC_IDR		(AT91_MC + 0xa8)	/* Interrupt Disable Register */ -#define AT91_SDRAMC_IMR		(AT91_MC + 0xac)	/* Interrupt Mask Register */ -#define AT91_SDRAMC_ISR		(AT91_MC + 0xb0)	/* Interrupt Status Register */ -  /* Burst Flash Controller register */ -#define AT91_BFC_MR		(AT91_MC + 0xc0)	/* Mode Register */ +#define AT91_BFC_MR		0xc0			/* Mode Register */  #define		AT91_BFC_BFCOM		(3   <<  0)		/* Burst Flash Controller Operating Mode */  #define			AT91_BFC_BFCOM_DISABLED	(0 << 0)  #define			AT91_BFC_BFCOM_ASYNC	(1 << 0) diff --git a/arch/arm/mach-at91/include/mach/at91rm9200_sdramc.h b/arch/arm/mach-at91/include/mach/at91rm9200_sdramc.h new file mode 100644 index 00000000000..aa047f458f1 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91rm9200_sdramc.h @@ -0,0 +1,63 @@ +/* + * arch/arm/mach-at91/include/mach/at91rm9200_sdramc.h + * + * Copyright (C) 2005 Ivan Kokshaysky + * Copyright (C) SAN People + * + * Memory Controllers (SDRAMC only) - System peripherals registers. + * Based on AT91RM9200 datasheet revision E. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + */ + +#ifndef AT91RM9200_SDRAMC_H +#define AT91RM9200_SDRAMC_H + +/* SDRAM Controller registers */ +#define AT91RM9200_SDRAMC_MR		0x90			/* Mode Register */ +#define		AT91RM9200_SDRAMC_MODE	(0xf << 0)		/* Command Mode */ +#define			AT91RM9200_SDRAMC_MODE_NORMAL		(0 << 0) +#define			AT91RM9200_SDRAMC_MODE_NOP		(1 << 0) +#define			AT91RM9200_SDRAMC_MODE_PRECHARGE	(2 << 0) +#define			AT91RM9200_SDRAMC_MODE_LMR		(3 << 0) +#define			AT91RM9200_SDRAMC_MODE_REFRESH	(4 << 0) +#define		AT91RM9200_SDRAMC_DBW		(1   << 4)		/* Data Bus Width */ +#define			AT91RM9200_SDRAMC_DBW_32	(0 << 4) +#define			AT91RM9200_SDRAMC_DBW_16	(1 << 4) + +#define AT91RM9200_SDRAMC_TR		0x94			/* Refresh Timer Register */ +#define		AT91RM9200_SDRAMC_COUNT	(0xfff << 0)		/* Refresh Timer Count */ + +#define AT91RM9200_SDRAMC_CR		0x98			/* Configuration Register */ +#define		AT91RM9200_SDRAMC_NC		(3   <<  0)		/* Number of Column Bits */ +#define			AT91RM9200_SDRAMC_NC_8	(0 << 0) +#define			AT91RM9200_SDRAMC_NC_9	(1 << 0) +#define			AT91RM9200_SDRAMC_NC_10	(2 << 0) +#define			AT91RM9200_SDRAMC_NC_11	(3 << 0) +#define		AT91RM9200_SDRAMC_NR		(3   <<  2)		/* Number of Row Bits */ +#define			AT91RM9200_SDRAMC_NR_11	(0 << 2) +#define			AT91RM9200_SDRAMC_NR_12	(1 << 2) +#define			AT91RM9200_SDRAMC_NR_13	(2 << 2) +#define		AT91RM9200_SDRAMC_NB		(1   <<  4)		/* Number of Banks */ +#define			AT91RM9200_SDRAMC_NB_2	(0 << 4) +#define			AT91RM9200_SDRAMC_NB_4	(1 << 4) +#define		AT91RM9200_SDRAMC_CAS		(3   <<  5)		/* CAS Latency */ +#define			AT91RM9200_SDRAMC_CAS_2	(2 << 5) +#define		AT91RM9200_SDRAMC_TWR		(0xf <<  7)		/* Write Recovery Delay */ +#define		AT91RM9200_SDRAMC_TRC		(0xf << 11)		/* Row Cycle Delay */ +#define		AT91RM9200_SDRAMC_TRP		(0xf << 15)		/* Row Precharge Delay */ +#define		AT91RM9200_SDRAMC_TRCD	(0xf << 19)		/* Row to Column Delay */ +#define		AT91RM9200_SDRAMC_TRAS	(0xf << 23)		/* Active to Precharge Delay */ +#define		AT91RM9200_SDRAMC_TXSR	(0xf << 27)		/* Exit Self Refresh to Active Delay */ + +#define AT91RM9200_SDRAMC_SRR		0x9c			/* Self Refresh Register */ +#define AT91RM9200_SDRAMC_LPR		0xa0			/* Low Power Register */ +#define AT91RM9200_SDRAMC_IER		0xa4			/* Interrupt Enable Register */ +#define AT91RM9200_SDRAMC_IDR		0xa8			/* Interrupt Disable Register */ +#define AT91RM9200_SDRAMC_IMR		0xac			/* Interrupt Mask Register */ +#define AT91RM9200_SDRAMC_ISR		0xb0			/* Interrupt Status Register */ + +#endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9260.h b/arch/arm/mach-at91/include/mach/at91sam9260.h index 4e79036d3b8..416c7b6c56d 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9260.h +++ b/arch/arm/mach-at91/include/mach/at91sam9260.h @@ -20,8 +20,6 @@  /*   * Peripheral identifiers/interrupts.   */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Peripherals */  #define AT91SAM9260_ID_PIOA	2	/* Parallel IO Controller A */  #define AT91SAM9260_ID_PIOB	3	/* Parallel IO Controller B */  #define AT91SAM9260_ID_PIOC	4	/* Parallel IO Controller C */ @@ -78,35 +76,24 @@  #define AT91SAM9260_BASE_TC4		0xfffdc040  #define AT91SAM9260_BASE_TC5		0xfffdc080  #define AT91SAM9260_BASE_ADC		0xfffe0000 -#define AT91_BASE_SYS			0xffffe800  /* - * System Peripherals (offset from AT91_BASE_SYS) + * System Peripherals   */ -#define AT91_ECC	(0xffffe800 - AT91_BASE_SYS) -#define AT91_SDRAMC0	(0xffffea00 - AT91_BASE_SYS) -#define AT91_SMC	(0xffffec00 - AT91_BASE_SYS) -#define AT91_MATRIX	(0xffffee00 - AT91_BASE_SYS) -#define AT91_CCFG	(0xffffef10 - AT91_BASE_SYS) -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS) -#define AT91_DBGU	(0xfffff200 - AT91_BASE_SYS) -#define AT91_PIOA	(0xfffff400 - AT91_BASE_SYS) -#define AT91_PIOB	(0xfffff600 - AT91_BASE_SYS) -#define AT91_PIOC	(0xfffff800 - AT91_BASE_SYS) -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS) -#define AT91_RSTC	(0xfffffd00 - AT91_BASE_SYS) -#define AT91_SHDWC	(0xfffffd10 - AT91_BASE_SYS) -#define AT91_RTT	(0xfffffd20 - AT91_BASE_SYS) -#define AT91_PIT	(0xfffffd30 - AT91_BASE_SYS) -#define AT91_WDT	(0xfffffd40 - AT91_BASE_SYS) -#define AT91_GPBR	(0xfffffd50 - AT91_BASE_SYS) - -#define AT91_USART0	AT91SAM9260_BASE_US0 -#define AT91_USART1	AT91SAM9260_BASE_US1 -#define AT91_USART2	AT91SAM9260_BASE_US2 -#define AT91_USART3	AT91SAM9260_BASE_US3 -#define AT91_USART4	AT91SAM9260_BASE_US4 -#define AT91_USART5	AT91SAM9260_BASE_US5 +#define AT91SAM9260_BASE_ECC	0xffffe800 +#define AT91SAM9260_BASE_SDRAMC	0xffffea00 +#define AT91SAM9260_BASE_SMC	0xffffec00 +#define AT91SAM9260_BASE_MATRIX	0xffffee00 +#define AT91SAM9260_BASE_DBGU	AT91_BASE_DBGU0 +#define AT91SAM9260_BASE_PIOA	0xfffff400 +#define AT91SAM9260_BASE_PIOB	0xfffff600 +#define AT91SAM9260_BASE_PIOC	0xfffff800 +#define AT91SAM9260_BASE_RSTC	0xfffffd00 +#define AT91SAM9260_BASE_SHDWC	0xfffffd10 +#define AT91SAM9260_BASE_RTT	0xfffffd20 +#define AT91SAM9260_BASE_PIT	0xfffffd30 +#define AT91SAM9260_BASE_WDT	0xfffffd40 +#define AT91SAM9260_BASE_GPBR	0xfffffd50  /* @@ -119,6 +106,8 @@  #define AT91SAM9260_SRAM0_SIZE	SZ_4K		/* Internal SRAM 0 size (4Kb) */  #define AT91SAM9260_SRAM1_BASE	0x00300000	/* Internal SRAM 1 base address */  #define AT91SAM9260_SRAM1_SIZE	SZ_4K		/* Internal SRAM 1 size (4Kb) */ +#define AT91SAM9260_SRAM_BASE	0x002FF000	/* Internal SRAM base address */ +#define AT91SAM9260_SRAM_SIZE	SZ_8K		/* Internal SRAM size (8Kb) */  #define AT91SAM9260_UHP_BASE	0x00500000	/* USB Host controller */ @@ -132,6 +121,8 @@  #define AT91SAM9G20_SRAM0_SIZE	SZ_16K		/* Internal SRAM 0 size (16Kb) */  #define AT91SAM9G20_SRAM1_BASE	0x00300000	/* Internal SRAM 1 base address */  #define AT91SAM9G20_SRAM1_SIZE	SZ_16K		/* Internal SRAM 1 size (16Kb) */ +#define AT91SAM9G20_SRAM_BASE	0x002FC000	/* Internal SRAM base address */ +#define AT91SAM9G20_SRAM_SIZE	SZ_32K		/* Internal SRAM size (32Kb) */  #define AT91SAM9G20_UHP_BASE	0x00500000	/* USB Host controller */ diff --git a/arch/arm/mach-at91/include/mach/at91sam9260_matrix.h b/arch/arm/mach-at91/include/mach/at91sam9260_matrix.h index 020f02ed921..f459df42062 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9260_matrix.h +++ b/arch/arm/mach-at91/include/mach/at91sam9260_matrix.h @@ -15,12 +15,12 @@  #ifndef AT91SAM9260_MATRIX_H  #define AT91SAM9260_MATRIX_H -#define AT91_MATRIX_MCFG0	(AT91_MATRIX + 0x00)	/* Master Configuration Register 0 */ -#define AT91_MATRIX_MCFG1	(AT91_MATRIX + 0x04)	/* Master Configuration Register 1 */ -#define AT91_MATRIX_MCFG2	(AT91_MATRIX + 0x08)	/* Master Configuration Register 2 */ -#define AT91_MATRIX_MCFG3	(AT91_MATRIX + 0x0C)	/* Master Configuration Register 3 */ -#define AT91_MATRIX_MCFG4	(AT91_MATRIX + 0x10)	/* Master Configuration Register 4 */ -#define AT91_MATRIX_MCFG5	(AT91_MATRIX + 0x14)	/* Master Configuration Register 5 */ +#define AT91_MATRIX_MCFG0	0x00			/* Master Configuration Register 0 */ +#define AT91_MATRIX_MCFG1	0x04			/* Master Configuration Register 1 */ +#define AT91_MATRIX_MCFG2	0x08			/* Master Configuration Register 2 */ +#define AT91_MATRIX_MCFG3	0x0C			/* Master Configuration Register 3 */ +#define AT91_MATRIX_MCFG4	0x10			/* Master Configuration Register 4 */ +#define AT91_MATRIX_MCFG5	0x14			/* Master Configuration Register 5 */  #define		AT91_MATRIX_ULBT		(7 << 0)	/* Undefined Length Burst Type */  #define			AT91_MATRIX_ULBT_INFINITE	(0 << 0)  #define			AT91_MATRIX_ULBT_SINGLE		(1 << 0) @@ -28,11 +28,11 @@  #define			AT91_MATRIX_ULBT_EIGHT		(3 << 0)  #define			AT91_MATRIX_ULBT_SIXTEEN	(4 << 0) -#define AT91_MATRIX_SCFG0	(AT91_MATRIX + 0x40)	/* Slave Configuration Register 0 */ -#define AT91_MATRIX_SCFG1	(AT91_MATRIX + 0x44)	/* Slave Configuration Register 1 */ -#define AT91_MATRIX_SCFG2	(AT91_MATRIX + 0x48)	/* Slave Configuration Register 2 */ -#define AT91_MATRIX_SCFG3	(AT91_MATRIX + 0x4C)	/* Slave Configuration Register 3 */ -#define AT91_MATRIX_SCFG4	(AT91_MATRIX + 0x50)	/* Slave Configuration Register 4 */ +#define AT91_MATRIX_SCFG0	0x40			/* Slave Configuration Register 0 */ +#define AT91_MATRIX_SCFG1	0x44			/* Slave Configuration Register 1 */ +#define AT91_MATRIX_SCFG2	0x48			/* Slave Configuration Register 2 */ +#define AT91_MATRIX_SCFG3	0x4C			/* Slave Configuration Register 3 */ +#define AT91_MATRIX_SCFG4	0x50			/* Slave Configuration Register 4 */  #define		AT91_MATRIX_SLOT_CYCLE		(0xff <<  0)	/* Maximum Number of Allowed Cycles for a Burst */  #define		AT91_MATRIX_DEFMSTR_TYPE	(3    << 16)	/* Default Master Type */  #define			AT91_MATRIX_DEFMSTR_TYPE_NONE	(0 << 16) @@ -43,11 +43,11 @@  #define			AT91_MATRIX_ARBT_ROUND_ROBIN	(0 << 24)  #define			AT91_MATRIX_ARBT_FIXED_PRIORITY	(1 << 24) -#define AT91_MATRIX_PRAS0	(AT91_MATRIX + 0x80)	/* Priority Register A for Slave 0 */ -#define AT91_MATRIX_PRAS1	(AT91_MATRIX + 0x88)	/* Priority Register A for Slave 1 */ -#define AT91_MATRIX_PRAS2	(AT91_MATRIX + 0x90)	/* Priority Register A for Slave 2 */ -#define AT91_MATRIX_PRAS3	(AT91_MATRIX + 0x98)	/* Priority Register A for Slave 3 */ -#define AT91_MATRIX_PRAS4	(AT91_MATRIX + 0xA0)	/* Priority Register A for Slave 4 */ +#define AT91_MATRIX_PRAS0	0x80			/* Priority Register A for Slave 0 */ +#define AT91_MATRIX_PRAS1	0x88			/* Priority Register A for Slave 1 */ +#define AT91_MATRIX_PRAS2	0x90			/* Priority Register A for Slave 2 */ +#define AT91_MATRIX_PRAS3	0x98			/* Priority Register A for Slave 3 */ +#define AT91_MATRIX_PRAS4	0xA0			/* Priority Register A for Slave 4 */  #define		AT91_MATRIX_M0PR		(3 << 0)	/* Master 0 Priority */  #define		AT91_MATRIX_M1PR		(3 << 4)	/* Master 1 Priority */  #define		AT91_MATRIX_M2PR		(3 << 8)	/* Master 2 Priority */ @@ -55,11 +55,11 @@  #define		AT91_MATRIX_M4PR		(3 << 16)	/* Master 4 Priority */  #define		AT91_MATRIX_M5PR		(3 << 20)	/* Master 5 Priority */ -#define AT91_MATRIX_MRCR	(AT91_MATRIX + 0x100)	/* Master Remap Control Register */ +#define AT91_MATRIX_MRCR	0x100			/* Master Remap Control Register */  #define		AT91_MATRIX_RCB0		(1 << 0)	/* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */  #define		AT91_MATRIX_RCB1		(1 << 1)	/* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */ -#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x11C)	/* EBI Chip Select Assignment Register */ +#define AT91_MATRIX_EBICSA	0x11C			/* EBI Chip Select Assignment Register */  #define		AT91_MATRIX_CS1A		(1 << 1)	/* Chip Select 1 Assignment */  #define			AT91_MATRIX_CS1A_SMC		(0 << 1)  #define			AT91_MATRIX_CS1A_SDRAMC		(1 << 1) diff --git a/arch/arm/mach-at91/include/mach/at91sam9261.h b/arch/arm/mach-at91/include/mach/at91sam9261.h index 2b561851812..a041406d06e 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9261.h +++ b/arch/arm/mach-at91/include/mach/at91sam9261.h @@ -18,8 +18,6 @@  /*   * Peripheral identifiers/interrupts.   */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Peripherals */  #define AT91SAM9261_ID_PIOA	2	/* Parallel IO Controller A */  #define AT91SAM9261_ID_PIOB	3	/* Parallel IO Controller B */  #define AT91SAM9261_ID_PIOC	4	/* Parallel IO Controller C */ @@ -62,31 +60,24 @@  #define AT91SAM9261_BASE_SSC2		0xfffc4000  #define AT91SAM9261_BASE_SPI0		0xfffc8000  #define AT91SAM9261_BASE_SPI1		0xfffcc000 -#define AT91_BASE_SYS			0xffffea00  /* - * System Peripherals (offset from AT91_BASE_SYS) + * System Peripherals   */ -#define AT91_SDRAMC0	(0xffffea00 - AT91_BASE_SYS) -#define AT91_SMC	(0xffffec00 - AT91_BASE_SYS) -#define AT91_MATRIX	(0xffffee00 - AT91_BASE_SYS) -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS) -#define AT91_DBGU	(0xfffff200 - AT91_BASE_SYS) -#define AT91_PIOA	(0xfffff400 - AT91_BASE_SYS) -#define AT91_PIOB	(0xfffff600 - AT91_BASE_SYS) -#define AT91_PIOC	(0xfffff800 - AT91_BASE_SYS) -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS) -#define AT91_RSTC	(0xfffffd00 - AT91_BASE_SYS) -#define AT91_SHDWC	(0xfffffd10 - AT91_BASE_SYS) -#define AT91_RTT	(0xfffffd20 - AT91_BASE_SYS) -#define AT91_PIT	(0xfffffd30 - AT91_BASE_SYS) -#define AT91_WDT	(0xfffffd40 - AT91_BASE_SYS) -#define AT91_GPBR	(0xfffffd50 - AT91_BASE_SYS) - -#define AT91_USART0	AT91SAM9261_BASE_US0 -#define AT91_USART1	AT91SAM9261_BASE_US1 -#define AT91_USART2	AT91SAM9261_BASE_US2 +#define AT91SAM9261_BASE_SMC	0xffffec00 +#define AT91SAM9261_BASE_MATRIX	0xffffee00 +#define AT91SAM9261_BASE_SDRAMC	0xffffea00 +#define AT91SAM9261_BASE_DBGU	AT91_BASE_DBGU0 +#define AT91SAM9261_BASE_PIOA	0xfffff400 +#define AT91SAM9261_BASE_PIOB	0xfffff600 +#define AT91SAM9261_BASE_PIOC	0xfffff800 +#define AT91SAM9261_BASE_RSTC	0xfffffd00 +#define AT91SAM9261_BASE_SHDWC	0xfffffd10 +#define AT91SAM9261_BASE_RTT	0xfffffd20 +#define AT91SAM9261_BASE_PIT	0xfffffd30 +#define AT91SAM9261_BASE_WDT	0xfffffd40 +#define AT91SAM9261_BASE_GPBR	0xfffffd50  /* diff --git a/arch/arm/mach-at91/include/mach/at91sam9261_matrix.h b/arch/arm/mach-at91/include/mach/at91sam9261_matrix.h index 69c6501915d..a50cdf8b8ca 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9261_matrix.h +++ b/arch/arm/mach-at91/include/mach/at91sam9261_matrix.h @@ -15,15 +15,15 @@  #ifndef AT91SAM9261_MATRIX_H  #define AT91SAM9261_MATRIX_H -#define AT91_MATRIX_MCFG	(AT91_MATRIX + 0x00)	/* Master Configuration Register */ +#define AT91_MATRIX_MCFG	0x00			/* Master Configuration Register */  #define		AT91_MATRIX_RCB0	(1 << 0)		/* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */  #define		AT91_MATRIX_RCB1	(1 << 1)		/* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */ -#define AT91_MATRIX_SCFG0	(AT91_MATRIX + 0x04)	/* Slave Configuration Register 0 */ -#define AT91_MATRIX_SCFG1	(AT91_MATRIX + 0x08)	/* Slave Configuration Register 1 */ -#define AT91_MATRIX_SCFG2	(AT91_MATRIX + 0x0C)	/* Slave Configuration Register 2 */ -#define AT91_MATRIX_SCFG3	(AT91_MATRIX + 0x10)	/* Slave Configuration Register 3 */ -#define AT91_MATRIX_SCFG4	(AT91_MATRIX + 0x14)	/* Slave Configuration Register 4 */ +#define AT91_MATRIX_SCFG0	0x04			/* Slave Configuration Register 0 */ +#define AT91_MATRIX_SCFG1	0x08			/* Slave Configuration Register 1 */ +#define AT91_MATRIX_SCFG2	0x0C			/* Slave Configuration Register 2 */ +#define AT91_MATRIX_SCFG3	0x10			/* Slave Configuration Register 3 */ +#define AT91_MATRIX_SCFG4	0x14			/* Slave Configuration Register 4 */  #define		AT91_MATRIX_SLOT_CYCLE		(0xff << 0)	/* Maximum Number of Allowed Cycles for a Burst */  #define		AT91_MATRIX_DEFMSTR_TYPE	(3    << 16)	/* Default Master Type */  #define			AT91_MATRIX_DEFMSTR_TYPE_NONE	(0 << 16) @@ -31,7 +31,7 @@  #define			AT91_MATRIX_DEFMSTR_TYPE_FIXED	(2 << 16)  #define		AT91_MATRIX_FIXED_DEFMSTR	(7    << 18)	/* Fixed Index of Default Master */ -#define AT91_MATRIX_TCR		(AT91_MATRIX + 0x24)	/* TCM Configuration Register */ +#define AT91_MATRIX_TCR		0x24			/* TCM Configuration Register */  #define		AT91_MATRIX_ITCM_SIZE		(0xf << 0)	/* Size of ITCM enabled memory block */  #define			AT91_MATRIX_ITCM_0		(0 << 0)  #define			AT91_MATRIX_ITCM_16		(5 << 0) @@ -43,7 +43,7 @@  #define			AT91_MATRIX_DTCM_32		(6 << 4)  #define			AT91_MATRIX_DTCM_64		(7 << 4) -#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x30)	/* EBI Chip Select Assignment Register */ +#define AT91_MATRIX_EBICSA	0x30			/* EBI Chip Select Assignment Register */  #define		AT91_MATRIX_CS1A		(1 << 1)	/* Chip Select 1 Assignment */  #define			AT91_MATRIX_CS1A_SMC		(0 << 1)  #define			AT91_MATRIX_CS1A_SDRAMC		(1 << 1) @@ -58,7 +58,7 @@  #define			AT91_MATRIX_CS5A_SMC_CF2	(1 << 5)  #define		AT91_MATRIX_DBPUC		(1 << 8)	/* Data Bus Pull-up Configuration */ -#define AT91_MATRIX_USBPUCR	(AT91_MATRIX + 0x34)	/* USB Pad Pull-Up Control Register */ +#define AT91_MATRIX_USBPUCR	0x34			/* USB Pad Pull-Up Control Register */  #define		AT91_MATRIX_USBPUCR_PUON	(1 << 30)	/* USB Device PAD Pull-up Enable */  #endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9263.h b/arch/arm/mach-at91/include/mach/at91sam9263.h index 2091f1e42d4..d201029d60b 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9263.h +++ b/arch/arm/mach-at91/include/mach/at91sam9263.h @@ -18,8 +18,6 @@  /*   * Peripheral identifiers/interrupts.   */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Peripherals */  #define AT91SAM9263_ID_PIOA	2	/* Parallel IO Controller A */  #define AT91SAM9263_ID_PIOB	3	/* Parallel IO Controller B */  #define AT91SAM9263_ID_PIOCDE	4	/* Parallel IO Controller C, D and E */ @@ -72,38 +70,30 @@  #define AT91SAM9263_BASE_EMAC		0xfffbc000  #define AT91SAM9263_BASE_ISI		0xfffc4000  #define AT91SAM9263_BASE_2DGE		0xfffc8000 -#define AT91_BASE_SYS			0xffffe000  /* - * System Peripherals (offset from AT91_BASE_SYS) + * System Peripherals   */ -#define AT91_ECC0	(0xffffe000 - AT91_BASE_SYS) -#define AT91_SDRAMC0	(0xffffe200 - AT91_BASE_SYS) -#define AT91_SMC0	(0xffffe400 - AT91_BASE_SYS) -#define AT91_ECC1	(0xffffe600 - AT91_BASE_SYS) -#define AT91_SDRAMC1	(0xffffe800 - AT91_BASE_SYS) -#define AT91_SMC1	(0xffffea00 - AT91_BASE_SYS) -#define AT91_MATRIX	(0xffffec00 - AT91_BASE_SYS) -#define AT91_CCFG	(0xffffed10 - AT91_BASE_SYS) -#define AT91_DBGU	(0xffffee00 - AT91_BASE_SYS) -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS) -#define AT91_PIOA	(0xfffff200 - AT91_BASE_SYS) -#define AT91_PIOB	(0xfffff400 - AT91_BASE_SYS) -#define AT91_PIOC	(0xfffff600 - AT91_BASE_SYS) -#define AT91_PIOD	(0xfffff800 - AT91_BASE_SYS) -#define AT91_PIOE	(0xfffffa00 - AT91_BASE_SYS) -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS) -#define AT91_RSTC	(0xfffffd00 - AT91_BASE_SYS) -#define AT91_SHDWC	(0xfffffd10 - AT91_BASE_SYS) -#define AT91_RTT0	(0xfffffd20 - AT91_BASE_SYS) -#define AT91_PIT	(0xfffffd30 - AT91_BASE_SYS) -#define AT91_WDT	(0xfffffd40 - AT91_BASE_SYS) -#define AT91_RTT1	(0xfffffd50 - AT91_BASE_SYS) -#define AT91_GPBR	(0xfffffd60 - AT91_BASE_SYS) - -#define AT91_USART0	AT91SAM9263_BASE_US0 -#define AT91_USART1	AT91SAM9263_BASE_US1 -#define AT91_USART2	AT91SAM9263_BASE_US2 +#define AT91SAM9263_BASE_ECC0	0xffffe000 +#define AT91SAM9263_BASE_SDRAMC0 0xffffe200 +#define AT91SAM9263_BASE_SMC0	0xffffe400 +#define AT91SAM9263_BASE_ECC1	0xffffe600 +#define AT91SAM9263_BASE_SDRAMC1 0xffffe800 +#define AT91SAM9263_BASE_SMC1	0xffffea00 +#define AT91SAM9263_BASE_MATRIX	0xffffec00 +#define AT91SAM9263_BASE_DBGU	AT91_BASE_DBGU1 +#define AT91SAM9263_BASE_PIOA	0xfffff200 +#define AT91SAM9263_BASE_PIOB	0xfffff400 +#define AT91SAM9263_BASE_PIOC	0xfffff600 +#define AT91SAM9263_BASE_PIOD	0xfffff800 +#define AT91SAM9263_BASE_PIOE	0xfffffa00 +#define AT91SAM9263_BASE_RSTC	0xfffffd00 +#define AT91SAM9263_BASE_SHDWC	0xfffffd10 +#define AT91SAM9263_BASE_RTT0	0xfffffd20 +#define AT91SAM9263_BASE_PIT	0xfffffd30 +#define AT91SAM9263_BASE_WDT	0xfffffd40 +#define AT91SAM9263_BASE_RTT1	0xfffffd50 +#define AT91SAM9263_BASE_GPBR	0xfffffd60  #define AT91_SMC	AT91_SMC0 diff --git a/arch/arm/mach-at91/include/mach/at91sam9263_matrix.h b/arch/arm/mach-at91/include/mach/at91sam9263_matrix.h index 9b3efd3eb2f..ebb5fdb565e 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9263_matrix.h +++ b/arch/arm/mach-at91/include/mach/at91sam9263_matrix.h @@ -15,15 +15,15 @@  #ifndef AT91SAM9263_MATRIX_H  #define AT91SAM9263_MATRIX_H -#define AT91_MATRIX_MCFG0	(AT91_MATRIX + 0x00)	/* Master Configuration Register 0 */ -#define AT91_MATRIX_MCFG1	(AT91_MATRIX + 0x04)	/* Master Configuration Register 1 */ -#define AT91_MATRIX_MCFG2	(AT91_MATRIX + 0x08)	/* Master Configuration Register 2 */ -#define AT91_MATRIX_MCFG3	(AT91_MATRIX + 0x0C)	/* Master Configuration Register 3 */ -#define AT91_MATRIX_MCFG4	(AT91_MATRIX + 0x10)	/* Master Configuration Register 4 */ -#define AT91_MATRIX_MCFG5	(AT91_MATRIX + 0x14)	/* Master Configuration Register 5 */ -#define AT91_MATRIX_MCFG6	(AT91_MATRIX + 0x18)	/* Master Configuration Register 6 */ -#define AT91_MATRIX_MCFG7	(AT91_MATRIX + 0x1C)	/* Master Configuration Register 7 */ -#define AT91_MATRIX_MCFG8	(AT91_MATRIX + 0x20)	/* Master Configuration Register 8 */ +#define AT91_MATRIX_MCFG0	0x00			/* Master Configuration Register 0 */ +#define AT91_MATRIX_MCFG1	0x04			/* Master Configuration Register 1 */ +#define AT91_MATRIX_MCFG2	0x08			/* Master Configuration Register 2 */ +#define AT91_MATRIX_MCFG3	0x0C			/* Master Configuration Register 3 */ +#define AT91_MATRIX_MCFG4	0x10			/* Master Configuration Register 4 */ +#define AT91_MATRIX_MCFG5	0x14			/* Master Configuration Register 5 */ +#define AT91_MATRIX_MCFG6	0x18			/* Master Configuration Register 6 */ +#define AT91_MATRIX_MCFG7	0x1C			/* Master Configuration Register 7 */ +#define AT91_MATRIX_MCFG8	0x20			/* Master Configuration Register 8 */  #define		AT91_MATRIX_ULBT	(7 << 0)	/* Undefined Length Burst Type */  #define			AT91_MATRIX_ULBT_INFINITE	(0 << 0)  #define			AT91_MATRIX_ULBT_SINGLE		(1 << 0) @@ -31,14 +31,14 @@  #define			AT91_MATRIX_ULBT_EIGHT		(3 << 0)  #define			AT91_MATRIX_ULBT_SIXTEEN	(4 << 0) -#define AT91_MATRIX_SCFG0	(AT91_MATRIX + 0x40)	/* Slave Configuration Register 0 */ -#define AT91_MATRIX_SCFG1	(AT91_MATRIX + 0x44)	/* Slave Configuration Register 1 */ -#define AT91_MATRIX_SCFG2	(AT91_MATRIX + 0x48)	/* Slave Configuration Register 2 */ -#define AT91_MATRIX_SCFG3	(AT91_MATRIX + 0x4C)	/* Slave Configuration Register 3 */ -#define AT91_MATRIX_SCFG4	(AT91_MATRIX + 0x50)	/* Slave Configuration Register 4 */ -#define AT91_MATRIX_SCFG5	(AT91_MATRIX + 0x54)	/* Slave Configuration Register 5 */ -#define AT91_MATRIX_SCFG6	(AT91_MATRIX + 0x58)	/* Slave Configuration Register 6 */ -#define AT91_MATRIX_SCFG7	(AT91_MATRIX + 0x5C)	/* Slave Configuration Register 7 */ +#define AT91_MATRIX_SCFG0	0x40			/* Slave Configuration Register 0 */ +#define AT91_MATRIX_SCFG1	0x44			/* Slave Configuration Register 1 */ +#define AT91_MATRIX_SCFG2	0x48			/* Slave Configuration Register 2 */ +#define AT91_MATRIX_SCFG3	0x4C			/* Slave Configuration Register 3 */ +#define AT91_MATRIX_SCFG4	0x50			/* Slave Configuration Register 4 */ +#define AT91_MATRIX_SCFG5	0x54			/* Slave Configuration Register 5 */ +#define AT91_MATRIX_SCFG6	0x58			/* Slave Configuration Register 6 */ +#define AT91_MATRIX_SCFG7	0x5C			/* Slave Configuration Register 7 */  #define		AT91_MATRIX_SLOT_CYCLE		(0xff << 0)	/* Maximum Number of Allowed Cycles for a Burst */  #define		AT91_MATRIX_DEFMSTR_TYPE	(3    << 16)	/* Default Master Type */  #define			AT91_MATRIX_DEFMSTR_TYPE_NONE	(0 << 16) @@ -49,22 +49,22 @@  #define			AT91_MATRIX_ARBT_ROUND_ROBIN	(0 << 24)  #define			AT91_MATRIX_ARBT_FIXED_PRIORITY	(1 << 24) -#define AT91_MATRIX_PRAS0	(AT91_MATRIX + 0x80)	/* Priority Register A for Slave 0 */ -#define AT91_MATRIX_PRBS0	(AT91_MATRIX + 0x84)	/* Priority Register B for Slave 0 */ -#define AT91_MATRIX_PRAS1	(AT91_MATRIX + 0x88)	/* Priority Register A for Slave 1 */ -#define AT91_MATRIX_PRBS1	(AT91_MATRIX + 0x8C)	/* Priority Register B for Slave 1 */ -#define AT91_MATRIX_PRAS2	(AT91_MATRIX + 0x90)	/* Priority Register A for Slave 2 */ -#define AT91_MATRIX_PRBS2	(AT91_MATRIX + 0x94)	/* Priority Register B for Slave 2 */ -#define AT91_MATRIX_PRAS3	(AT91_MATRIX + 0x98)	/* Priority Register A for Slave 3 */ -#define AT91_MATRIX_PRBS3	(AT91_MATRIX + 0x9C)	/* Priority Register B for Slave 3 */ -#define AT91_MATRIX_PRAS4	(AT91_MATRIX + 0xA0)	/* Priority Register A for Slave 4 */ -#define AT91_MATRIX_PRBS4	(AT91_MATRIX + 0xA4)	/* Priority Register B for Slave 4 */ -#define AT91_MATRIX_PRAS5	(AT91_MATRIX + 0xA8)	/* Priority Register A for Slave 5 */ -#define AT91_MATRIX_PRBS5	(AT91_MATRIX + 0xAC)	/* Priority Register B for Slave 5 */ -#define AT91_MATRIX_PRAS6	(AT91_MATRIX + 0xB0)	/* Priority Register A for Slave 6 */ -#define AT91_MATRIX_PRBS6	(AT91_MATRIX + 0xB4)	/* Priority Register B for Slave 6 */ -#define AT91_MATRIX_PRAS7	(AT91_MATRIX + 0xB8)	/* Priority Register A for Slave 7 */ -#define AT91_MATRIX_PRBS7	(AT91_MATRIX + 0xBC)	/* Priority Register B for Slave 7 */ +#define AT91_MATRIX_PRAS0	0x80			/* Priority Register A for Slave 0 */ +#define AT91_MATRIX_PRBS0	0x84			/* Priority Register B for Slave 0 */ +#define AT91_MATRIX_PRAS1	0x88			/* Priority Register A for Slave 1 */ +#define AT91_MATRIX_PRBS1	0x8C			/* Priority Register B for Slave 1 */ +#define AT91_MATRIX_PRAS2	0x90			/* Priority Register A for Slave 2 */ +#define AT91_MATRIX_PRBS2	0x94			/* Priority Register B for Slave 2 */ +#define AT91_MATRIX_PRAS3	0x98			/* Priority Register A for Slave 3 */ +#define AT91_MATRIX_PRBS3	0x9C			/* Priority Register B for Slave 3 */ +#define AT91_MATRIX_PRAS4	0xA0			/* Priority Register A for Slave 4 */ +#define AT91_MATRIX_PRBS4	0xA4			/* Priority Register B for Slave 4 */ +#define AT91_MATRIX_PRAS5	0xA8			/* Priority Register A for Slave 5 */ +#define AT91_MATRIX_PRBS5	0xAC			/* Priority Register B for Slave 5 */ +#define AT91_MATRIX_PRAS6	0xB0			/* Priority Register A for Slave 6 */ +#define AT91_MATRIX_PRBS6	0xB4			/* Priority Register B for Slave 6 */ +#define AT91_MATRIX_PRAS7	0xB8			/* Priority Register A for Slave 7 */ +#define AT91_MATRIX_PRBS7	0xBC			/* Priority Register B for Slave 7 */  #define		AT91_MATRIX_M0PR		(3 << 0)	/* Master 0 Priority */  #define		AT91_MATRIX_M1PR		(3 << 4)	/* Master 1 Priority */  #define		AT91_MATRIX_M2PR		(3 << 8)	/* Master 2 Priority */ @@ -75,7 +75,7 @@  #define		AT91_MATRIX_M7PR		(3 << 28)	/* Master 7 Priority */  #define		AT91_MATRIX_M8PR		(3 << 0)	/* Master 8 Priority (in Register B) */ -#define AT91_MATRIX_MRCR	(AT91_MATRIX + 0x100)	/* Master Remap Control Register */ +#define AT91_MATRIX_MRCR	0x100			/* Master Remap Control Register */  #define		AT91_MATRIX_RCB0		(1 << 0)	/* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */  #define		AT91_MATRIX_RCB1		(1 << 1)	/* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */  #define		AT91_MATRIX_RCB2		(1 << 2) @@ -86,7 +86,7 @@  #define		AT91_MATRIX_RCB7		(1 << 7)  #define		AT91_MATRIX_RCB8		(1 << 8) -#define AT91_MATRIX_TCMR	(AT91_MATRIX + 0x114)	/* TCM Configuration Register */ +#define AT91_MATRIX_TCMR	0x114			/* TCM Configuration Register */  #define		AT91_MATRIX_ITCM_SIZE		(0xf << 0)	/* Size of ITCM enabled memory block */  #define			AT91_MATRIX_ITCM_0		(0 << 0)  #define			AT91_MATRIX_ITCM_16		(5 << 0) @@ -96,7 +96,7 @@  #define			AT91_MATRIX_DTCM_16		(5 << 4)  #define			AT91_MATRIX_DTCM_32		(6 << 4) -#define AT91_MATRIX_EBI0CSA	(AT91_MATRIX + 0x120)	/* EBI0 Chip Select Assignment Register */ +#define AT91_MATRIX_EBI0CSA	0x120			/* EBI0 Chip Select Assignment Register */  #define		AT91_MATRIX_EBI0_CS1A		(1 << 1)	/* Chip Select 1 Assignment */  #define			AT91_MATRIX_EBI0_CS1A_SMC		(0 << 1)  #define			AT91_MATRIX_EBI0_CS1A_SDRAMC		(1 << 1) @@ -114,7 +114,7 @@  #define			AT91_MATRIX_EBI0_VDDIOMSEL_1_8V		(0 << 16)  #define			AT91_MATRIX_EBI0_VDDIOMSEL_3_3V		(1 << 16) -#define AT91_MATRIX_EBI1CSA	(AT91_MATRIX + 0x124)	/* EBI1 Chip Select Assignment Register */ +#define AT91_MATRIX_EBI1CSA	0x124			/* EBI1 Chip Select Assignment Register */  #define		AT91_MATRIX_EBI1_CS1A		(1 << 1)	/* Chip Select 1 Assignment */  #define			AT91_MATRIX_EBI1_CS1A_SMC		(0 << 1)  #define			AT91_MATRIX_EBI1_CS1A_SDRAMC		(1 << 1) diff --git a/arch/arm/mach-at91/include/mach/at91sam9_ddrsdr.h b/arch/arm/mach-at91/include/mach/at91sam9_ddrsdr.h index d27b15ba8eb..0210797abf2 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9_ddrsdr.h +++ b/arch/arm/mach-at91/include/mach/at91sam9_ddrsdr.h @@ -46,10 +46,10 @@  #define			AT91_DDRSDRC_CAS_25	(6 << 4)  #define		AT91_DDRSDRC_RST_DLL	(1 << 7)		/* Reset DLL */  #define		AT91_DDRSDRC_DICDS	(1 << 8)		/* Output impedance control */ -#define		AT91_DDRSDRC_DIS_DLL	(1 << 9)		/* Disable DLL */ -#define		AT91_DDRSDRC_OCD	(1 << 12)		/* Off-Chip Driver */ -#define		AT91_DDRSDRC_DQMS	(1 << 16)		/* Mask Data is Shared */ -#define		AT91_DDRSDRC_ACTBST	(1 << 18)		/* Active Bank X to Burst Stop Read Access Bank Y */ +#define		AT91_DDRSDRC_DIS_DLL	(1 << 9)		/* Disable DLL [SAM9 Only] */ +#define		AT91_DDRSDRC_OCD	(1 << 12)		/* Off-Chip Driver [SAM9 Only] */ +#define		AT91_DDRSDRC_DQMS	(1 << 16)		/* Mask Data is Shared [SAM9 Only] */ +#define		AT91_DDRSDRC_ACTBST	(1 << 18)		/* Active Bank X to Burst Stop Read Access Bank Y [SAM9 Only] */  #define AT91_DDRSDRC_T0PR	0x0C	/* Timing 0 Register */  #define		AT91_DDRSDRC_TRAS	(0xf <<  0)		/* Active to Precharge delay */ @@ -59,7 +59,7 @@  #define		AT91_DDRSDRC_TRP	(0xf << 16)		/* Row precharge delay */  #define		AT91_DDRSDRC_TRRD	(0xf << 20)		/* Active BankA to BankB */  #define		AT91_DDRSDRC_TWTR	(0x7 << 24)		/* Internal Write to Read delay */ -#define		AT91_DDRSDRC_RED_WRRD	(0x1 << 27)		/* Reduce Write to Read Delay */ +#define		AT91_DDRSDRC_RED_WRRD	(0x1 << 27)		/* Reduce Write to Read Delay [SAM9 Only] */  #define		AT91_DDRSDRC_TMRD	(0xf << 28)		/* Load mode to active/refresh delay */  #define AT91_DDRSDRC_T1PR	0x10	/* Timing 1 Register */ @@ -68,7 +68,7 @@  #define		AT91_DDRSDRC_TXSRD	(0xff << 16)		/* Exit self-refresh to read */  #define		AT91_DDRSDRC_TXP	(0xf  << 24)		/* Exit power-down delay */ -#define AT91_DDRSDRC_T2PR	0x14	/* Timing 2 Register */ +#define AT91_DDRSDRC_T2PR	0x14	/* Timing 2 Register [SAM9 Only] */  #define		AT91_DDRSDRC_TXARD	(0xf  << 0)		/* Exit active power down delay to read command in mode "Fast Exit" */  #define		AT91_DDRSDRC_TXARDS	(0xf  << 4)		/* Exit active power down delay to read command in mode "Slow Exit" */  #define		AT91_DDRSDRC_TRPA	(0xf  << 8)		/* Row Precharge All delay */ @@ -96,7 +96,7 @@  #define			AT91_DDRSDRC_MD_SDR		0  #define			AT91_DDRSDRC_MD_LOW_POWER_SDR	1  #define			AT91_DDRSDRC_MD_LOW_POWER_DDR	3 -#define			AT91_DDRSDRC_MD_DDR2		6 +#define			AT91_DDRSDRC_MD_DDR2		6	/* [SAM9 Only] */  #define		AT91_DDRSDRC_DBW	(1 << 4)		/* Data Bus Width */  #define			AT91_DDRSDRC_DBW_32BITS		(0 <<  4)  #define			AT91_DDRSDRC_DBW_16BITS		(1 <<  4) @@ -107,24 +107,18 @@  #define		AT91_DDRSDRC_MDOVF	(1 << 2)		/* Master Delay Overflow */  #define		AT91_DDRSDRC_MDVAL	(0xff <<  8)		/* Master Delay value */ -#define AT91_DDRSDRC_HS		0x2C	/* High Speed Register */ +#define AT91_DDRSDRC_HS		0x2C	/* High Speed Register [SAM9 Only] */  #define		AT91_DDRSDRC_DIS_ATCP_RD	(1 << 2)	/* Anticip read access is disabled */  #define AT91_DDRSDRC_DELAY(n)	(0x30 + (0x4 * (n)))	/* Delay I/O Register n */ -#define AT91_DDRSDRC_WPMR	0xE4	/* Write Protect Mode Register */ +#define AT91_DDRSDRC_WPMR	0xE4	/* Write Protect Mode Register [SAM9 Only] */  #define		AT91_DDRSDRC_WP		(1 << 0)		/* Write protect enable */  #define		AT91_DDRSDRC_WPKEY	(0xffffff << 8)		/* Write protect key */  #define		AT91_DDRSDRC_KEY	(0x444452 << 8)		/* Write protect key = "DDR" */ -#define AT91_DDRSDRC_WPSR	0xE8	/* Write Protect Status Register */ +#define AT91_DDRSDRC_WPSR	0xE8	/* Write Protect Status Register [SAM9 Only] */  #define		AT91_DDRSDRC_WPVS	(1 << 0)		/* Write protect violation status */  #define		AT91_DDRSDRC_WPVSRC	(0xffff << 8)		/* Write protect violation source */ -/* Register access macros */ -#define at91_ramc_read(num, reg) \ -	at91_sys_read(AT91_DDRSDRC##num + reg) -#define at91_ramc_write(num, reg, value) \ -	at91_sys_write(AT91_DDRSDRC##num + reg, value) -  #endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h b/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h index 100f5a59292..3d085a9a745 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h +++ b/arch/arm/mach-at91/include/mach/at91sam9_sdramc.h @@ -82,10 +82,4 @@  #define			AT91_SDRAMC_MD_SDRAM		0  #define			AT91_SDRAMC_MD_LOW_POWER_SDRAM	1 -/* Register access macros */ -#define at91_ramc_read(num, reg) \ -	at91_sys_read(AT91_SDRAMC##num + reg) -#define at91_ramc_write(num, reg, value) \ -	at91_sys_write(AT91_SDRAMC##num + reg, value) -  #endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9_smc.h b/arch/arm/mach-at91/include/mach/at91sam9_smc.h index 57de6207e57..175e1fdd9fe 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9_smc.h +++ b/arch/arm/mach-at91/include/mach/at91sam9_smc.h @@ -16,7 +16,38 @@  #ifndef AT91SAM9_SMC_H  #define AT91SAM9_SMC_H -#define AT91_SMC_SETUP(n)	(AT91_SMC + 0x00 + ((n)*0x10))	/* Setup Register for CS n */ +#include <mach/cpu.h> + +#ifndef __ASSEMBLY__ +struct sam9_smc_config { +	/* Setup register */ +	u8 ncs_read_setup; +	u8 nrd_setup; +	u8 ncs_write_setup; +	u8 nwe_setup; + +	/* Pulse register */ +	u8 ncs_read_pulse; +	u8 nrd_pulse; +	u8 ncs_write_pulse; +	u8 nwe_pulse; + +	/* Cycle register */ +	u16 read_cycle; +	u16 write_cycle; + +	/* Mode register */ +	u32 mode; +	u8 tdf_cycles:4; +}; + +extern void sam9_smc_configure(int id, int cs, struct sam9_smc_config *config); +extern void sam9_smc_read(int id, int cs, struct sam9_smc_config *config); +extern void sam9_smc_read_mode(int id, int cs, struct sam9_smc_config *config); +extern void sam9_smc_write_mode(int id, int cs, struct sam9_smc_config *config); +#endif + +#define AT91_SMC_SETUP		0x00				/* Setup Register for CS n */  #define		AT91_SMC_NWESETUP	(0x3f << 0)			/* NWE Setup Length */  #define			AT91_SMC_NWESETUP_(x)	((x) << 0)  #define		AT91_SMC_NCS_WRSETUP	(0x3f << 8)			/* NCS Setup Length in Write Access */ @@ -26,7 +57,7 @@  #define		AT91_SMC_NCS_RDSETUP	(0x3f << 24)			/* NCS Setup Length in Read Access */  #define			AT91_SMC_NCS_RDSETUP_(x)	((x) << 24) -#define AT91_SMC_PULSE(n)	(AT91_SMC + 0x04 + ((n)*0x10))	/* Pulse Register for CS n */ +#define AT91_SMC_PULSE		0x04				/* Pulse Register for CS n */  #define		AT91_SMC_NWEPULSE	(0x7f <<  0)			/* NWE Pulse Length */  #define			AT91_SMC_NWEPULSE_(x)	((x) << 0)  #define		AT91_SMC_NCS_WRPULSE	(0x7f <<  8)			/* NCS Pulse Length in Write Access */ @@ -36,13 +67,13 @@  #define		AT91_SMC_NCS_RDPULSE	(0x7f << 24)			/* NCS Pulse Length in Read Access */  #define			AT91_SMC_NCS_RDPULSE_(x)((x) << 24) -#define AT91_SMC_CYCLE(n)	(AT91_SMC + 0x08 + ((n)*0x10))	/* Cycle Register for CS n */ +#define AT91_SMC_CYCLE		0x08				/* Cycle Register for CS n */  #define		AT91_SMC_NWECYCLE	(0x1ff << 0 )			/* Total Write Cycle Length */  #define			AT91_SMC_NWECYCLE_(x)	((x) << 0)  #define		AT91_SMC_NRDCYCLE	(0x1ff << 16)			/* Total Read Cycle Length */  #define			AT91_SMC_NRDCYCLE_(x)	((x) << 16) -#define AT91_SMC_MODE(n)	(AT91_SMC + 0x0c + ((n)*0x10))	/* Mode Register for CS n */ +#define AT91_SMC_MODE		0x0c				/* Mode Register for CS n */  #define		AT91_SMC_READMODE	(1 <<  0)			/* Read Mode */  #define		AT91_SMC_WRITEMODE	(1 <<  1)			/* Write Mode */  #define		AT91_SMC_EXNWMODE	(3 <<  4)			/* NWAIT Mode */ @@ -66,11 +97,4 @@  #define			AT91_SMC_PS_16			(2 << 28)  #define			AT91_SMC_PS_32			(3 << 28) -#if defined(AT91_SMC1)		/* The AT91SAM9263 has 2 Static Memory contollers */ -#define AT91_SMC1_SETUP(n)	(AT91_SMC1 + 0x00 + ((n)*0x10))	/* Setup Register for CS n */ -#define AT91_SMC1_PULSE(n)	(AT91_SMC1 + 0x04 + ((n)*0x10))	/* Pulse Register for CS n */ -#define AT91_SMC1_CYCLE(n)	(AT91_SMC1 + 0x08 + ((n)*0x10))	/* Cycle Register for CS n */ -#define AT91_SMC1_MODE(n)	(AT91_SMC1 + 0x0c + ((n)*0x10))	/* Mode Register for CS n */ -#endif -  #endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9g45.h b/arch/arm/mach-at91/include/mach/at91sam9g45.h index a526869aee3..8eba1021f53 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9g45.h +++ b/arch/arm/mach-at91/include/mach/at91sam9g45.h @@ -18,8 +18,6 @@  /*   * Peripheral identifiers/interrupts.   */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Controller Interrupt */  #define AT91SAM9G45_ID_PIOA	2	/* Parallel I/O Controller A */  #define AT91SAM9G45_ID_PIOB	3	/* Parallel I/O Controller B */  #define AT91SAM9G45_ID_PIOC	4	/* Parallel I/O Controller C */ @@ -84,37 +82,29 @@  #define AT91SAM9G45_BASE_TC3		0xfffd4000  #define AT91SAM9G45_BASE_TC4		0xfffd4040  #define AT91SAM9G45_BASE_TC5		0xfffd4080 -#define AT91_BASE_SYS			0xffffe200  /* - * System Peripherals (offset from AT91_BASE_SYS) + * System Peripherals   */ -#define AT91_ECC	(0xffffe200 - AT91_BASE_SYS) -#define AT91_DDRSDRC1	(0xffffe400 - AT91_BASE_SYS) -#define AT91_DDRSDRC0	(0xffffe600 - AT91_BASE_SYS) -#define AT91_SMC	(0xffffe800 - AT91_BASE_SYS) -#define AT91_MATRIX	(0xffffea00 - AT91_BASE_SYS) -#define AT91_DMA	(0xffffec00 - AT91_BASE_SYS) -#define AT91_DBGU	(0xffffee00 - AT91_BASE_SYS) -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS) -#define AT91_PIOA	(0xfffff200 - AT91_BASE_SYS) -#define AT91_PIOB	(0xfffff400 - AT91_BASE_SYS) -#define AT91_PIOC	(0xfffff600 - AT91_BASE_SYS) -#define AT91_PIOD	(0xfffff800 - AT91_BASE_SYS) -#define AT91_PIOE	(0xfffffa00 - AT91_BASE_SYS) -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS) -#define AT91_RSTC	(0xfffffd00 - AT91_BASE_SYS) -#define AT91_SHDWC	(0xfffffd10 - AT91_BASE_SYS) -#define AT91_RTT	(0xfffffd20 - AT91_BASE_SYS) -#define AT91_PIT	(0xfffffd30 - AT91_BASE_SYS) -#define AT91_WDT	(0xfffffd40 - AT91_BASE_SYS) -#define AT91_GPBR	(0xfffffd60 - AT91_BASE_SYS) -#define AT91_RTC	(0xfffffdb0 - AT91_BASE_SYS) - -#define AT91_USART0	AT91SAM9G45_BASE_US0 -#define AT91_USART1	AT91SAM9G45_BASE_US1 -#define AT91_USART2	AT91SAM9G45_BASE_US2 -#define AT91_USART3	AT91SAM9G45_BASE_US3 +#define AT91SAM9G45_BASE_ECC	0xffffe200 +#define AT91SAM9G45_BASE_DDRSDRC1 0xffffe400 +#define AT91SAM9G45_BASE_DDRSDRC0 0xffffe600 +#define AT91SAM9G45_BASE_DMA	0xffffec00 +#define AT91SAM9G45_BASE_SMC	0xffffe800 +#define AT91SAM9G45_BASE_MATRIX	0xffffea00 +#define AT91SAM9G45_BASE_DBGU	AT91_BASE_DBGU1 +#define AT91SAM9G45_BASE_PIOA	0xfffff200 +#define AT91SAM9G45_BASE_PIOB	0xfffff400 +#define AT91SAM9G45_BASE_PIOC	0xfffff600 +#define AT91SAM9G45_BASE_PIOD	0xfffff800 +#define AT91SAM9G45_BASE_PIOE	0xfffffa00 +#define AT91SAM9G45_BASE_RSTC	0xfffffd00 +#define AT91SAM9G45_BASE_SHDWC	0xfffffd10 +#define AT91SAM9G45_BASE_RTT	0xfffffd20 +#define AT91SAM9G45_BASE_PIT	0xfffffd30 +#define AT91SAM9G45_BASE_WDT	0xfffffd40 +#define AT91SAM9G45_BASE_RTC	0xfffffdb0 +#define AT91SAM9G45_BASE_GPBR	0xfffffd60  /*   * Internal Memory. @@ -131,10 +121,6 @@  #define AT91SAM9G45_EHCI_BASE	0x00800000	/* USB Host controller (EHCI) */  #define AT91SAM9G45_VDEC_BASE	0x00900000	/* Video Decoder Controller */ -#define CONFIG_DRAM_BASE	AT91_CHIPSELECT_6 - -#define CONSISTENT_DMA_SIZE	SZ_4M -  /*   * DMA peripheral identifiers   * for hardware handshaking interface @@ -150,6 +136,8 @@  #define AT_DMA_ID_SSC1_RX	 8  #define AT_DMA_ID_AC97_TX	 9  #define AT_DMA_ID_AC97_RX	10 +#define AT_DMA_ID_AES_TX	11 +#define AT_DMA_ID_AES_RX	12  #define AT_DMA_ID_MCI1		13  #endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9g45_matrix.h b/arch/arm/mach-at91/include/mach/at91sam9g45_matrix.h index c972d60e0ae..b76e2ed2fbc 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9g45_matrix.h +++ b/arch/arm/mach-at91/include/mach/at91sam9g45_matrix.h @@ -15,18 +15,18 @@  #ifndef AT91SAM9G45_MATRIX_H  #define AT91SAM9G45_MATRIX_H -#define AT91_MATRIX_MCFG0	(AT91_MATRIX + 0x00)	/* Master Configuration Register 0 */ -#define AT91_MATRIX_MCFG1	(AT91_MATRIX + 0x04)	/* Master Configuration Register 1 */ -#define AT91_MATRIX_MCFG2	(AT91_MATRIX + 0x08)	/* Master Configuration Register 2 */ -#define AT91_MATRIX_MCFG3	(AT91_MATRIX + 0x0C)	/* Master Configuration Register 3 */ -#define AT91_MATRIX_MCFG4	(AT91_MATRIX + 0x10)	/* Master Configuration Register 4 */ -#define AT91_MATRIX_MCFG5	(AT91_MATRIX + 0x14)	/* Master Configuration Register 5 */ -#define AT91_MATRIX_MCFG6	(AT91_MATRIX + 0x18)	/* Master Configuration Register 6 */ -#define AT91_MATRIX_MCFG7	(AT91_MATRIX + 0x1C)	/* Master Configuration Register 7 */ -#define AT91_MATRIX_MCFG8	(AT91_MATRIX + 0x20)	/* Master Configuration Register 8 */ -#define AT91_MATRIX_MCFG9	(AT91_MATRIX + 0x24)	/* Master Configuration Register 9 */ -#define AT91_MATRIX_MCFG10	(AT91_MATRIX + 0x28)	/* Master Configuration Register 10 */ -#define AT91_MATRIX_MCFG11	(AT91_MATRIX + 0x2C)	/* Master Configuration Register 11 */ +#define AT91_MATRIX_MCFG0	0x00			/* Master Configuration Register 0 */ +#define AT91_MATRIX_MCFG1	0x04			/* Master Configuration Register 1 */ +#define AT91_MATRIX_MCFG2	0x08			/* Master Configuration Register 2 */ +#define AT91_MATRIX_MCFG3	0x0C			/* Master Configuration Register 3 */ +#define AT91_MATRIX_MCFG4	0x10			/* Master Configuration Register 4 */ +#define AT91_MATRIX_MCFG5	0x14			/* Master Configuration Register 5 */ +#define AT91_MATRIX_MCFG6	0x18			/* Master Configuration Register 6 */ +#define AT91_MATRIX_MCFG7	0x1C			/* Master Configuration Register 7 */ +#define AT91_MATRIX_MCFG8	0x20			/* Master Configuration Register 8 */ +#define AT91_MATRIX_MCFG9	0x24			/* Master Configuration Register 9 */ +#define AT91_MATRIX_MCFG10	0x28			/* Master Configuration Register 10 */ +#define AT91_MATRIX_MCFG11	0x2C			/* Master Configuration Register 11 */  #define		AT91_MATRIX_ULBT	(7 << 0)	/* Undefined Length Burst Type */  #define			AT91_MATRIX_ULBT_INFINITE	(0 << 0)  #define			AT91_MATRIX_ULBT_SINGLE		(1 << 0) @@ -37,14 +37,14 @@  #define			AT91_MATRIX_ULBT_SIXTYFOUR	(6 << 0)  #define			AT91_MATRIX_ULBT_128		(7 << 0) -#define AT91_MATRIX_SCFG0	(AT91_MATRIX + 0x40)	/* Slave Configuration Register 0 */ -#define AT91_MATRIX_SCFG1	(AT91_MATRIX + 0x44)	/* Slave Configuration Register 1 */ -#define AT91_MATRIX_SCFG2	(AT91_MATRIX + 0x48)	/* Slave Configuration Register 2 */ -#define AT91_MATRIX_SCFG3	(AT91_MATRIX + 0x4C)	/* Slave Configuration Register 3 */ -#define AT91_MATRIX_SCFG4	(AT91_MATRIX + 0x50)	/* Slave Configuration Register 4 */ -#define AT91_MATRIX_SCFG5	(AT91_MATRIX + 0x54)	/* Slave Configuration Register 5 */ -#define AT91_MATRIX_SCFG6	(AT91_MATRIX + 0x58)	/* Slave Configuration Register 6 */ -#define AT91_MATRIX_SCFG7	(AT91_MATRIX + 0x5C)	/* Slave Configuration Register 7 */ +#define AT91_MATRIX_SCFG0	0x40			/* Slave Configuration Register 0 */ +#define AT91_MATRIX_SCFG1	0x44			/* Slave Configuration Register 1 */ +#define AT91_MATRIX_SCFG2	0x48			/* Slave Configuration Register 2 */ +#define AT91_MATRIX_SCFG3	0x4C			/* Slave Configuration Register 3 */ +#define AT91_MATRIX_SCFG4	0x50			/* Slave Configuration Register 4 */ +#define AT91_MATRIX_SCFG5	0x54			/* Slave Configuration Register 5 */ +#define AT91_MATRIX_SCFG6	0x58			/* Slave Configuration Register 6 */ +#define AT91_MATRIX_SCFG7	0x5C			/* Slave Configuration Register 7 */  #define		AT91_MATRIX_SLOT_CYCLE		(0x1ff << 0)	/* Maximum Number of Allowed Cycles for a Burst */  #define		AT91_MATRIX_DEFMSTR_TYPE	(3    << 16)	/* Default Master Type */  #define			AT91_MATRIX_DEFMSTR_TYPE_NONE	(0 << 16) @@ -52,22 +52,22 @@  #define			AT91_MATRIX_DEFMSTR_TYPE_FIXED	(2 << 16)  #define		AT91_MATRIX_FIXED_DEFMSTR	(0xf  << 18)	/* Fixed Index of Default Master */ -#define AT91_MATRIX_PRAS0	(AT91_MATRIX + 0x80)	/* Priority Register A for Slave 0 */ -#define AT91_MATRIX_PRBS0	(AT91_MATRIX + 0x84)	/* Priority Register B for Slave 0 */ -#define AT91_MATRIX_PRAS1	(AT91_MATRIX + 0x88)	/* Priority Register A for Slave 1 */ -#define AT91_MATRIX_PRBS1	(AT91_MATRIX + 0x8C)	/* Priority Register B for Slave 1 */ -#define AT91_MATRIX_PRAS2	(AT91_MATRIX + 0x90)	/* Priority Register A for Slave 2 */ -#define AT91_MATRIX_PRBS2	(AT91_MATRIX + 0x94)	/* Priority Register B for Slave 2 */ -#define AT91_MATRIX_PRAS3	(AT91_MATRIX + 0x98)	/* Priority Register A for Slave 3 */ -#define AT91_MATRIX_PRBS3	(AT91_MATRIX + 0x9C)	/* Priority Register B for Slave 3 */ -#define AT91_MATRIX_PRAS4	(AT91_MATRIX + 0xA0)	/* Priority Register A for Slave 4 */ -#define AT91_MATRIX_PRBS4	(AT91_MATRIX + 0xA4)	/* Priority Register B for Slave 4 */ -#define AT91_MATRIX_PRAS5	(AT91_MATRIX + 0xA8)	/* Priority Register A for Slave 5 */ -#define AT91_MATRIX_PRBS5	(AT91_MATRIX + 0xAC)	/* Priority Register B for Slave 5 */ -#define AT91_MATRIX_PRAS6	(AT91_MATRIX + 0xB0)	/* Priority Register A for Slave 6 */ -#define AT91_MATRIX_PRBS6	(AT91_MATRIX + 0xB4)	/* Priority Register B for Slave 6 */ -#define AT91_MATRIX_PRAS7	(AT91_MATRIX + 0xB8)	/* Priority Register A for Slave 7 */ -#define AT91_MATRIX_PRBS7	(AT91_MATRIX + 0xBC)	/* Priority Register B for Slave 7 */ +#define AT91_MATRIX_PRAS0	0x80			/* Priority Register A for Slave 0 */ +#define AT91_MATRIX_PRBS0	0x84			/* Priority Register B for Slave 0 */ +#define AT91_MATRIX_PRAS1	0x88			/* Priority Register A for Slave 1 */ +#define AT91_MATRIX_PRBS1	0x8C			/* Priority Register B for Slave 1 */ +#define AT91_MATRIX_PRAS2	0x90			/* Priority Register A for Slave 2 */ +#define AT91_MATRIX_PRBS2	0x94			/* Priority Register B for Slave 2 */ +#define AT91_MATRIX_PRAS3	0x98			/* Priority Register A for Slave 3 */ +#define AT91_MATRIX_PRBS3	0x9C			/* Priority Register B for Slave 3 */ +#define AT91_MATRIX_PRAS4	0xA0			/* Priority Register A for Slave 4 */ +#define AT91_MATRIX_PRBS4	0xA4			/* Priority Register B for Slave 4 */ +#define AT91_MATRIX_PRAS5	0xA8			/* Priority Register A for Slave 5 */ +#define AT91_MATRIX_PRBS5	0xAC			/* Priority Register B for Slave 5 */ +#define AT91_MATRIX_PRAS6	0xB0			/* Priority Register A for Slave 6 */ +#define AT91_MATRIX_PRBS6	0xB4			/* Priority Register B for Slave 6 */ +#define AT91_MATRIX_PRAS7	0xB8			/* Priority Register A for Slave 7 */ +#define AT91_MATRIX_PRBS7	0xBC			/* Priority Register B for Slave 7 */  #define		AT91_MATRIX_M0PR		(3 << 0)	/* Master 0 Priority */  #define		AT91_MATRIX_M1PR		(3 << 4)	/* Master 1 Priority */  #define		AT91_MATRIX_M2PR		(3 << 8)	/* Master 2 Priority */ @@ -81,7 +81,7 @@  #define		AT91_MATRIX_M10PR		(3 << 8)	/* Master 10 Priority (in Register B) */  #define		AT91_MATRIX_M11PR		(3 << 12)	/* Master 11 Priority (in Register B) */ -#define AT91_MATRIX_MRCR	(AT91_MATRIX + 0x100)	/* Master Remap Control Register */ +#define AT91_MATRIX_MRCR	0x100			/* Master Remap Control Register */  #define		AT91_MATRIX_RCB0		(1 << 0)	/* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */  #define		AT91_MATRIX_RCB1		(1 << 1)	/* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */  #define		AT91_MATRIX_RCB2		(1 << 2) @@ -95,7 +95,7 @@  #define		AT91_MATRIX_RCB10		(1 << 10)  #define		AT91_MATRIX_RCB11		(1 << 11) -#define AT91_MATRIX_TCMR	(AT91_MATRIX + 0x110)	/* TCM Configuration Register */ +#define AT91_MATRIX_TCMR	0x110			/* TCM Configuration Register */  #define		AT91_MATRIX_ITCM_SIZE		(0xf << 0)	/* Size of ITCM enabled memory block */  #define			AT91_MATRIX_ITCM_0		(0 << 0)  #define			AT91_MATRIX_ITCM_32		(6 << 0) @@ -107,12 +107,12 @@  #define			AT91_MATRIX_TCM_NO_WS		(0x0 << 11)  #define			AT91_MATRIX_TCM_ONE_WS		(0x1 << 11) -#define AT91_MATRIX_VIDEO	(AT91_MATRIX + 0x118)	/* Video Mode Configuration Register */ +#define AT91_MATRIX_VIDEO	0x118			/* Video Mode Configuration Register */  #define		AT91C_VDEC_SEL			(0x1 <<  0) /* Video Mode Selection */  #define			AT91C_VDEC_SEL_OFF		(0 << 0)  #define			AT91C_VDEC_SEL_ON		(1 << 0) -#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x128)	/* EBI Chip Select Assignment Register */ +#define AT91_MATRIX_EBICSA	0x128			/* EBI Chip Select Assignment Register */  #define		AT91_MATRIX_EBI_CS1A		(1 << 1)	/* Chip Select 1 Assignment */  #define			AT91_MATRIX_EBI_CS1A_SMC		(0 << 1)  #define			AT91_MATRIX_EBI_CS1A_SDRAMC		(1 << 1) @@ -138,13 +138,13 @@  #define			AT91_MATRIX_EBI_DDR_IOSR_REDUCED	(0 << 18)  #define			AT91_MATRIX_EBI_DDR_IOSR_NORMAL		(1 << 18) -#define AT91_MATRIX_WPMR	(AT91_MATRIX + 0x1E4)	/* Write Protect Mode Register */ +#define AT91_MATRIX_WPMR	0x1E4			/* Write Protect Mode Register */  #define		AT91_MATRIX_WPMR_WPEN		(1 << 0)	/* Write Protect ENable */  #define			AT91_MATRIX_WPMR_WP_WPDIS		(0 << 0)  #define			AT91_MATRIX_WPMR_WP_WPEN		(1 << 0)  #define		AT91_MATRIX_WPMR_WPKEY		(0xFFFFFF << 8)	/* Write Protect KEY */ -#define AT91_MATRIX_WPSR	(AT91_MATRIX + 0x1E8)	/* Write Protect Status Register */ +#define AT91_MATRIX_WPSR	0x1E8			/* Write Protect Status Register */  #define		AT91_MATRIX_WPSR_WPVS		(1 << 0)	/* Write Protect Violation Status */  #define			AT91_MATRIX_WPSR_NO_WPV		(0 << 0)  #define			AT91_MATRIX_WPSR_WPV		(1 << 0) diff --git a/arch/arm/mach-at91/include/mach/at91sam9n12.h b/arch/arm/mach-at91/include/mach/at91sam9n12.h new file mode 100644 index 00000000000..0151bcf6163 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91sam9n12.h @@ -0,0 +1,65 @@ +/* + * SoC specific header file for the AT91SAM9N12 + * + * Copyright (C) 2012 Atmel Corporation + * + * Common definitions, based on AT91SAM9N12 SoC datasheet + * + * Licensed under GPLv2 or later + */ + +#ifndef _AT91SAM9N12_H_ +#define _AT91SAM9N12_H_ + +/* + * Peripheral identifiers/interrupts. + */ +#define AT91SAM9N12_ID_PIOAB	2	/* Parallel I/O Controller A and B */ +#define AT91SAM9N12_ID_PIOCD	3	/* Parallel I/O Controller C and D */ +#define AT91SAM9N12_ID_FUSE	4	/* FUSE Controller */ +#define AT91SAM9N12_ID_USART0	5	/* USART 0 */ +#define AT91SAM9N12_ID_USART1	6	/* USART 1 */ +#define AT91SAM9N12_ID_USART2	7	/* USART 2 */ +#define AT91SAM9N12_ID_USART3	8	/* USART 3 */ +#define AT91SAM9N12_ID_TWI0	9	/* Two-Wire Interface 0 */ +#define AT91SAM9N12_ID_TWI1	10	/* Two-Wire Interface 1 */ +#define AT91SAM9N12_ID_MCI	12	/* High Speed Multimedia Card Interface */ +#define AT91SAM9N12_ID_SPI0	13	/* Serial Peripheral Interface 0 */ +#define AT91SAM9N12_ID_SPI1	14	/* Serial Peripheral Interface 1 */ +#define AT91SAM9N12_ID_UART0	15	/* UART 0 */ +#define AT91SAM9N12_ID_UART1	16	/* UART 1 */ +#define AT91SAM9N12_ID_TCB	17	/* Timer Counter 0, 1, 2, 3, 4 and 5 */ +#define AT91SAM9N12_ID_PWM	18	/* Pulse Width Modulation Controller */ +#define AT91SAM9N12_ID_ADC	19	/* ADC Controller */ +#define AT91SAM9N12_ID_DMA	20	/* DMA Controller */ +#define AT91SAM9N12_ID_UHP	22	/* USB Host High Speed */ +#define AT91SAM9N12_ID_UDP	23	/* USB Device High Speed */ +#define AT91SAM9N12_ID_LCDC	25	/* LCD Controller */ +#define AT91SAM9N12_ID_ISI	25	/* Image Sensor Interface */ +#define AT91SAM9N12_ID_SSC	28	/* Synchronous Serial Controller */ +#define AT91SAM9N12_ID_TRNG	30	/* TRNG */ +#define AT91SAM9N12_ID_IRQ0	31	/* Advanced Interrupt Controller */ + +/* + * User Peripheral physical base addresses. + */ +#define AT91SAM9N12_BASE_USART0	0xf801c000 +#define AT91SAM9N12_BASE_USART1	0xf8020000 +#define AT91SAM9N12_BASE_USART2	0xf8024000 +#define AT91SAM9N12_BASE_USART3	0xf8028000 + +/* + * System Peripherals + */ +#define AT91SAM9N12_BASE_RTC	0xfffffeb0 + +/* + * Internal Memory. + */ +#define AT91SAM9N12_SRAM_BASE	0x00300000	/* Internal SRAM base address */ +#define AT91SAM9N12_SRAM_SIZE	SZ_32K		/* Internal SRAM size (32Kb) */ + +#define AT91SAM9N12_ROM_BASE	0x00100000	/* Internal ROM base address */ +#define AT91SAM9N12_ROM_SIZE	SZ_128K		/* Internal ROM size (128Kb) */ + +#endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9n12_matrix.h b/arch/arm/mach-at91/include/mach/at91sam9n12_matrix.h new file mode 100644 index 00000000000..40060cd62fa --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91sam9n12_matrix.h @@ -0,0 +1,53 @@ +/* + * Matrix-centric header file for the AT91SAM9N12 + * + * Copyright (C) 2012 Atmel Corporation. + * + * Only EBI related registers. + * Write Protect register definitions may be useful. + * + * Licensed under GPLv2 or later. + */ + +#ifndef _AT91SAM9N12_MATRIX_H_ +#define _AT91SAM9N12_MATRIX_H_ + +#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x118)	/* EBI Chip Select Assignment Register */ +#define		AT91_MATRIX_EBI_CS1A		(1 << 1)	/* Chip Select 1 Assignment */ +#define			AT91_MATRIX_EBI_CS1A_SMC		(0 << 1) +#define			AT91_MATRIX_EBI_CS1A_SDRAMC		(1 << 1) +#define		AT91_MATRIX_EBI_CS3A		(1 << 3)	/* Chip Select 3 Assignment */ +#define			AT91_MATRIX_EBI_CS3A_SMC		(0 << 3) +#define			AT91_MATRIX_EBI_CS3A_SMC_NANDFLASH	(1 << 3) +#define		AT91_MATRIX_EBI_DBPUC		(1 << 8)	/* Data Bus Pull-up Configuration */ +#define			AT91_MATRIX_EBI_DBPU_ON			(0 << 8) +#define			AT91_MATRIX_EBI_DBPU_OFF		(1 << 8) +#define		AT91_MATRIX_EBI_VDDIOMSEL	(1 << 16)	/* Memory voltage selection */ +#define			AT91_MATRIX_EBI_VDDIOMSEL_1_8V		(0 << 16) +#define			AT91_MATRIX_EBI_VDDIOMSEL_3_3V		(1 << 16) +#define		AT91_MATRIX_EBI_EBI_IOSR	(1 << 17)	/* EBI I/O slew rate selection */ +#define			AT91_MATRIX_EBI_EBI_IOSR_REDUCED	(0 << 17) +#define			AT91_MATRIX_EBI_EBI_IOSR_NORMAL		(1 << 17) +#define		AT91_MATRIX_EBI_DDR_IOSR	(1 << 18)	/* DDR2 dedicated port I/O slew rate selection */ +#define			AT91_MATRIX_EBI_DDR_IOSR_REDUCED	(0 << 18) +#define			AT91_MATRIX_EBI_DDR_IOSR_NORMAL		(1 << 18) +#define		AT91_MATRIX_NFD0_SELECT		(1 << 24)	/* NAND Flash Data Bus Selection */ +#define			AT91_MATRIX_NFD0_ON_D0			(0 << 24) +#define			AT91_MATRIX_NFD0_ON_D16			(1 << 24) +#define		AT91_MATRIX_DDR_MP_EN		(1 << 25)	/* DDR Multi-port Enable */ +#define			AT91_MATRIX_MP_OFF			(0 << 25) +#define			AT91_MATRIX_MP_ON			(1 << 25) + +#define AT91_MATRIX_WPMR	(AT91_MATRIX + 0x1E4)	/* Write Protect Mode Register */ +#define		AT91_MATRIX_WPMR_WPEN		(1 << 0)	/* Write Protect ENable */ +#define			AT91_MATRIX_WPMR_WP_WPDIS		(0 << 0) +#define			AT91_MATRIX_WPMR_WP_WPEN		(1 << 0) +#define		AT91_MATRIX_WPMR_WPKEY		(0xFFFFFF << 8)	/* Write Protect KEY */ + +#define AT91_MATRIX_WPSR	(AT91_MATRIX + 0x1E8)	/* Write Protect Status Register */ +#define		AT91_MATRIX_WPSR_WPVS		(1 << 0)	/* Write Protect Violation Status */ +#define			AT91_MATRIX_WPSR_NO_WPV		(0 << 0) +#define			AT91_MATRIX_WPSR_WPV		(1 << 0) +#define		AT91_MATRIX_WPSR_WPVSRC		(0xFFFF << 8)	/* Write Protect Violation Source */ + +#endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9rl.h b/arch/arm/mach-at91/include/mach/at91sam9rl.h index 87ba8517ad9..a15db56d33f 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9rl.h +++ b/arch/arm/mach-at91/include/mach/at91sam9rl.h @@ -17,8 +17,6 @@  /*   * Peripheral identifiers/interrupts.   */ -#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ -#define AT91_ID_SYS		1	/* System Controller */  #define AT91SAM9RL_ID_PIOA	2	/* Parallel IO Controller A */  #define AT91SAM9RL_ID_PIOB	3	/* Parallel IO Controller B */  #define AT91SAM9RL_ID_PIOC	4	/* Parallel IO Controller C */ @@ -66,38 +64,30 @@  #define AT91SAM9RL_BASE_TSC	0xfffd0000  #define AT91SAM9RL_BASE_UDPHS	0xfffd4000  #define AT91SAM9RL_BASE_AC97C	0xfffd8000 -#define AT91_BASE_SYS		0xffffc000  /*   * System Peripherals (offset from AT91_BASE_SYS)   */ -#define AT91_DMA	(0xffffe600 - AT91_BASE_SYS) -#define AT91_ECC	(0xffffe800 - AT91_BASE_SYS) -#define AT91_SDRAMC0	(0xffffea00 - AT91_BASE_SYS) -#define AT91_SMC	(0xffffec00 - AT91_BASE_SYS) -#define AT91_MATRIX	(0xffffee00 - AT91_BASE_SYS) -#define AT91_CCFG	(0xffffef10 - AT91_BASE_SYS) -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS) -#define AT91_DBGU	(0xfffff200 - AT91_BASE_SYS) -#define AT91_PIOA	(0xfffff400 - AT91_BASE_SYS) -#define AT91_PIOB	(0xfffff600 - AT91_BASE_SYS) -#define AT91_PIOC	(0xfffff800 - AT91_BASE_SYS) -#define AT91_PIOD	(0xfffffa00 - AT91_BASE_SYS) -#define AT91_PMC	(0xfffffc00 - AT91_BASE_SYS) -#define AT91_RSTC	(0xfffffd00 - AT91_BASE_SYS) -#define AT91_SHDWC	(0xfffffd10 - AT91_BASE_SYS) -#define AT91_RTT	(0xfffffd20 - AT91_BASE_SYS) -#define AT91_PIT	(0xfffffd30 - AT91_BASE_SYS) -#define AT91_WDT	(0xfffffd40 - AT91_BASE_SYS)  #define AT91_SCKCR	(0xfffffd50 - AT91_BASE_SYS) -#define AT91_GPBR	(0xfffffd60 - AT91_BASE_SYS) -#define AT91_RTC	(0xfffffe00 - AT91_BASE_SYS) -#define AT91_USART0	AT91SAM9RL_BASE_US0 -#define AT91_USART1	AT91SAM9RL_BASE_US1 -#define AT91_USART2	AT91SAM9RL_BASE_US2 -#define AT91_USART3	AT91SAM9RL_BASE_US3 +#define AT91SAM9RL_BASE_DMA	0xffffe600 +#define AT91SAM9RL_BASE_ECC	0xffffe800 +#define AT91SAM9RL_BASE_SDRAMC	0xffffea00 +#define AT91SAM9RL_BASE_SMC	0xffffec00 +#define AT91SAM9RL_BASE_MATRIX	0xffffee00 +#define AT91SAM9RL_BASE_DBGU	AT91_BASE_DBGU0 +#define AT91SAM9RL_BASE_PIOA	0xfffff400 +#define AT91SAM9RL_BASE_PIOB	0xfffff600 +#define AT91SAM9RL_BASE_PIOC	0xfffff800 +#define AT91SAM9RL_BASE_PIOD	0xfffffa00 +#define AT91SAM9RL_BASE_RSTC	0xfffffd00 +#define AT91SAM9RL_BASE_SHDWC	0xfffffd10 +#define AT91SAM9RL_BASE_RTT	0xfffffd20 +#define AT91SAM9RL_BASE_PIT	0xfffffd30 +#define AT91SAM9RL_BASE_WDT	0xfffffd40 +#define AT91SAM9RL_BASE_GPBR	0xfffffd60 +#define AT91SAM9RL_BASE_RTC	0xfffffe00  /* diff --git a/arch/arm/mach-at91/include/mach/at91sam9rl_matrix.h b/arch/arm/mach-at91/include/mach/at91sam9rl_matrix.h index 5f9149071fe..6d160adadaf 100644 --- a/arch/arm/mach-at91/include/mach/at91sam9rl_matrix.h +++ b/arch/arm/mach-at91/include/mach/at91sam9rl_matrix.h @@ -14,12 +14,12 @@  #ifndef AT91SAM9RL_MATRIX_H  #define AT91SAM9RL_MATRIX_H -#define AT91_MATRIX_MCFG0	(AT91_MATRIX + 0x00)	/* Master Configuration Register 0 */ -#define AT91_MATRIX_MCFG1	(AT91_MATRIX + 0x04)	/* Master Configuration Register 1 */ -#define AT91_MATRIX_MCFG2	(AT91_MATRIX + 0x08)	/* Master Configuration Register 2 */ -#define AT91_MATRIX_MCFG3	(AT91_MATRIX + 0x0C)	/* Master Configuration Register 3 */ -#define AT91_MATRIX_MCFG4	(AT91_MATRIX + 0x10)	/* Master Configuration Register 4 */ -#define AT91_MATRIX_MCFG5	(AT91_MATRIX + 0x14)	/* Master Configuration Register 5 */ +#define AT91_MATRIX_MCFG0	0x00			/* Master Configuration Register 0 */ +#define AT91_MATRIX_MCFG1	0x04			/* Master Configuration Register 1 */ +#define AT91_MATRIX_MCFG2	0x08			/* Master Configuration Register 2 */ +#define AT91_MATRIX_MCFG3	0x0C			/* Master Configuration Register 3 */ +#define AT91_MATRIX_MCFG4	0x10			/* Master Configuration Register 4 */ +#define AT91_MATRIX_MCFG5	0x14			/* Master Configuration Register 5 */  #define		AT91_MATRIX_ULBT	(7 << 0)	/* Undefined Length Burst Type */  #define			AT91_MATRIX_ULBT_INFINITE	(0 << 0)  #define			AT91_MATRIX_ULBT_SINGLE		(1 << 0) @@ -27,12 +27,12 @@  #define			AT91_MATRIX_ULBT_EIGHT		(3 << 0)  #define			AT91_MATRIX_ULBT_SIXTEEN	(4 << 0) -#define AT91_MATRIX_SCFG0	(AT91_MATRIX + 0x40)	/* Slave Configuration Register 0 */ -#define AT91_MATRIX_SCFG1	(AT91_MATRIX + 0x44)	/* Slave Configuration Register 1 */ -#define AT91_MATRIX_SCFG2	(AT91_MATRIX + 0x48)	/* Slave Configuration Register 2 */ -#define AT91_MATRIX_SCFG3	(AT91_MATRIX + 0x4C)	/* Slave Configuration Register 3 */ -#define AT91_MATRIX_SCFG4	(AT91_MATRIX + 0x50)	/* Slave Configuration Register 4 */ -#define AT91_MATRIX_SCFG5	(AT91_MATRIX + 0x54)	/* Slave Configuration Register 5 */ +#define AT91_MATRIX_SCFG0	0x40			/* Slave Configuration Register 0 */ +#define AT91_MATRIX_SCFG1	0x44			/* Slave Configuration Register 1 */ +#define AT91_MATRIX_SCFG2	0x48			/* Slave Configuration Register 2 */ +#define AT91_MATRIX_SCFG3	0x4C			/* Slave Configuration Register 3 */ +#define AT91_MATRIX_SCFG4	0x50			/* Slave Configuration Register 4 */ +#define AT91_MATRIX_SCFG5	0x54			/* Slave Configuration Register 5 */  #define		AT91_MATRIX_SLOT_CYCLE		(0xff << 0)	/* Maximum Number of Allowed Cycles for a Burst */  #define		AT91_MATRIX_DEFMSTR_TYPE	(3    << 16)	/* Default Master Type */  #define			AT91_MATRIX_DEFMSTR_TYPE_NONE	(0 << 16) @@ -43,12 +43,12 @@  #define			AT91_MATRIX_ARBT_ROUND_ROBIN	(0 << 24)  #define			AT91_MATRIX_ARBT_FIXED_PRIORITY	(1 << 24) -#define AT91_MATRIX_PRAS0	(AT91_MATRIX + 0x80)	/* Priority Register A for Slave 0 */ -#define AT91_MATRIX_PRAS1	(AT91_MATRIX + 0x88)	/* Priority Register A for Slave 1 */ -#define AT91_MATRIX_PRAS2	(AT91_MATRIX + 0x90)	/* Priority Register A for Slave 2 */ -#define AT91_MATRIX_PRAS3	(AT91_MATRIX + 0x98)	/* Priority Register A for Slave 3 */ -#define AT91_MATRIX_PRAS4	(AT91_MATRIX + 0xA0)	/* Priority Register A for Slave 4 */ -#define AT91_MATRIX_PRAS5	(AT91_MATRIX + 0xA8)	/* Priority Register A for Slave 5 */ +#define AT91_MATRIX_PRAS0	0x80			/* Priority Register A for Slave 0 */ +#define AT91_MATRIX_PRAS1	0x88			/* Priority Register A for Slave 1 */ +#define AT91_MATRIX_PRAS2	0x90			/* Priority Register A for Slave 2 */ +#define AT91_MATRIX_PRAS3	0x98			/* Priority Register A for Slave 3 */ +#define AT91_MATRIX_PRAS4	0xA0			/* Priority Register A for Slave 4 */ +#define AT91_MATRIX_PRAS5	0xA8			/* Priority Register A for Slave 5 */  #define		AT91_MATRIX_M0PR		(3 << 0)	/* Master 0 Priority */  #define		AT91_MATRIX_M1PR		(3 << 4)	/* Master 1 Priority */  #define		AT91_MATRIX_M2PR		(3 << 8)	/* Master 2 Priority */ @@ -56,7 +56,7 @@  #define		AT91_MATRIX_M4PR		(3 << 16)	/* Master 4 Priority */  #define		AT91_MATRIX_M5PR		(3 << 20)	/* Master 5 Priority */ -#define AT91_MATRIX_MRCR	(AT91_MATRIX + 0x100)	/* Master Remap Control Register */ +#define AT91_MATRIX_MRCR	0x100			/* Master Remap Control Register */  #define		AT91_MATRIX_RCB0		(1 << 0)	/* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */  #define		AT91_MATRIX_RCB1		(1 << 1)	/* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */  #define		AT91_MATRIX_RCB2		(1 << 2) @@ -64,7 +64,7 @@  #define		AT91_MATRIX_RCB4		(1 << 4)  #define		AT91_MATRIX_RCB5		(1 << 5) -#define AT91_MATRIX_TCMR	(AT91_MATRIX + 0x114)	/* TCM Configuration Register */ +#define AT91_MATRIX_TCMR	0x114			/* TCM Configuration Register */  #define		AT91_MATRIX_ITCM_SIZE		(0xf << 0)	/* Size of ITCM enabled memory block */  #define			AT91_MATRIX_ITCM_0		(0 << 0)  #define			AT91_MATRIX_ITCM_16		(5 << 0) @@ -74,7 +74,7 @@  #define			AT91_MATRIX_DTCM_16		(5 << 4)  #define			AT91_MATRIX_DTCM_32		(6 << 4) -#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x120)	/* EBI0 Chip Select Assignment Register */ +#define AT91_MATRIX_EBICSA	0x120			/* EBI0 Chip Select Assignment Register */  #define		AT91_MATRIX_CS1A		(1 << 1)	/* Chip Select 1 Assignment */  #define			AT91_MATRIX_CS1A_SMC		(0 << 1)  #define			AT91_MATRIX_CS1A_SDRAMC		(1 << 1) diff --git a/arch/arm/mach-at91/include/mach/at91sam9x5.h b/arch/arm/mach-at91/include/mach/at91sam9x5.h new file mode 100644 index 00000000000..2fc76c49e97 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91sam9x5.h @@ -0,0 +1,71 @@ +/* + * Chip-specific header file for the AT91SAM9x5 family + * + *  Copyright (C) 2009-2012 Atmel Corporation. + * + * Common definitions. + * Based on AT91SAM9x5 datasheet. + * + * Licensed under GPLv2 or later. + */ + +#ifndef AT91SAM9X5_H +#define AT91SAM9X5_H + +/* + * Peripheral identifiers/interrupts. + */ +#define AT91SAM9X5_ID_PIOAB	2	/* Parallel I/O Controller A and B */ +#define AT91SAM9X5_ID_PIOCD	3	/* Parallel I/O Controller C and D */ +#define AT91SAM9X5_ID_SMD	4	/* SMD Soft Modem (SMD) */ +#define AT91SAM9X5_ID_USART0	5	/* USART 0 */ +#define AT91SAM9X5_ID_USART1	6	/* USART 1 */ +#define AT91SAM9X5_ID_USART2	7	/* USART 2 */ +#define AT91SAM9X5_ID_USART3	8	/* USART 3 */ +#define AT91SAM9X5_ID_TWI0	9	/* Two-Wire Interface 0 */ +#define AT91SAM9X5_ID_TWI1	10	/* Two-Wire Interface 1 */ +#define AT91SAM9X5_ID_TWI2	11	/* Two-Wire Interface 2 */ +#define AT91SAM9X5_ID_MCI0	12	/* High Speed Multimedia Card Interface 0 */ +#define AT91SAM9X5_ID_SPI0	13	/* Serial Peripheral Interface 0 */ +#define AT91SAM9X5_ID_SPI1	14	/* Serial Peripheral Interface 1 */ +#define AT91SAM9X5_ID_UART0	15	/* UART 0 */ +#define AT91SAM9X5_ID_UART1	16	/* UART 1 */ +#define AT91SAM9X5_ID_TCB	17	/* Timer Counter 0, 1, 2, 3, 4 and 5 */ +#define AT91SAM9X5_ID_PWM	18	/* Pulse Width Modulation Controller */ +#define AT91SAM9X5_ID_ADC	19	/* ADC Controller */ +#define AT91SAM9X5_ID_DMA0	20	/* DMA Controller 0 */ +#define AT91SAM9X5_ID_DMA1	21	/* DMA Controller 1 */ +#define AT91SAM9X5_ID_UHPHS	22	/* USB Host High Speed */ +#define AT91SAM9X5_ID_UDPHS	23	/* USB Device High Speed */ +#define AT91SAM9X5_ID_EMAC0	24	/* Ethernet MAC0 */ +#define AT91SAM9X5_ID_LCDC	25	/* LCD Controller */ +#define AT91SAM9X5_ID_ISI	25	/* Image Sensor Interface */ +#define AT91SAM9X5_ID_MCI1	26	/* High Speed Multimedia Card Interface 1 */ +#define AT91SAM9X5_ID_EMAC1	27	/* Ethernet MAC1 */ +#define AT91SAM9X5_ID_SSC	28	/* Synchronous Serial Controller */ +#define AT91SAM9X5_ID_CAN0	29	/* CAN Controller 0 */ +#define AT91SAM9X5_ID_CAN1	30	/* CAN Controller 1 */ +#define AT91SAM9X5_ID_IRQ0	31	/* Advanced Interrupt Controller */ + +/* + * User Peripheral physical base addresses. + */ +#define AT91SAM9X5_BASE_USART0	0xf801c000 +#define AT91SAM9X5_BASE_USART1	0xf8020000 +#define AT91SAM9X5_BASE_USART2	0xf8024000 + +/* + * System Peripherals + */ +#define AT91SAM9X5_BASE_RTC	0xfffffeb0 + +/* + * Internal Memory. + */ +#define AT91SAM9X5_SRAM_BASE	0x00300000	/* Internal SRAM base address */ +#define AT91SAM9X5_SRAM_SIZE	SZ_32K		/* Internal SRAM size (32Kb) */ + +#define AT91SAM9X5_ROM_BASE	0x00400000	/* Internal ROM base address */ +#define AT91SAM9X5_ROM_SIZE	SZ_64K		/* Internal ROM size (64Kb) */ + +#endif diff --git a/arch/arm/mach-at91/include/mach/at91sam9x5_matrix.h b/arch/arm/mach-at91/include/mach/at91sam9x5_matrix.h new file mode 100644 index 00000000000..a606d396647 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/at91sam9x5_matrix.h @@ -0,0 +1,53 @@ +/* + * Matrix-centric header file for the AT91SAM9x5 family + * + *  Copyright (C) 2009-2012 Atmel Corporation. + * + * Only EBI related registers. + * Write Protect register definitions may be useful. + * + * Licensed under GPLv2 or later. + */ + +#ifndef AT91SAM9X5_MATRIX_H +#define AT91SAM9X5_MATRIX_H + +#define AT91_MATRIX_EBICSA	(AT91_MATRIX + 0x120)	/* EBI Chip Select Assignment Register */ +#define		AT91_MATRIX_EBI_CS1A		(1 << 1)	/* Chip Select 1 Assignment */ +#define			AT91_MATRIX_EBI_CS1A_SMC		(0 << 1) +#define			AT91_MATRIX_EBI_CS1A_SDRAMC		(1 << 1) +#define		AT91_MATRIX_EBI_CS3A		(1 << 3)	/* Chip Select 3 Assignment */ +#define			AT91_MATRIX_EBI_CS3A_SMC		(0 << 3) +#define			AT91_MATRIX_EBI_CS3A_SMC_NANDFLASH	(1 << 3) +#define		AT91_MATRIX_EBI_DBPUC		(1 << 8)	/* Data Bus Pull-up Configuration */ +#define			AT91_MATRIX_EBI_DBPU_ON			(0 << 8) +#define			AT91_MATRIX_EBI_DBPU_OFF		(1 << 8) +#define		AT91_MATRIX_EBI_VDDIOMSEL	(1 << 16)	/* Memory voltage selection */ +#define			AT91_MATRIX_EBI_VDDIOMSEL_1_8V		(0 << 16) +#define			AT91_MATRIX_EBI_VDDIOMSEL_3_3V		(1 << 16) +#define		AT91_MATRIX_EBI_EBI_IOSR	(1 << 17)	/* EBI I/O slew rate selection */ +#define			AT91_MATRIX_EBI_EBI_IOSR_REDUCED	(0 << 17) +#define			AT91_MATRIX_EBI_EBI_IOSR_NORMAL		(1 << 17) +#define		AT91_MATRIX_EBI_DDR_IOSR	(1 << 18)	/* DDR2 dedicated port I/O slew rate selection */ +#define			AT91_MATRIX_EBI_DDR_IOSR_REDUCED	(0 << 18) +#define			AT91_MATRIX_EBI_DDR_IOSR_NORMAL		(1 << 18) +#define		AT91_MATRIX_NFD0_SELECT		(1 << 24)	/* NAND Flash Data Bus Selection */ +#define			AT91_MATRIX_NFD0_ON_D0			(0 << 24) +#define			AT91_MATRIX_NFD0_ON_D16			(1 << 24) +#define		AT91_MATRIX_DDR_MP_EN		(1 << 25)	/* DDR Multi-port Enable */ +#define			AT91_MATRIX_MP_OFF			(0 << 25) +#define			AT91_MATRIX_MP_ON			(1 << 25) + +#define AT91_MATRIX_WPMR	(AT91_MATRIX + 0x1E4)	/* Write Protect Mode Register */ +#define		AT91_MATRIX_WPMR_WPEN		(1 << 0)	/* Write Protect ENable */ +#define			AT91_MATRIX_WPMR_WP_WPDIS		(0 << 0) +#define			AT91_MATRIX_WPMR_WP_WPEN		(1 << 0) +#define		AT91_MATRIX_WPMR_WPKEY		(0xFFFFFF << 8)	/* Write Protect KEY */ + +#define AT91_MATRIX_WPSR	(AT91_MATRIX + 0x1E8)	/* Write Protect Status Register */ +#define		AT91_MATRIX_WPSR_WPVS		(1 << 0)	/* Write Protect Violation Status */ +#define			AT91_MATRIX_WPSR_NO_WPV		(0 << 0) +#define			AT91_MATRIX_WPSR_WPV		(1 << 0) +#define		AT91_MATRIX_WPSR_WPVSRC		(0xFFFF << 8)	/* Write Protect Violation Source */ + +#endif diff --git a/arch/arm/mach-at91/include/mach/at91x40.h b/arch/arm/mach-at91/include/mach/at91x40.h index 063ac44a020..38dca2bb027 100644 --- a/arch/arm/mach-at91/include/mach/at91x40.h +++ b/arch/arm/mach-at91/include/mach/at91x40.h @@ -15,8 +15,6 @@  /*   *	IRQ list.   */ -#define AT91_ID_FIQ		0	/* FIQ */ -#define AT91_ID_SYS		1	/* System Peripheral */  #define AT91X40_ID_USART0	2	/* USART port 0 */  #define AT91X40_ID_USART1	3	/* USART port 1 */  #define AT91X40_ID_TC0		4	/* Timer/Counter 0 */ @@ -30,19 +28,18 @@  #define AT91X40_ID_IRQ2		18	/* External IRQ 2 */  /* - * System Peripherals (offset from AT91_BASE_SYS) + * System Peripherals   */  #define AT91_BASE_SYS	0xffc00000 -#define AT91_EBI	(0xffe00000 - AT91_BASE_SYS)	/* External Bus Interface */ -#define AT91_SF		(0xfff00000 - AT91_BASE_SYS)	/* Special Function */ -#define AT91_USART1	(0xfffcc000 - AT91_BASE_SYS)	/* USART 1 */ -#define AT91_USART0	(0xfffd0000 - AT91_BASE_SYS)	/* USART 0 */ -#define AT91_TC		(0xfffe0000 - AT91_BASE_SYS)	/* Timer Counter */ -#define AT91_PIOA	(0xffff0000 - AT91_BASE_SYS)	/* PIO Controller A */ -#define AT91_PS		(0xffff4000 - AT91_BASE_SYS)	/* Power Save */ -#define AT91_WD		(0xffff8000 - AT91_BASE_SYS)	/* Watchdog Timer */ -#define AT91_AIC	(0xfffff000 - AT91_BASE_SYS)	/* Advanced Interrupt Controller */ +#define AT91_EBI	0xffe00000	/* External Bus Interface */ +#define AT91_SF		0xfff00000	/* Special Function */ +#define AT91_USART1	0xfffcc000	/* USART 1 */ +#define AT91_USART0	0xfffd0000	/* USART 0 */ +#define AT91_TC		0xfffe0000	/* Timer Counter */ +#define AT91_PIOA	0xffff0000	/* PIO Controller A */ +#define AT91_PS		0xffff4000	/* Power Save */ +#define AT91_WD		0xffff8000	/* Watchdog Timer */  /*   * The AT91x40 series doesn't have a debug unit like the other AT91 parts. @@ -58,4 +55,6 @@  #define	AT91_PS_CR	(AT91_PS + 0)	/* PS Control register */  #define	AT91_PS_CR_CPU	(1 << 0)	/* CPU clock disable bit */ +#define AT91X40_MASTER_CLOCK	40000000 +  #endif /* AT91X40_H */ diff --git a/arch/arm/mach-at91/include/mach/at_hdmac.h b/arch/arm/mach-at91/include/mach/at_hdmac.h deleted file mode 100644 index 187cb58345c..00000000000 --- a/arch/arm/mach-at91/include/mach/at_hdmac.h +++ /dev/null @@ -1,102 +0,0 @@ -/* - * Header file for the Atmel AHB DMA Controller driver - * - * Copyright (C) 2008 Atmel Corporation - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - */ -#ifndef AT_HDMAC_H -#define AT_HDMAC_H - -#include <linux/dmaengine.h> - -/** - * struct at_dma_platform_data - Controller configuration parameters - * @nr_channels: Number of channels supported by hardware (max 8) - * @cap_mask: dma_capability flags supported by the platform - */ -struct at_dma_platform_data { -	unsigned int	nr_channels; -	dma_cap_mask_t  cap_mask; -}; - -/** - * enum at_dma_slave_width - DMA slave register access width. - * @AT_DMA_SLAVE_WIDTH_8BIT: Do 8-bit slave register accesses - * @AT_DMA_SLAVE_WIDTH_16BIT: Do 16-bit slave register accesses - * @AT_DMA_SLAVE_WIDTH_32BIT: Do 32-bit slave register accesses - */ -enum at_dma_slave_width { -	AT_DMA_SLAVE_WIDTH_8BIT = 0, -	AT_DMA_SLAVE_WIDTH_16BIT, -	AT_DMA_SLAVE_WIDTH_32BIT, -}; - -/** - * struct at_dma_slave - Controller-specific information about a slave - * @dma_dev: required DMA master device - * @tx_reg: physical address of data register used for - *	memory-to-peripheral transfers - * @rx_reg: physical address of data register used for - *	peripheral-to-memory transfers - * @reg_width: peripheral register width - * @cfg: Platform-specific initializer for the CFG register - * @ctrla: Platform-specific initializer for the CTRLA register - */ -struct at_dma_slave { -	struct device		*dma_dev; -	dma_addr_t		tx_reg; -	dma_addr_t		rx_reg; -	enum at_dma_slave_width	reg_width; -	u32			cfg; -	u32			ctrla; -}; - - -/* Platform-configurable bits in CFG */ -#define	ATC_SRC_PER(h)		(0xFU & (h))	/* Channel src rq associated with periph handshaking ifc h */ -#define	ATC_DST_PER(h)		((0xFU & (h)) <<  4)	/* Channel dst rq associated with periph handshaking ifc h */ -#define	ATC_SRC_REP		(0x1 <<  8)	/* Source Replay Mod */ -#define	ATC_SRC_H2SEL		(0x1 <<  9)	/* Source Handshaking Mod */ -#define		ATC_SRC_H2SEL_SW	(0x0 <<  9) -#define		ATC_SRC_H2SEL_HW	(0x1 <<  9) -#define	ATC_DST_REP		(0x1 << 12)	/* Destination Replay Mod */ -#define	ATC_DST_H2SEL		(0x1 << 13)	/* Destination Handshaking Mod */ -#define		ATC_DST_H2SEL_SW	(0x0 << 13) -#define		ATC_DST_H2SEL_HW	(0x1 << 13) -#define	ATC_SOD			(0x1 << 16)	/* Stop On Done */ -#define	ATC_LOCK_IF		(0x1 << 20)	/* Interface Lock */ -#define	ATC_LOCK_B		(0x1 << 21)	/* AHB Bus Lock */ -#define	ATC_LOCK_IF_L		(0x1 << 22)	/* Master Interface Arbiter Lock */ -#define		ATC_LOCK_IF_L_CHUNK	(0x0 << 22) -#define		ATC_LOCK_IF_L_BUFFER	(0x1 << 22) -#define	ATC_AHB_PROT_MASK	(0x7 << 24)	/* AHB Protection */ -#define	ATC_FIFOCFG_MASK	(0x3 << 28)	/* FIFO Request Configuration */ -#define		ATC_FIFOCFG_LARGESTBURST	(0x0 << 28) -#define		ATC_FIFOCFG_HALFFIFO		(0x1 << 28) -#define		ATC_FIFOCFG_ENOUGHSPACE		(0x2 << 28) - -/* Platform-configurable bits in CTRLA */ -#define	ATC_SCSIZE_MASK		(0x7 << 16)	/* Source Chunk Transfer Size */ -#define		ATC_SCSIZE_1		(0x0 << 16) -#define		ATC_SCSIZE_4		(0x1 << 16) -#define		ATC_SCSIZE_8		(0x2 << 16) -#define		ATC_SCSIZE_16		(0x3 << 16) -#define		ATC_SCSIZE_32		(0x4 << 16) -#define		ATC_SCSIZE_64		(0x5 << 16) -#define		ATC_SCSIZE_128		(0x6 << 16) -#define		ATC_SCSIZE_256		(0x7 << 16) -#define	ATC_DCSIZE_MASK		(0x7 << 20)	/* Destination Chunk Transfer Size */ -#define		ATC_DCSIZE_1		(0x0 << 20) -#define		ATC_DCSIZE_4		(0x1 << 20) -#define		ATC_DCSIZE_8		(0x2 << 20) -#define		ATC_DCSIZE_16		(0x3 << 20) -#define		ATC_DCSIZE_32		(0x4 << 20) -#define		ATC_DCSIZE_64		(0x5 << 20) -#define		ATC_DCSIZE_128		(0x6 << 20) -#define		ATC_DCSIZE_256		(0x7 << 20) - -#endif /* AT_HDMAC_H */ diff --git a/arch/arm/mach-at91/include/mach/atmel-mci.h b/arch/arm/mach-at91/include/mach/atmel-mci.h index 998cb0c0713..3069e413557 100644 --- a/arch/arm/mach-at91/include/mach/atmel-mci.h +++ b/arch/arm/mach-at91/include/mach/atmel-mci.h @@ -1,7 +1,7 @@  #ifndef __MACH_ATMEL_MCI_H  #define __MACH_ATMEL_MCI_H -#include <mach/at_hdmac.h> +#include <linux/platform_data/dma-atmel.h>  /**   * struct mci_dma_data - DMA data for MCI interface @@ -14,11 +14,4 @@ struct mci_dma_data {  #define	slave_data_ptr(s)	(&(s)->sdata)  #define find_slave_dev(s)	((s)->sdata.dma_dev) -#define	setup_dma_addr(s, t, r)	do {		\ -	if (s) {				\ -		(s)->sdata.tx_reg = (t);	\ -		(s)->sdata.rx_reg = (r);	\ -	}					\ -} while (0) -  #endif /* __MACH_ATMEL_MCI_H */ diff --git a/arch/arm/mach-at91/include/mach/board.h b/arch/arm/mach-at91/include/mach/board.h deleted file mode 100644 index 58528aa9c8a..00000000000 --- a/arch/arm/mach-at91/include/mach/board.h +++ /dev/null @@ -1,218 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/board.h - * - *  Copyright (C) 2005 HP Labs - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -/* - * These are data structures found in platform_device.dev.platform_data, - * and describing board-specific data needed by drivers.  For example, - * which pin is used for a given GPIO role. - * - * In 2.6, drivers should strongly avoid board-specific knowledge so - * that supporting new boards normally won't require driver patches. - * Most board-specific knowledge should be in arch/.../board-*.c files. - */ - -#ifndef __ASM_ARCH_BOARD_H -#define __ASM_ARCH_BOARD_H - -#include <linux/mtd/partitions.h> -#include <linux/device.h> -#include <linux/i2c.h> -#include <linux/leds.h> -#include <linux/spi/spi.h> -#include <linux/usb/atmel_usba_udc.h> -#include <linux/atmel-mci.h> -#include <sound/atmel-ac97c.h> -#include <linux/serial.h> - - /* USB Device */ -struct at91_udc_data { -	u8	vbus_pin;		/* high == host powering us */ -	u8	vbus_active_low;	/* vbus polarity */ -	u8	vbus_polled;		/* Use polling, not interrupt */ -	u8	pullup_pin;		/* active == D+ pulled up */ -	u8	pullup_active_low;	/* true == pullup_pin is active low */ -}; -extern void __init at91_add_device_udc(struct at91_udc_data *data); - - /* USB High Speed Device */ -extern void __init at91_add_device_usba(struct usba_platform_data *data); - - /* Compact Flash */ -struct at91_cf_data { -	u8	irq_pin;		/* I/O IRQ */ -	u8	det_pin;		/* Card detect */ -	u8	vcc_pin;		/* power switching */ -	u8	rst_pin;		/* card reset */ -	u8	chipselect;		/* EBI Chip Select number */ -	u8	flags; -#define AT91_CF_TRUE_IDE	0x01 -#define AT91_IDE_SWAP_A0_A2	0x02 -}; -extern void __init at91_add_device_cf(struct at91_cf_data *data); - - /* MMC / SD */ -  /* at91_mci platform config */ -struct at91_mmc_data { -	u8		det_pin;	/* card detect IRQ */ -	unsigned	slot_b:1;	/* uses Slot B */ -	unsigned	wire4:1;	/* (SD) supports DAT0..DAT3 */ -	u8		wp_pin;		/* (SD) writeprotect detect */ -	u8		vcc_pin;	/* power switching (high == on) */ -}; -extern void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data); - -  /* atmel-mci platform config */ -extern void __init at91_add_device_mci(short mmc_id, struct mci_platform_data *data); - - /* Ethernet (EMAC & MACB) */ -struct at91_eth_data { -	u32		phy_mask; -	u8		phy_irq_pin;	/* PHY IRQ */ -	u8		is_rmii;	/* using RMII interface? */ -}; -extern void __init at91_add_device_eth(struct at91_eth_data *data); - -#if defined(CONFIG_ARCH_AT91SAM9260) || defined(CONFIG_ARCH_AT91SAM9263) || defined(CONFIG_ARCH_AT91SAM9G20) || defined(CONFIG_ARCH_AT91CAP9) \ -	|| defined(CONFIG_ARCH_AT91SAM9G45) || defined(CONFIG_ARCH_AT572D940HF) -#define eth_platform_data	at91_eth_data -#endif - - /* USB Host */ -struct at91_usbh_data { -	u8		ports;		/* number of ports on root hub */ -	u8		vbus_pin[2];	/* port power-control pin */ -}; -extern void __init at91_add_device_usbh(struct at91_usbh_data *data); -extern void __init at91_add_device_usbh_ohci(struct at91_usbh_data *data); -extern void __init at91_add_device_usbh_ehci(struct at91_usbh_data *data); - - /* NAND / SmartMedia */ -struct atmel_nand_data { -	u8		enable_pin;	/* chip enable */ -	u8		det_pin;	/* card detect */ -	u8		rdy_pin;	/* ready/busy */ -	u8              rdy_pin_active_low;     /* rdy_pin value is inverted */ -	u8		ale;		/* address line number connected to ALE */ -	u8		cle;		/* address line number connected to CLE */ -	u8		bus_width_16;	/* buswidth is 16 bit */ -	struct mtd_partition* (*partition_info)(int, int*); -}; -extern void __init at91_add_device_nand(struct atmel_nand_data *data); - - /* I2C*/ -#if defined(CONFIG_ARCH_AT91SAM9G45) -extern void __init at91_add_device_i2c(short i2c_id, struct i2c_board_info *devices, int nr_devices); -#else -extern void __init at91_add_device_i2c(struct i2c_board_info *devices, int nr_devices); -#endif - - /* SPI */ -extern void __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices); - - /* Serial */ -#define ATMEL_UART_CTS	0x01 -#define ATMEL_UART_RTS	0x02 -#define ATMEL_UART_DSR	0x04 -#define ATMEL_UART_DTR	0x08 -#define ATMEL_UART_DCD	0x10 -#define ATMEL_UART_RI	0x20 - -extern void __init at91_register_uart(unsigned id, unsigned portnr, unsigned pins); -extern void __init at91_set_serial_console(unsigned portnr); - -struct at91_uart_config { -	unsigned short	console_tty;	/* tty number of serial console */ -	unsigned short	nr_tty;		/* number of serial tty's */ -	short		tty_map[];	/* map UART to tty number */ -}; -extern struct platform_device *atmel_default_console_device; -extern void __init __deprecated at91_init_serial(struct at91_uart_config *config); - -struct atmel_uart_data { -	short			use_dma_tx;	/* use transmit DMA? */ -	short			use_dma_rx;	/* use receive DMA? */ -	void __iomem		*regs;		/* virt. base address, if any */ -	struct serial_rs485	rs485;		/* rs485 settings */ -}; -extern void __init at91_add_device_serial(void); - -/* - * PWM - */ -#define AT91_PWM0	0 -#define AT91_PWM1	1 -#define AT91_PWM2	2 -#define AT91_PWM3	3 - -extern void __init at91_add_device_pwm(u32 mask); - -/* - * SSC -- accessed through ssc_request(id).  Drivers don't bind to SSC - * platform devices.  Their SSC ID is part of their configuration data, - * along with information about which SSC signals they should use. - */ -#define ATMEL_SSC_TK	0x01 -#define ATMEL_SSC_TF	0x02 -#define ATMEL_SSC_TD	0x04 -#define ATMEL_SSC_TX	(ATMEL_SSC_TK | ATMEL_SSC_TF | ATMEL_SSC_TD) - -#define ATMEL_SSC_RK	0x10 -#define ATMEL_SSC_RF	0x20 -#define ATMEL_SSC_RD	0x40 -#define ATMEL_SSC_RX	(ATMEL_SSC_RK | ATMEL_SSC_RF | ATMEL_SSC_RD) - -extern void __init at91_add_device_ssc(unsigned id, unsigned pins); - - /* LCD Controller */ -struct atmel_lcdfb_info; -extern void __init at91_add_device_lcdc(struct atmel_lcdfb_info *data); - - /* AC97 */ -extern void __init at91_add_device_ac97(struct ac97c_platform_data *data); - - /* ISI */ -extern void __init at91_add_device_isi(void); - - /* Touchscreen Controller */ -struct at91_tsadcc_data { -	unsigned int    adc_clock; -	u8		pendet_debounce; -	u8		ts_sample_hold_time; -}; -extern void __init at91_add_device_tsadcc(struct at91_tsadcc_data *data); - -/* CAN */ -struct at91_can_data { -	void (*transceiver_switch)(int on); -}; -extern void __init at91_add_device_can(struct at91_can_data *data); - - /* LEDs */ -extern void __init at91_init_leds(u8 cpu_led, u8 timer_led); -extern void __init at91_gpio_leds(struct gpio_led *leds, int nr); -extern void __init at91_pwm_leds(struct gpio_led *leds, int nr); - - /* AT572D940HF DSP */ -extern void __init at91_add_device_mAgic(void); - -/* FIXME: this needs a better location, but gets stuff building again */ -extern int at91_suspend_entering_slow_clock(void); - -#endif diff --git a/arch/arm/mach-at91/include/mach/cpu.h b/arch/arm/mach-at91/include/mach/cpu.h index 3bef931d0b1..86c71debab5 100644 --- a/arch/arm/mach-at91/include/mach/cpu.h +++ b/arch/arm/mach-at91/include/mach/cpu.h @@ -1,7 +1,8 @@  /*   * arch/arm/mach-at91/include/mach/cpu.h   * - *  Copyright (C) 2006 SAN People + * Copyright (C) 2006 SAN People + * Copyright (C) 2011 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>   *   * This program is free software; you can redistribute it and/or modify   * it under the terms of the GNU General Public License as published by @@ -10,12 +11,8 @@   *   */ -#ifndef __ASM_ARCH_CPU_H -#define __ASM_ARCH_CPU_H - -#include <mach/hardware.h> -#include <mach/at91_dbgu.h> - +#ifndef __MACH_CPU_H__ +#define __MACH_CPU_H__  #define ARCH_ID_AT91RM9200	0x09290780  #define ARCH_ID_AT91SAM9260	0x019803a0 @@ -27,114 +24,157 @@  #define ARCH_ID_AT91SAM9G45	0x819b05a0  #define ARCH_ID_AT91SAM9G45MRL	0x819b05a2	/* aka 9G45-ES2 & non ES lots */  #define ARCH_ID_AT91SAM9G45ES	0x819b05a1	/* 9G45-ES (Engineering Sample) */ -#define ARCH_ID_AT91CAP9	0x039A03A0 +#define ARCH_ID_AT91SAM9X5	0x819a05a0 +#define ARCH_ID_AT91SAM9N12	0x819a07a0  #define ARCH_ID_AT91SAM9XE128	0x329973a0  #define ARCH_ID_AT91SAM9XE256	0x329a93a0  #define ARCH_ID_AT91SAM9XE512	0x329aa3a0 -#define ARCH_ID_AT572D940HF	0x0e0303e0 -  #define ARCH_ID_AT91M40800	0x14080044  #define ARCH_ID_AT91R40807	0x44080746  #define ARCH_ID_AT91M40807	0x14080745  #define ARCH_ID_AT91R40008	0x44000840 -static inline unsigned long at91_cpu_identify(void) -{ -	return (at91_sys_read(AT91_DBGU_CIDR) & ~AT91_CIDR_VERSION); -} - -static inline unsigned long at91_cpu_fully_identify(void) -{ -	return at91_sys_read(AT91_DBGU_CIDR); -} +#define ARCH_ID_SAMA5D3		0x8A5C07C0  #define ARCH_EXID_AT91SAM9M11	0x00000001  #define ARCH_EXID_AT91SAM9M10	0x00000002  #define ARCH_EXID_AT91SAM9G46	0x00000003  #define ARCH_EXID_AT91SAM9G45	0x00000004 -static inline unsigned long at91_exid_identify(void) -{ -	return at91_sys_read(AT91_DBGU_EXID); -} +#define ARCH_EXID_AT91SAM9G15	0x00000000 +#define ARCH_EXID_AT91SAM9G35	0x00000001 +#define ARCH_EXID_AT91SAM9X35	0x00000002 +#define ARCH_EXID_AT91SAM9G25	0x00000003 +#define ARCH_EXID_AT91SAM9X25	0x00000004 +#define ARCH_EXID_SAMA5D31	0x00444300 +#define ARCH_EXID_SAMA5D33	0x00414300 +#define ARCH_EXID_SAMA5D34	0x00414301 +#define ARCH_EXID_SAMA5D35	0x00584300 +#define ARCH_EXID_SAMA5D36	0x00004301  #define ARCH_FAMILY_AT91X92	0x09200000  #define ARCH_FAMILY_AT91SAM9	0x01900000  #define ARCH_FAMILY_AT91SAM9XE	0x02900000 -static inline unsigned long at91_arch_identify(void) -{ -	return (at91_sys_read(AT91_DBGU_CIDR) & AT91_CIDR_ARCH); -} +/* RM9200 type */ +#define ARCH_REVISON_9200_BGA	(0 << 0) +#define ARCH_REVISON_9200_PQFP	(1 << 0) + +#ifndef __ASSEMBLY__ +enum at91_soc_type { +	/* 920T */ +	AT91_SOC_RM9200, + +	/* SAM92xx */ +	AT91_SOC_SAM9260, AT91_SOC_SAM9261, AT91_SOC_SAM9263, + +	/* SAM9Gxx */ +	AT91_SOC_SAM9G10, AT91_SOC_SAM9G20, AT91_SOC_SAM9G45, + +	/* SAM9RL */ +	AT91_SOC_SAM9RL, + +	/* SAM9X5 */ +	AT91_SOC_SAM9X5, + +	/* SAM9N12 */ +	AT91_SOC_SAM9N12, + +	/* SAMA5D3 */ +	AT91_SOC_SAMA5D3, -#ifdef CONFIG_ARCH_AT91CAP9 -#include <mach/at91_pmc.h> +	/* Unknown type */ +	AT91_SOC_UNKNOWN, +}; -#define ARCH_REVISION_CAP9_B	0x399 -#define ARCH_REVISION_CAP9_C	0x601 +enum at91_soc_subtype { +	/* RM9200 */ +	AT91_SOC_RM9200_BGA, AT91_SOC_RM9200_PQFP, -static inline unsigned long at91cap9_rev_identify(void) +	/* SAM9260 */ +	AT91_SOC_SAM9XE, + +	/* SAM9G45 */ +	AT91_SOC_SAM9G45ES, AT91_SOC_SAM9M10, AT91_SOC_SAM9G46, AT91_SOC_SAM9M11, + +	/* SAM9X5 */ +	AT91_SOC_SAM9G15, AT91_SOC_SAM9G35, AT91_SOC_SAM9X35, +	AT91_SOC_SAM9G25, AT91_SOC_SAM9X25, + +	/* SAMA5D3 */ +	AT91_SOC_SAMA5D31, AT91_SOC_SAMA5D33, AT91_SOC_SAMA5D34, +	AT91_SOC_SAMA5D35, AT91_SOC_SAMA5D36, + +	/* No subtype for this SoC */ +	AT91_SOC_SUBTYPE_NONE, + +	/* Unknown subtype */ +	AT91_SOC_SUBTYPE_UNKNOWN, +}; + +struct at91_socinfo { +	unsigned int type, subtype; +	unsigned int cidr, exid; +}; + +extern struct at91_socinfo at91_soc_initdata; +const char *at91_get_soc_type(struct at91_socinfo *c); +const char *at91_get_soc_subtype(struct at91_socinfo *c); + +static inline int at91_soc_is_detected(void)  { -	return (at91_sys_read(AT91_PMC_VER)); +	return at91_soc_initdata.type != AT91_SOC_UNKNOWN;  } -#endif -#ifdef CONFIG_ARCH_AT91RM9200 -#define cpu_is_at91rm9200()	(at91_cpu_identify() == ARCH_ID_AT91RM9200) +#ifdef CONFIG_SOC_AT91RM9200 +#define cpu_is_at91rm9200()	(at91_soc_initdata.type == AT91_SOC_RM9200) +#define cpu_is_at91rm9200_bga()	(at91_soc_initdata.subtype == AT91_SOC_RM9200_BGA) +#define cpu_is_at91rm9200_pqfp() (at91_soc_initdata.subtype == AT91_SOC_RM9200_PQFP)  #else  #define cpu_is_at91rm9200()	(0) +#define cpu_is_at91rm9200_bga()	(0) +#define cpu_is_at91rm9200_pqfp() (0)  #endif -#ifdef CONFIG_ARCH_AT91SAM9260 -#define cpu_is_at91sam9xe()	(at91_arch_identify() == ARCH_FAMILY_AT91SAM9XE) -#define cpu_is_at91sam9260()	((at91_cpu_identify() == ARCH_ID_AT91SAM9260) || cpu_is_at91sam9xe()) +#ifdef CONFIG_SOC_AT91SAM9260 +#define cpu_is_at91sam9xe()	(at91_soc_initdata.subtype == AT91_SOC_SAM9XE) +#define cpu_is_at91sam9260()	(at91_soc_initdata.type == AT91_SOC_SAM9260) +#define cpu_is_at91sam9g20()	(at91_soc_initdata.type == AT91_SOC_SAM9G20)  #else  #define cpu_is_at91sam9xe()	(0)  #define cpu_is_at91sam9260()	(0) -#endif - -#ifdef CONFIG_ARCH_AT91SAM9G20 -#define cpu_is_at91sam9g20()	(at91_cpu_identify() == ARCH_ID_AT91SAM9G20) -#else  #define cpu_is_at91sam9g20()	(0)  #endif -#ifdef CONFIG_ARCH_AT91SAM9261 -#define cpu_is_at91sam9261()	(at91_cpu_identify() == ARCH_ID_AT91SAM9261) +#ifdef CONFIG_SOC_AT91SAM9261 +#define cpu_is_at91sam9261()	(at91_soc_initdata.type == AT91_SOC_SAM9261) +#define cpu_is_at91sam9g10()	(at91_soc_initdata.type == AT91_SOC_SAM9G10)  #else  #define cpu_is_at91sam9261()	(0) -#endif - -#ifdef CONFIG_ARCH_AT91SAM9G10 -#define cpu_is_at91sam9g10()	((at91_cpu_identify() & ~AT91_CIDR_EXT)	== ARCH_ID_AT91SAM9G10) -#else  #define cpu_is_at91sam9g10()	(0)  #endif -#ifdef CONFIG_ARCH_AT91SAM9263 -#define cpu_is_at91sam9263()	(at91_cpu_identify() == ARCH_ID_AT91SAM9263) +#ifdef CONFIG_SOC_AT91SAM9263 +#define cpu_is_at91sam9263()	(at91_soc_initdata.type == AT91_SOC_SAM9263)  #else  #define cpu_is_at91sam9263()	(0)  #endif -#ifdef CONFIG_ARCH_AT91SAM9RL -#define cpu_is_at91sam9rl()	(at91_cpu_identify() == ARCH_ID_AT91SAM9RL64) +#ifdef CONFIG_SOC_AT91SAM9RL +#define cpu_is_at91sam9rl()	(at91_soc_initdata.type == AT91_SOC_SAM9RL)  #else  #define cpu_is_at91sam9rl()	(0)  #endif -#ifdef CONFIG_ARCH_AT91SAM9G45 -#define cpu_is_at91sam9g45()	(at91_cpu_identify() == ARCH_ID_AT91SAM9G45) -#define cpu_is_at91sam9g45es()	(at91_cpu_fully_identify() == ARCH_ID_AT91SAM9G45ES) -#define cpu_is_at91sam9m10()    (cpu_is_at91sam9g45() && \ -                                (at91_exid_identify() == ARCH_EXID_AT91SAM9M10)) -#define cpu_is_at91sam9m46()    (cpu_is_at91sam9g45() && \ -                                (at91_exid_identify() == ARCH_EXID_AT91SAM9G46)) -#define cpu_is_at91sam9m11()    (cpu_is_at91sam9g45() && \ -                                (at91_exid_identify() == ARCH_EXID_AT91SAM9M11)) +#ifdef CONFIG_SOC_AT91SAM9G45 +#define cpu_is_at91sam9g45()	(at91_soc_initdata.type == AT91_SOC_SAM9G45) +#define cpu_is_at91sam9g45es()	(at91_soc_initdata.subtype == AT91_SOC_SAM9G45ES) +#define cpu_is_at91sam9m10()	(at91_soc_initdata.subtype == AT91_SOC_SAM9M10) +#define cpu_is_at91sam9g46()	(at91_soc_initdata.subtype == AT91_SOC_SAM9G46) +#define cpu_is_at91sam9m11()	(at91_soc_initdata.subtype == AT91_SOC_SAM9M11)  #else  #define cpu_is_at91sam9g45()	(0)  #define cpu_is_at91sam9g45es()	(0) @@ -143,20 +183,32 @@ static inline unsigned long at91cap9_rev_identify(void)  #define cpu_is_at91sam9m11()	(0)  #endif -#ifdef CONFIG_ARCH_AT91CAP9 -#define cpu_is_at91cap9()	(at91_cpu_identify() == ARCH_ID_AT91CAP9) -#define cpu_is_at91cap9_revB()	(at91cap9_rev_identify() == ARCH_REVISION_CAP9_B) -#define cpu_is_at91cap9_revC()	(at91cap9_rev_identify() == ARCH_REVISION_CAP9_C) +#ifdef CONFIG_SOC_AT91SAM9X5 +#define cpu_is_at91sam9x5()	(at91_soc_initdata.type == AT91_SOC_SAM9X5) +#define cpu_is_at91sam9g15()	(at91_soc_initdata.subtype == AT91_SOC_SAM9G15) +#define cpu_is_at91sam9g35()	(at91_soc_initdata.subtype == AT91_SOC_SAM9G35) +#define cpu_is_at91sam9x35()	(at91_soc_initdata.subtype == AT91_SOC_SAM9X35) +#define cpu_is_at91sam9g25()	(at91_soc_initdata.subtype == AT91_SOC_SAM9G25) +#define cpu_is_at91sam9x25()	(at91_soc_initdata.subtype == AT91_SOC_SAM9X25)  #else -#define cpu_is_at91cap9()	(0) -#define cpu_is_at91cap9_revB()	(0) -#define cpu_is_at91cap9_revC()	(0) +#define cpu_is_at91sam9x5()	(0) +#define cpu_is_at91sam9g15()	(0) +#define cpu_is_at91sam9g35()	(0) +#define cpu_is_at91sam9x35()	(0) +#define cpu_is_at91sam9g25()	(0) +#define cpu_is_at91sam9x25()	(0)  #endif -#ifdef CONFIG_ARCH_AT572D940HF -#define cpu_is_at572d940hf() (at91_cpu_identify() == ARCH_ID_AT572D940HF) +#ifdef CONFIG_SOC_AT91SAM9N12 +#define cpu_is_at91sam9n12()	(at91_soc_initdata.type == AT91_SOC_SAM9N12)  #else -#define cpu_is_at572d940hf() (0) +#define cpu_is_at91sam9n12()	(0) +#endif + +#ifdef CONFIG_SOC_SAMA5D3 +#define cpu_is_sama5d3()	(at91_soc_initdata.type == AT91_SOC_SAMA5D3) +#else +#define cpu_is_sama5d3()	(0)  #endif  /* @@ -164,5 +216,6 @@ static inline unsigned long at91cap9_rev_identify(void)   * definitions may reduce clutter in common drivers.   */  #define cpu_is_at32ap7000()	(0) +#endif /* __ASSEMBLY__ */ -#endif +#endif /* __MACH_CPU_H__ */ diff --git a/arch/arm/mach-at91/include/mach/debug-macro.S b/arch/arm/mach-at91/include/mach/debug-macro.S index 0f959faf74a..c6bb9e2d9ba 100644 --- a/arch/arm/mach-at91/include/mach/debug-macro.S +++ b/arch/arm/mach-at91/include/mach/debug-macro.S @@ -14,24 +14,30 @@  #include <mach/hardware.h>  #include <mach/at91_dbgu.h> -	.macro	addruart, rp, rv -	ldr	\rp, =(AT91_BASE_SYS + AT91_DBGU)		@ System peripherals (phys address) -	ldr	\rv, =(AT91_VA_BASE_SYS	+ AT91_DBGU)		@ System peripherals (virt address) +#if defined(CONFIG_AT91_DEBUG_LL_DBGU0) +#define AT91_DBGU AT91_BASE_DBGU0 +#else +#define AT91_DBGU AT91_BASE_DBGU1 +#endif + +	.macro	addruart, rp, rv, tmp +	ldr	\rp, =AT91_DBGU				@ System peripherals (phys address) +	ldr	\rv, =AT91_IO_P2V(AT91_DBGU)		@ System peripherals (virt address)  	.endm  	.macro	senduart,rd,rx -	strb	\rd, [\rx, #(AT91_DBGU_THR - AT91_DBGU)]	@ Write to Transmitter Holding Register +	strb	\rd, [\rx, #(AT91_DBGU_THR)]		@ Write to Transmitter Holding Register  	.endm  	.macro	waituart,rd,rx -1001:	ldr	\rd, [\rx, #(AT91_DBGU_SR - AT91_DBGU)]		@ Read Status Register -	tst	\rd, #AT91_DBGU_TXRDY				@ DBGU_TXRDY = 1 when ready to transmit +1001:	ldr	\rd, [\rx, #(AT91_DBGU_SR)]		@ Read Status Register +	tst	\rd, #AT91_DBGU_TXRDY			@ DBGU_TXRDY = 1 when ready to transmit  	beq	1001b  	.endm  	.macro	busyuart,rd,rx -1001:	ldr	\rd, [\rx, #(AT91_DBGU_SR - AT91_DBGU)]		@ Read Status Register -	tst	\rd, #AT91_DBGU_TXEMPTY				@ DBGU_TXEMPTY = 1 when transmission complete +1001:	ldr	\rd, [\rx, #(AT91_DBGU_SR)]		@ Read Status Register +	tst	\rd, #AT91_DBGU_TXEMPTY			@ DBGU_TXEMPTY = 1 when transmission complete  	beq	1001b  	.endm diff --git a/arch/arm/mach-at91/include/mach/entry-macro.S b/arch/arm/mach-at91/include/mach/entry-macro.S deleted file mode 100644 index 7ab68f97222..00000000000 --- a/arch/arm/mach-at91/include/mach/entry-macro.S +++ /dev/null @@ -1,32 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/entry-macro.S - * - *  Copyright (C) 2003-2005 SAN People - * - * Low-level IRQ helper macros for AT91RM9200 platforms - * - * This file is licensed under the terms of the GNU General Public - * License version 2. This program is licensed "as is" without any - * warranty of any kind, whether express or implied. - */ - -#include <mach/hardware.h> -#include <mach/at91_aic.h> - -	.macro	disable_fiq -	.endm - -	.macro  get_irqnr_preamble, base, tmp -	ldr	\base, =(AT91_VA_BASE_SYS + AT91_AIC)		@ base virtual address of AIC peripheral -	.endm - -	.macro  arch_ret_to_user, tmp1, tmp2 -	.endm - -	.macro	get_irqnr_and_base, irqnr, irqstat, base, tmp -	ldr	\irqnr, [\base, #(AT91_AIC_IVR - AT91_AIC)]	@ read IRQ vector register: de-asserts nIRQ to processor (and clears interrupt) -	ldr	\irqstat, [\base, #(AT91_AIC_ISR - AT91_AIC)]	@ read interrupt source number -	teq	\irqstat, #0					@ ISR is 0 when no current interrupt, or spurious interrupt -	streq	\tmp, [\base, #(AT91_AIC_EOICR - AT91_AIC)]	@ not going to be handled further, then ACK it now. -	.endm - diff --git a/arch/arm/mach-at91/include/mach/gpio.h b/arch/arm/mach-at91/include/mach/gpio.h deleted file mode 100644 index bfdd8ab26dc..00000000000 --- a/arch/arm/mach-at91/include/mach/gpio.h +++ /dev/null @@ -1,235 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/gpio.h - * - *  Copyright (C) 2005 HP Labs - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - */ - -#ifndef __ASM_ARCH_AT91RM9200_GPIO_H -#define __ASM_ARCH_AT91RM9200_GPIO_H - -#include <linux/kernel.h> -#include <asm/irq.h> - -#define PIN_BASE		NR_AIC_IRQS - -#define MAX_GPIO_BANKS		5 -#define NR_BUILTIN_GPIO		(PIN_BASE + (MAX_GPIO_BANKS * 32)) - -/* these pin numbers double as IRQ numbers, like AT91xxx_ID_* values */ - -#define	AT91_PIN_PA0	(PIN_BASE + 0x00 + 0) -#define	AT91_PIN_PA1	(PIN_BASE + 0x00 + 1) -#define	AT91_PIN_PA2	(PIN_BASE + 0x00 + 2) -#define	AT91_PIN_PA3	(PIN_BASE + 0x00 + 3) -#define	AT91_PIN_PA4	(PIN_BASE + 0x00 + 4) -#define	AT91_PIN_PA5	(PIN_BASE + 0x00 + 5) -#define	AT91_PIN_PA6	(PIN_BASE + 0x00 + 6) -#define	AT91_PIN_PA7	(PIN_BASE + 0x00 + 7) -#define	AT91_PIN_PA8	(PIN_BASE + 0x00 + 8) -#define	AT91_PIN_PA9	(PIN_BASE + 0x00 + 9) -#define	AT91_PIN_PA10	(PIN_BASE + 0x00 + 10) -#define	AT91_PIN_PA11	(PIN_BASE + 0x00 + 11) -#define	AT91_PIN_PA12	(PIN_BASE + 0x00 + 12) -#define	AT91_PIN_PA13	(PIN_BASE + 0x00 + 13) -#define	AT91_PIN_PA14	(PIN_BASE + 0x00 + 14) -#define	AT91_PIN_PA15	(PIN_BASE + 0x00 + 15) -#define	AT91_PIN_PA16	(PIN_BASE + 0x00 + 16) -#define	AT91_PIN_PA17	(PIN_BASE + 0x00 + 17) -#define	AT91_PIN_PA18	(PIN_BASE + 0x00 + 18) -#define	AT91_PIN_PA19	(PIN_BASE + 0x00 + 19) -#define	AT91_PIN_PA20	(PIN_BASE + 0x00 + 20) -#define	AT91_PIN_PA21	(PIN_BASE + 0x00 + 21) -#define	AT91_PIN_PA22	(PIN_BASE + 0x00 + 22) -#define	AT91_PIN_PA23	(PIN_BASE + 0x00 + 23) -#define	AT91_PIN_PA24	(PIN_BASE + 0x00 + 24) -#define	AT91_PIN_PA25	(PIN_BASE + 0x00 + 25) -#define	AT91_PIN_PA26	(PIN_BASE + 0x00 + 26) -#define	AT91_PIN_PA27	(PIN_BASE + 0x00 + 27) -#define	AT91_PIN_PA28	(PIN_BASE + 0x00 + 28) -#define	AT91_PIN_PA29	(PIN_BASE + 0x00 + 29) -#define	AT91_PIN_PA30	(PIN_BASE + 0x00 + 30) -#define	AT91_PIN_PA31	(PIN_BASE + 0x00 + 31) - -#define	AT91_PIN_PB0	(PIN_BASE + 0x20 + 0) -#define	AT91_PIN_PB1	(PIN_BASE + 0x20 + 1) -#define	AT91_PIN_PB2	(PIN_BASE + 0x20 + 2) -#define	AT91_PIN_PB3	(PIN_BASE + 0x20 + 3) -#define	AT91_PIN_PB4	(PIN_BASE + 0x20 + 4) -#define	AT91_PIN_PB5	(PIN_BASE + 0x20 + 5) -#define	AT91_PIN_PB6	(PIN_BASE + 0x20 + 6) -#define	AT91_PIN_PB7	(PIN_BASE + 0x20 + 7) -#define	AT91_PIN_PB8	(PIN_BASE + 0x20 + 8) -#define	AT91_PIN_PB9	(PIN_BASE + 0x20 + 9) -#define	AT91_PIN_PB10	(PIN_BASE + 0x20 + 10) -#define	AT91_PIN_PB11	(PIN_BASE + 0x20 + 11) -#define	AT91_PIN_PB12	(PIN_BASE + 0x20 + 12) -#define	AT91_PIN_PB13	(PIN_BASE + 0x20 + 13) -#define	AT91_PIN_PB14	(PIN_BASE + 0x20 + 14) -#define	AT91_PIN_PB15	(PIN_BASE + 0x20 + 15) -#define	AT91_PIN_PB16	(PIN_BASE + 0x20 + 16) -#define	AT91_PIN_PB17	(PIN_BASE + 0x20 + 17) -#define	AT91_PIN_PB18	(PIN_BASE + 0x20 + 18) -#define	AT91_PIN_PB19	(PIN_BASE + 0x20 + 19) -#define	AT91_PIN_PB20	(PIN_BASE + 0x20 + 20) -#define	AT91_PIN_PB21	(PIN_BASE + 0x20 + 21) -#define	AT91_PIN_PB22	(PIN_BASE + 0x20 + 22) -#define	AT91_PIN_PB23	(PIN_BASE + 0x20 + 23) -#define	AT91_PIN_PB24	(PIN_BASE + 0x20 + 24) -#define	AT91_PIN_PB25	(PIN_BASE + 0x20 + 25) -#define	AT91_PIN_PB26	(PIN_BASE + 0x20 + 26) -#define	AT91_PIN_PB27	(PIN_BASE + 0x20 + 27) -#define	AT91_PIN_PB28	(PIN_BASE + 0x20 + 28) -#define	AT91_PIN_PB29	(PIN_BASE + 0x20 + 29) -#define	AT91_PIN_PB30	(PIN_BASE + 0x20 + 30) -#define	AT91_PIN_PB31	(PIN_BASE + 0x20 + 31) - -#define	AT91_PIN_PC0	(PIN_BASE + 0x40 + 0) -#define	AT91_PIN_PC1	(PIN_BASE + 0x40 + 1) -#define	AT91_PIN_PC2	(PIN_BASE + 0x40 + 2) -#define	AT91_PIN_PC3	(PIN_BASE + 0x40 + 3) -#define	AT91_PIN_PC4	(PIN_BASE + 0x40 + 4) -#define	AT91_PIN_PC5	(PIN_BASE + 0x40 + 5) -#define	AT91_PIN_PC6	(PIN_BASE + 0x40 + 6) -#define	AT91_PIN_PC7	(PIN_BASE + 0x40 + 7) -#define	AT91_PIN_PC8	(PIN_BASE + 0x40 + 8) -#define	AT91_PIN_PC9	(PIN_BASE + 0x40 + 9) -#define	AT91_PIN_PC10	(PIN_BASE + 0x40 + 10) -#define	AT91_PIN_PC11	(PIN_BASE + 0x40 + 11) -#define	AT91_PIN_PC12	(PIN_BASE + 0x40 + 12) -#define	AT91_PIN_PC13	(PIN_BASE + 0x40 + 13) -#define	AT91_PIN_PC14	(PIN_BASE + 0x40 + 14) -#define	AT91_PIN_PC15	(PIN_BASE + 0x40 + 15) -#define	AT91_PIN_PC16	(PIN_BASE + 0x40 + 16) -#define	AT91_PIN_PC17	(PIN_BASE + 0x40 + 17) -#define	AT91_PIN_PC18	(PIN_BASE + 0x40 + 18) -#define	AT91_PIN_PC19	(PIN_BASE + 0x40 + 19) -#define	AT91_PIN_PC20	(PIN_BASE + 0x40 + 20) -#define	AT91_PIN_PC21	(PIN_BASE + 0x40 + 21) -#define	AT91_PIN_PC22	(PIN_BASE + 0x40 + 22) -#define	AT91_PIN_PC23	(PIN_BASE + 0x40 + 23) -#define	AT91_PIN_PC24	(PIN_BASE + 0x40 + 24) -#define	AT91_PIN_PC25	(PIN_BASE + 0x40 + 25) -#define	AT91_PIN_PC26	(PIN_BASE + 0x40 + 26) -#define	AT91_PIN_PC27	(PIN_BASE + 0x40 + 27) -#define	AT91_PIN_PC28	(PIN_BASE + 0x40 + 28) -#define	AT91_PIN_PC29	(PIN_BASE + 0x40 + 29) -#define	AT91_PIN_PC30	(PIN_BASE + 0x40 + 30) -#define	AT91_PIN_PC31	(PIN_BASE + 0x40 + 31) - -#define	AT91_PIN_PD0	(PIN_BASE + 0x60 + 0) -#define	AT91_PIN_PD1	(PIN_BASE + 0x60 + 1) -#define	AT91_PIN_PD2	(PIN_BASE + 0x60 + 2) -#define	AT91_PIN_PD3	(PIN_BASE + 0x60 + 3) -#define	AT91_PIN_PD4	(PIN_BASE + 0x60 + 4) -#define	AT91_PIN_PD5	(PIN_BASE + 0x60 + 5) -#define	AT91_PIN_PD6	(PIN_BASE + 0x60 + 6) -#define	AT91_PIN_PD7	(PIN_BASE + 0x60 + 7) -#define	AT91_PIN_PD8	(PIN_BASE + 0x60 + 8) -#define	AT91_PIN_PD9	(PIN_BASE + 0x60 + 9) -#define	AT91_PIN_PD10	(PIN_BASE + 0x60 + 10) -#define	AT91_PIN_PD11	(PIN_BASE + 0x60 + 11) -#define	AT91_PIN_PD12	(PIN_BASE + 0x60 + 12) -#define	AT91_PIN_PD13	(PIN_BASE + 0x60 + 13) -#define	AT91_PIN_PD14	(PIN_BASE + 0x60 + 14) -#define	AT91_PIN_PD15	(PIN_BASE + 0x60 + 15) -#define	AT91_PIN_PD16	(PIN_BASE + 0x60 + 16) -#define	AT91_PIN_PD17	(PIN_BASE + 0x60 + 17) -#define	AT91_PIN_PD18	(PIN_BASE + 0x60 + 18) -#define	AT91_PIN_PD19	(PIN_BASE + 0x60 + 19) -#define	AT91_PIN_PD20	(PIN_BASE + 0x60 + 20) -#define	AT91_PIN_PD21	(PIN_BASE + 0x60 + 21) -#define	AT91_PIN_PD22	(PIN_BASE + 0x60 + 22) -#define	AT91_PIN_PD23	(PIN_BASE + 0x60 + 23) -#define	AT91_PIN_PD24	(PIN_BASE + 0x60 + 24) -#define	AT91_PIN_PD25	(PIN_BASE + 0x60 + 25) -#define	AT91_PIN_PD26	(PIN_BASE + 0x60 + 26) -#define	AT91_PIN_PD27	(PIN_BASE + 0x60 + 27) -#define	AT91_PIN_PD28	(PIN_BASE + 0x60 + 28) -#define	AT91_PIN_PD29	(PIN_BASE + 0x60 + 29) -#define	AT91_PIN_PD30	(PIN_BASE + 0x60 + 30) -#define	AT91_PIN_PD31	(PIN_BASE + 0x60 + 31) - -#define	AT91_PIN_PE0	(PIN_BASE + 0x80 + 0) -#define	AT91_PIN_PE1	(PIN_BASE + 0x80 + 1) -#define	AT91_PIN_PE2	(PIN_BASE + 0x80 + 2) -#define	AT91_PIN_PE3	(PIN_BASE + 0x80 + 3) -#define	AT91_PIN_PE4	(PIN_BASE + 0x80 + 4) -#define	AT91_PIN_PE5	(PIN_BASE + 0x80 + 5) -#define	AT91_PIN_PE6	(PIN_BASE + 0x80 + 6) -#define	AT91_PIN_PE7	(PIN_BASE + 0x80 + 7) -#define	AT91_PIN_PE8	(PIN_BASE + 0x80 + 8) -#define	AT91_PIN_PE9	(PIN_BASE + 0x80 + 9) -#define	AT91_PIN_PE10	(PIN_BASE + 0x80 + 10) -#define	AT91_PIN_PE11	(PIN_BASE + 0x80 + 11) -#define	AT91_PIN_PE12	(PIN_BASE + 0x80 + 12) -#define	AT91_PIN_PE13	(PIN_BASE + 0x80 + 13) -#define	AT91_PIN_PE14	(PIN_BASE + 0x80 + 14) -#define	AT91_PIN_PE15	(PIN_BASE + 0x80 + 15) -#define	AT91_PIN_PE16	(PIN_BASE + 0x80 + 16) -#define	AT91_PIN_PE17	(PIN_BASE + 0x80 + 17) -#define	AT91_PIN_PE18	(PIN_BASE + 0x80 + 18) -#define	AT91_PIN_PE19	(PIN_BASE + 0x80 + 19) -#define	AT91_PIN_PE20	(PIN_BASE + 0x80 + 20) -#define	AT91_PIN_PE21	(PIN_BASE + 0x80 + 21) -#define	AT91_PIN_PE22	(PIN_BASE + 0x80 + 22) -#define	AT91_PIN_PE23	(PIN_BASE + 0x80 + 23) -#define	AT91_PIN_PE24	(PIN_BASE + 0x80 + 24) -#define	AT91_PIN_PE25	(PIN_BASE + 0x80 + 25) -#define	AT91_PIN_PE26	(PIN_BASE + 0x80 + 26) -#define	AT91_PIN_PE27	(PIN_BASE + 0x80 + 27) -#define	AT91_PIN_PE28	(PIN_BASE + 0x80 + 28) -#define	AT91_PIN_PE29	(PIN_BASE + 0x80 + 29) -#define	AT91_PIN_PE30	(PIN_BASE + 0x80 + 30) -#define	AT91_PIN_PE31	(PIN_BASE + 0x80 + 31) - -#ifndef __ASSEMBLY__ -/* setup setup routines, called from board init or driver probe() */ -extern int __init_or_module at91_set_GPIO_periph(unsigned pin, int use_pullup); -extern int __init_or_module at91_set_A_periph(unsigned pin, int use_pullup); -extern int __init_or_module at91_set_B_periph(unsigned pin, int use_pullup); -extern int __init_or_module at91_set_gpio_input(unsigned pin, int use_pullup); -extern int __init_or_module at91_set_gpio_output(unsigned pin, int value); -extern int __init_or_module at91_set_deglitch(unsigned pin, int is_on); -extern int __init_or_module at91_set_multi_drive(unsigned pin, int is_on); - -/* callable at any time */ -extern int at91_set_gpio_value(unsigned pin, int value); -extern int at91_get_gpio_value(unsigned pin); - -/* callable only from core power-management code */ -extern void at91_gpio_suspend(void); -extern void at91_gpio_resume(void); - -/*-------------------------------------------------------------------------*/ - -/* wrappers for "new style" GPIO calls. the old AT91-specfic ones should - * eventually be removed (along with this errno.h inclusion), and the - * gpio request/free calls should probably be implemented. - */ - -#include <asm/errno.h> -#include <asm-generic/gpio.h>		/* cansleep wrappers */ - -#define gpio_get_value	__gpio_get_value -#define gpio_set_value	__gpio_set_value -#define gpio_cansleep	__gpio_cansleep - -static inline int gpio_to_irq(unsigned gpio) -{ -	return gpio; -} - -static inline int irq_to_gpio(unsigned irq) -{ -	return irq; -} - -#endif	/* __ASSEMBLY__ */ - -#endif diff --git a/arch/arm/mach-at91/include/mach/hardware.h b/arch/arm/mach-at91/include/mach/hardware.h index 3d64a75e3ed..56338245653 100644 --- a/arch/arm/mach-at91/include/mach/hardware.h +++ b/arch/arm/mach-at91/include/mach/hardware.h @@ -16,28 +16,51 @@  #include <asm/sizes.h> -#if defined(CONFIG_ARCH_AT91RM9200) +/* DBGU base */ +/* rm9200, 9260/9g20, 9261/9g10, 9rl */ +#define AT91_BASE_DBGU0	0xfffff200 +/* 9263, 9g45 */ +#define AT91_BASE_DBGU1	0xffffee00 + +#if defined(CONFIG_ARCH_AT91X40) +#include <mach/at91x40.h> +#else  #include <mach/at91rm9200.h> -#elif defined(CONFIG_ARCH_AT91SAM9260) || defined(CONFIG_ARCH_AT91SAM9G20)  #include <mach/at91sam9260.h> -#elif defined(CONFIG_ARCH_AT91SAM9261) || defined(CONFIG_ARCH_AT91SAM9G10)  #include <mach/at91sam9261.h> -#elif defined(CONFIG_ARCH_AT91SAM9263)  #include <mach/at91sam9263.h> -#elif defined(CONFIG_ARCH_AT91SAM9RL)  #include <mach/at91sam9rl.h> -#elif defined(CONFIG_ARCH_AT91SAM9G45)  #include <mach/at91sam9g45.h> -#elif defined(CONFIG_ARCH_AT91CAP9) -#include <mach/at91cap9.h> -#elif defined(CONFIG_ARCH_AT91X40) -#include <mach/at91x40.h> -#elif defined(CONFIG_ARCH_AT572D940HF) -#include <mach/at572d940hf.h> -#else -#error "Unsupported AT91 processor" +#include <mach/at91sam9x5.h> +#include <mach/at91sam9n12.h> +#include <mach/sama5d3.h> + +/* + * On all at91 except rm9200 and x40 have the System Controller starts + * at address 0xffffc000 and has a size of 16KiB. + * + * On rm9200 it's start at 0xfffe4000 of 111KiB with non reserved data starting + * at 0xfffff000 + * + * Removes the individual definitions of AT91_BASE_SYS and + * replaces them with a common version at base 0xfffffc000 and size 16KiB + * and map the same memory space + */ +#define AT91_BASE_SYS	0xffffc000  #endif +/* + * On all at91 have the Advanced Interrupt Controller starts at address + * 0xfffff000 and the Power Management Controller starts at 0xfffffc00 + */ +#define AT91_AIC	0xfffff000 +#define AT91_PMC	0xfffffc00 + +/* + * Peripheral identifiers/interrupts. + */ +#define AT91_ID_FIQ		0	/* Advanced Interrupt Controller (FIQ) */ +#define AT91_ID_SYS		1	/* System Peripherals */  #ifdef CONFIG_MMU  /* @@ -45,13 +68,13 @@   * to 0xFEF78000 .. 0xFF000000.  (544Kb)   */  #define AT91_IO_PHYS_BASE	0xFFF78000 -#define AT91_IO_VIRT_BASE	(0xFF000000 - AT91_IO_SIZE) +#define AT91_IO_VIRT_BASE	IOMEM(0xFF000000 - AT91_IO_SIZE)  #else  /*   * Identity mapping for the non MMU case.   */  #define AT91_IO_PHYS_BASE	AT91_BASE_SYS -#define AT91_IO_VIRT_BASE	AT91_IO_PHYS_BASE +#define AT91_IO_VIRT_BASE	IOMEM(AT91_IO_PHYS_BASE)  #endif  #define AT91_IO_SIZE		(0xFFFFFFFF - AT91_IO_PHYS_BASE + 1) @@ -63,15 +86,11 @@   * Virtual to Physical Address mapping for IO devices.   */  #define AT91_VA_BASE_SYS	AT91_IO_P2V(AT91_BASE_SYS) -#define AT91_VA_BASE_EMAC	AT91_IO_P2V(AT91RM9200_BASE_EMAC)   /* Internal SRAM is mapped below the IO devices */  #define AT91_SRAM_MAX		SZ_1M  #define AT91_VIRT_BASE		(AT91_IO_VIRT_BASE - AT91_SRAM_MAX) -/* Serial ports */ -#define ATMEL_MAX_UART		7		/* 6 USART3's and one DBGU port (SAM9260) */ -  /* External Memory Map */  #define AT91_CHIPSELECT_0	0x10000000  #define AT91_CHIPSELECT_1	0x20000000 @@ -82,15 +101,23 @@  #define AT91_CHIPSELECT_6	0x70000000  #define AT91_CHIPSELECT_7	0x80000000 -/* SDRAM */ -#ifdef CONFIG_DRAM_BASE -#define AT91_SDRAM_BASE		CONFIG_DRAM_BASE -#else -#define AT91_SDRAM_BASE		AT91_CHIPSELECT_1 -#endif -  /* Clocks */  #define AT91_SLOW_CLOCK		32768		/* slow clock */ +/* + * FIXME: this is needed to communicate between the pinctrl driver and + * the PM implementation in the machine. Possibly part of the PM + * implementation should be moved down into the pinctrl driver and get + * called as part of the generic suspend/resume path. + */ +#ifndef __ASSEMBLY__ +#ifdef CONFIG_PINCTRL_AT91 +extern void at91_pinctrl_gpio_suspend(void); +extern void at91_pinctrl_gpio_resume(void); +#else +static inline void at91_pinctrl_gpio_suspend(void) {} +static inline void at91_pinctrl_gpio_resume(void) {} +#endif +#endif  #endif diff --git a/arch/arm/mach-at91/include/mach/io.h b/arch/arm/mach-at91/include/mach/io.h index 0b0cccc46e6..2d9ca045574 100644 --- a/arch/arm/mach-at91/include/mach/io.h +++ b/arch/arm/mach-at91/include/mach/io.h @@ -22,27 +22,6 @@  #define __ASM_ARCH_IO_H  #define IO_SPACE_LIMIT		0xFFFFFFFF - -#define __io(a)		__typesafe_io(a) -#define __mem_pci(a)	(a) - - -#ifndef __ASSEMBLY__ - -static inline unsigned int at91_sys_read(unsigned int reg_offset) -{ -	void __iomem *addr = (void __iomem *)AT91_VA_BASE_SYS; - -	return __raw_readl(addr + reg_offset); -} - -static inline void at91_sys_write(unsigned int reg_offset, unsigned long value) -{ -	void __iomem *addr = (void __iomem *)AT91_VA_BASE_SYS; - -	__raw_writel(value, addr + reg_offset); -} - -#endif +#define __io(a)			__typesafe_io(a)  #endif diff --git a/arch/arm/mach-at91/include/mach/irqs.h b/arch/arm/mach-at91/include/mach/irqs.h deleted file mode 100644 index 36bd55f3fc6..00000000000 --- a/arch/arm/mach-at91/include/mach/irqs.h +++ /dev/null @@ -1,48 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/irqs.h - * - *  Copyright (C) 2004 SAN People - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -#ifndef __ASM_ARCH_IRQS_H -#define __ASM_ARCH_IRQS_H - -#include <linux/io.h> -#include <mach/at91_aic.h> - -#define NR_AIC_IRQS 32 - - -/* - * Acknowledge interrupt with AIC after interrupt has been handled. - *   (by kernel/irq.c) - */ -#define irq_finish(irq) do { at91_sys_write(AT91_AIC_EOICR, 0); } while (0) - - -/* - * IRQ interrupt symbols are the AT91xxx_ID_* symbols - * for IRQs handled directly through the AIC, or else the AT91_PIN_* - * symbols in gpio.h for ones handled indirectly as GPIOs. - * We make provision for 5 banks of GPIO. - */ -#define	NR_IRQS		(NR_AIC_IRQS + (5 * 32)) - -/* FIQ is AIC source 0. */ -#define FIQ_START AT91_ID_FIQ - -#endif diff --git a/arch/arm/mach-at91/include/mach/memory.h b/arch/arm/mach-at91/include/mach/memory.h index 14f4ef4b6a9..401c207f2f3 100644 --- a/arch/arm/mach-at91/include/mach/memory.h +++ b/arch/arm/mach-at91/include/mach/memory.h @@ -23,6 +23,4 @@  #include <mach/hardware.h> -#define PHYS_OFFSET	(AT91_SDRAM_BASE) -  #endif diff --git a/arch/arm/mach-at91/include/mach/sama5d3.h b/arch/arm/mach-at91/include/mach/sama5d3.h new file mode 100644 index 00000000000..25613d8c6dc --- /dev/null +++ b/arch/arm/mach-at91/include/mach/sama5d3.h @@ -0,0 +1,86 @@ +/* + * Chip-specific header file for the SAMA5D3 family + * + *  Copyright (C) 2013 Atmel, + *                2013 Ludovic Desroches <ludovic.desroches@atmel.com> + * + * Common definitions. + * Based on SAMA5D3 datasheet. + * + * Licensed under GPLv2 or later. + */ + +#ifndef SAMA5D3_H +#define SAMA5D3_H + +/* + * Peripheral identifiers/interrupts. + */ +#define AT91_ID_FIQ		 0	/* Advanced Interrupt Controller (FIQ) */ +#define AT91_ID_SYS		 1	/* System Peripherals */ +#define SAMA5D3_ID_DBGU		 2	/* debug Unit (usually no special interrupt line) */ +#define AT91_ID_PIT		 3	/* PIT */ +#define SAMA5D3_ID_WDT		 4	/* Watchdog Timer Interrupt */ +#define SAMA5D3_ID_HSMC		 5	/* Static Memory Controller */ +#define SAMA5D3_ID_PIOA		 6	/* PIOA */ +#define SAMA5D3_ID_PIOB		 7	/* PIOB */ +#define SAMA5D3_ID_PIOC		 8	/* PIOC */ +#define SAMA5D3_ID_PIOD		 9	/* PIOD */ +#define SAMA5D3_ID_PIOE		10	/* PIOE */ +#define SAMA5D3_ID_SMD		11	/* SMD Soft Modem */ +#define SAMA5D3_ID_USART0	12	/* USART0 */ +#define SAMA5D3_ID_USART1	13	/* USART1 */ +#define SAMA5D3_ID_USART2	14	/* USART2 */ +#define SAMA5D3_ID_USART3	15	/* USART3 */ +#define SAMA5D3_ID_UART0	16	/* UART 0 */ +#define SAMA5D3_ID_UART1	17	/* UART 1 */ +#define SAMA5D3_ID_TWI0		18	/* Two-Wire Interface 0 */ +#define SAMA5D3_ID_TWI1		19	/* Two-Wire Interface 1 */ +#define SAMA5D3_ID_TWI2		20	/* Two-Wire Interface 2 */ +#define SAMA5D3_ID_HSMCI0	21	/* MCI */ +#define SAMA5D3_ID_HSMCI1	22	/* MCI */ +#define SAMA5D3_ID_HSMCI2	23	/* MCI */ +#define SAMA5D3_ID_SPI0		24	/* Serial Peripheral Interface 0 */ +#define SAMA5D3_ID_SPI1		25	/* Serial Peripheral Interface 1 */ +#define SAMA5D3_ID_TC0		26	/* Timer Counter 0 */ +#define SAMA5D3_ID_TC1		27	/* Timer Counter 2 */ +#define SAMA5D3_ID_PWM		28	/* Pulse Width Modulation Controller */ +#define SAMA5D3_ID_ADC		29	/* Touch Screen ADC Controller */ +#define SAMA5D3_ID_DMA0		30	/* DMA Controller 0 */ +#define SAMA5D3_ID_DMA1		31	/* DMA Controller 1 */ +#define SAMA5D3_ID_UHPHS	32	/* USB Host High Speed */ +#define SAMA5D3_ID_UDPHS	33	/* USB Device High Speed */ +#define SAMA5D3_ID_GMAC		34	/* Gigabit Ethernet MAC */ +#define SAMA5D3_ID_EMAC		35	/* Ethernet MAC */ +#define SAMA5D3_ID_LCDC		36	/* LCD Controller */ +#define SAMA5D3_ID_ISI		37	/* Image Sensor Interface */ +#define SAMA5D3_ID_SSC0		38	/* Synchronous Serial Controller 0 */ +#define SAMA5D3_ID_SSC1		39	/* Synchronous Serial Controller 1 */ +#define SAMA5D3_ID_CAN0		40	/* CAN Controller 0 */ +#define SAMA5D3_ID_CAN1		41	/* CAN Controller 1 */ +#define SAMA5D3_ID_SHA		42	/* Secure Hash Algorithm */ +#define SAMA5D3_ID_AES		43	/* Advanced Encryption Standard */ +#define SAMA5D3_ID_TDES		44	/* Triple Data Encryption Standard */ +#define SAMA5D3_ID_TRNG		45	/* True Random Generator Number */ +#define SAMA5D3_ID_IRQ0		47	/* Advanced Interrupt Controller (IRQ0) */ + +/* + * User Peripheral physical base addresses. + */ +#define SAMA5D3_BASE_USART0	0xf001c000 +#define SAMA5D3_BASE_USART1	0xf0020000 +#define SAMA5D3_BASE_USART2	0xf8020000 +#define SAMA5D3_BASE_USART3	0xf8024000 + +/* + * System Peripherals + */ +#define SAMA5D3_BASE_RTC	0xfffffeb0 + +/* + * Internal Memory + */ +#define SAMA5D3_SRAM_BASE	0x00300000	/* Internal SRAM base address */ +#define SAMA5D3_SRAM_SIZE	(128 * SZ_1K)	/* Internal SRAM size (128Kb) */ + +#endif diff --git a/arch/arm/mach-at91/include/mach/system.h b/arch/arm/mach-at91/include/mach/system.h deleted file mode 100644 index 36af14bc13b..00000000000 --- a/arch/arm/mach-at91/include/mach/system.h +++ /dev/null @@ -1,59 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/system.h - * - *  Copyright (C) 2003 SAN People - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -#ifndef __ASM_ARCH_SYSTEM_H -#define __ASM_ARCH_SYSTEM_H - -#include <mach/hardware.h> -#include <mach/at91_st.h> -#include <mach/at91_dbgu.h> -#include <mach/at91_pmc.h> - -static inline void arch_idle(void) -{ -	/* -	 * Disable the processor clock.  The processor will be automatically -	 * re-enabled by an interrupt or by a reset. -	 */ -#ifdef AT91_PS -	at91_sys_write(AT91_PS_CR, AT91_PS_CR_CPU); -#else -	at91_sys_write(AT91_PMC_SCDR, AT91_PMC_PCK); -#endif -#ifndef CONFIG_CPU_ARM920T -	/* -	 * Set the processor (CP15) into 'Wait for Interrupt' mode. -	 * Post-RM9200 processors need this in conjunction with the above -	 * to save power when idle. -	 */ -	cpu_do_idle(); -#endif -} - -void (*at91_arch_reset)(void); - -static inline void arch_reset(char mode, const char *cmd) -{ -	/* call the CPU-specific reset function */ -	if (at91_arch_reset) -		(at91_arch_reset)(); -} - -#endif diff --git a/arch/arm/mach-at91/include/mach/system_rev.h b/arch/arm/mach-at91/include/mach/system_rev.h new file mode 100644 index 00000000000..ef79a9aafc0 --- /dev/null +++ b/arch/arm/mach-at91/include/mach/system_rev.h @@ -0,0 +1,27 @@ +/* + * Copyright (C) 2011 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> + * + * Under GPLv2 only + */ + +#ifndef __ARCH_SYSTEM_REV_H__ +#define __ARCH_SYSTEM_REV_H__ + +#include <asm/system_info.h> + +/* + * board revision encoding + * mach specific + * the 16-31 bit are reserved for at91 generic information + * + * bit 31: + *	0 => nand 8 bit + *	1 => nand 16 bit + */ +#define BOARD_HAVE_NAND_16BIT	(1 << 31) +static inline int board_have_nand_16bit(void) +{ +	return (system_rev & BOARD_HAVE_NAND_16BIT) ? 1 : 0; +} + +#endif /* __ARCH_SYSTEM_REV_H__ */ diff --git a/arch/arm/mach-at91/include/mach/timex.h b/arch/arm/mach-at91/include/mach/timex.h deleted file mode 100644 index 05a6e8af80c..00000000000 --- a/arch/arm/mach-at91/include/mach/timex.h +++ /dev/null @@ -1,92 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/timex.h - * - *  Copyright (C) 2003 SAN People - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -#ifndef __ASM_ARCH_TIMEX_H -#define __ASM_ARCH_TIMEX_H - -#include <mach/hardware.h> - -#if defined(CONFIG_ARCH_AT91RM9200) - -#define CLOCK_TICK_RATE		(AT91_SLOW_CLOCK) - -#elif defined(CONFIG_ARCH_AT91SAM9260) - -#if defined(CONFIG_MACH_USB_A9260) || defined(CONFIG_MACH_QIL_A9260) -#define AT91SAM9_MASTER_CLOCK	90000000 -#else -#define AT91SAM9_MASTER_CLOCK	99300000 -#endif - -#define CLOCK_TICK_RATE		(AT91SAM9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91SAM9261) - -#define AT91SAM9_MASTER_CLOCK	99300000 -#define CLOCK_TICK_RATE		(AT91SAM9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91SAM9G10) - -#define AT91SAM9_MASTER_CLOCK	133000000 -#define CLOCK_TICK_RATE		(AT91SAM9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91SAM9263) - -#if defined(CONFIG_MACH_USB_A9263) -#define AT91SAM9_MASTER_CLOCK	90000000 -#else -#define AT91SAM9_MASTER_CLOCK	99959500 -#endif - -#define CLOCK_TICK_RATE		(AT91SAM9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91SAM9RL) - -#define AT91SAM9_MASTER_CLOCK	100000000 -#define CLOCK_TICK_RATE		(AT91SAM9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91SAM9G20) - -#define AT91SAM9_MASTER_CLOCK	132096000 -#define CLOCK_TICK_RATE		(AT91SAM9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91SAM9G45) - -#define AT91SAM9_MASTER_CLOCK	133333333 -#define CLOCK_TICK_RATE		(AT91SAM9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91CAP9) - -#define AT91CAP9_MASTER_CLOCK	100000000 -#define CLOCK_TICK_RATE		(AT91CAP9_MASTER_CLOCK/16) - -#elif defined(CONFIG_ARCH_AT91X40) - -#define AT91X40_MASTER_CLOCK	40000000 -#define CLOCK_TICK_RATE		(AT91X40_MASTER_CLOCK) - -#elif defined(CONFIG_ARCH_AT572D940HF) - -#define AT572D940HF_MASTER_CLOCK	80000000 -#define CLOCK_TICK_RATE		(AT572D940HF_MASTER_CLOCK/16) - -#endif - -#endif diff --git a/arch/arm/mach-at91/include/mach/uncompress.h b/arch/arm/mach-at91/include/mach/uncompress.h index 18bdcdeb474..4bb644f8e87 100644 --- a/arch/arm/mach-at91/include/mach/uncompress.h +++ b/arch/arm/mach-at91/include/mach/uncompress.h @@ -1,7 +1,8 @@  /*   * arch/arm/mach-at91/include/mach/uncompress.h   * - *  Copyright (C) 2003 SAN People + * Copyright (C) 2003 SAN People + * Copyright (C) 2012 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>   *   * This program is free software; you can redistribute it and/or modify   * it under the terms of the GNU General Public License as published by @@ -23,21 +24,162 @@  #include <linux/io.h>  #include <linux/atmel_serial.h> +#include <mach/hardware.h> -#if defined(CONFIG_AT91_EARLY_DBGU) -#define UART_OFFSET (AT91_DBGU + AT91_BASE_SYS) -#elif defined(CONFIG_AT91_EARLY_USART0) -#define UART_OFFSET AT91_USART0 -#elif defined(CONFIG_AT91_EARLY_USART1) -#define UART_OFFSET AT91_USART1 -#elif defined(CONFIG_AT91_EARLY_USART2) -#define UART_OFFSET AT91_USART2 -#elif defined(CONFIG_AT91_EARLY_USART3) -#define UART_OFFSET AT91_USART3 -#elif defined(CONFIG_AT91_EARLY_USART4) -#define UART_OFFSET AT91_USART4 -#elif defined(CONFIG_AT91_EARLY_USART5) -#define UART_OFFSET AT91_USART5 +#include <mach/at91_dbgu.h> +#include <mach/cpu.h> + +void __iomem *at91_uart; + +#if !defined(CONFIG_ARCH_AT91X40) +static const u32 uarts_rm9200[] = { +	AT91_BASE_DBGU0, +	AT91RM9200_BASE_US0, +	AT91RM9200_BASE_US1, +	AT91RM9200_BASE_US2, +	AT91RM9200_BASE_US3, +	0, +}; + +static const u32 uarts_sam9260[] = { +	AT91_BASE_DBGU0, +	AT91SAM9260_BASE_US0, +	AT91SAM9260_BASE_US1, +	AT91SAM9260_BASE_US2, +	AT91SAM9260_BASE_US3, +	AT91SAM9260_BASE_US4, +	AT91SAM9260_BASE_US5, +	0, +}; + +static const u32 uarts_sam9261[] = { +	AT91_BASE_DBGU0, +	AT91SAM9261_BASE_US0, +	AT91SAM9261_BASE_US1, +	AT91SAM9261_BASE_US2, +	0, +}; + +static const u32 uarts_sam9263[] = { +	AT91_BASE_DBGU1, +	AT91SAM9263_BASE_US0, +	AT91SAM9263_BASE_US1, +	AT91SAM9263_BASE_US2, +	0, +}; + +static const u32 uarts_sam9g45[] = { +	AT91_BASE_DBGU1, +	AT91SAM9G45_BASE_US0, +	AT91SAM9G45_BASE_US1, +	AT91SAM9G45_BASE_US2, +	AT91SAM9G45_BASE_US3, +	0, +}; + +static const u32 uarts_sam9rl[] = { +	AT91_BASE_DBGU0, +	AT91SAM9RL_BASE_US0, +	AT91SAM9RL_BASE_US1, +	AT91SAM9RL_BASE_US2, +	AT91SAM9RL_BASE_US3, +	0, +}; + +static const u32 uarts_sam9x5[] = { +	AT91_BASE_DBGU0, +	AT91SAM9X5_BASE_USART0, +	AT91SAM9X5_BASE_USART1, +	AT91SAM9X5_BASE_USART2, +	0, +}; + +static const u32 uarts_sama5[] = { +	AT91_BASE_DBGU1, +	SAMA5D3_BASE_USART0, +	SAMA5D3_BASE_USART1, +	SAMA5D3_BASE_USART2, +	SAMA5D3_BASE_USART3, +	0, +}; + +static inline const u32* decomp_soc_detect(void __iomem *dbgu_base) +{ +	u32 cidr, socid; + +	cidr = __raw_readl(dbgu_base + AT91_DBGU_CIDR); +	socid = cidr & ~AT91_CIDR_VERSION; + +	switch (socid) { +	case ARCH_ID_AT91RM9200: +		return uarts_rm9200; + +	case ARCH_ID_AT91SAM9G20: +	case ARCH_ID_AT91SAM9260: +		return uarts_sam9260; + +	case ARCH_ID_AT91SAM9261: +		return uarts_sam9261; + +	case ARCH_ID_AT91SAM9263: +		return uarts_sam9263; + +	case ARCH_ID_AT91SAM9G45: +		return uarts_sam9g45; + +	case ARCH_ID_AT91SAM9RL64: +		return uarts_sam9rl; + +	case ARCH_ID_AT91SAM9N12: +	case ARCH_ID_AT91SAM9X5: +		return uarts_sam9x5; + +	case ARCH_ID_SAMA5D3: +		return uarts_sama5; +	} + +	/* at91sam9g10 */ +	if ((cidr & ~AT91_CIDR_EXT) == ARCH_ID_AT91SAM9G10) { +		return uarts_sam9261; +	} +	/* at91sam9xe */ +	else if ((cidr & AT91_CIDR_ARCH) == ARCH_FAMILY_AT91SAM9XE) { +		return uarts_sam9260; +	} + +	return NULL; +} + +static inline void arch_decomp_setup(void) +{ +	int i = 0; +	const u32* usarts; + +	usarts = decomp_soc_detect((void __iomem *)AT91_BASE_DBGU0); + +	if (!usarts) +		usarts = decomp_soc_detect((void __iomem *)AT91_BASE_DBGU1); +	if (!usarts) { +		at91_uart = NULL; +		return; +	} + +	do { +		/* physical address */ +		at91_uart = (void __iomem *)usarts[i]; + +		if (__raw_readl(at91_uart + ATMEL_US_BRGR)) +			return; +		i++; +	} while (usarts[i]); + +	at91_uart = NULL; +} +#else +static inline void arch_decomp_setup(void) +{ +	at91_uart = NULL; +}  #endif  /* @@ -49,28 +191,22 @@   */  static void putc(int c)  { -#ifdef UART_OFFSET -	void __iomem *sys = (void __iomem *) UART_OFFSET;	/* physical address */ +	if (!at91_uart) +		return; -	while (!(__raw_readl(sys + ATMEL_US_CSR) & ATMEL_US_TXRDY)) +	while (!(__raw_readl(at91_uart + ATMEL_US_CSR) & ATMEL_US_TXRDY))  		barrier(); -	__raw_writel(c, sys + ATMEL_US_THR); -#endif +	__raw_writel(c, at91_uart + ATMEL_US_THR);  }  static inline void flush(void)  { -#ifdef UART_OFFSET -	void __iomem *sys = (void __iomem *) UART_OFFSET;	/* physical address */ +	if (!at91_uart) +		return;  	/* wait for transmission to complete */ -	while (!(__raw_readl(sys + ATMEL_US_CSR) & ATMEL_US_TXEMPTY)) +	while (!(__raw_readl(at91_uart + ATMEL_US_CSR) & ATMEL_US_TXEMPTY))  		barrier(); -#endif  } -#define arch_decomp_setup() - -#define arch_decomp_wdog() -  #endif diff --git a/arch/arm/mach-at91/include/mach/vmalloc.h b/arch/arm/mach-at91/include/mach/vmalloc.h deleted file mode 100644 index 8eb459f3f5b..00000000000 --- a/arch/arm/mach-at91/include/mach/vmalloc.h +++ /dev/null @@ -1,26 +0,0 @@ -/* - * arch/arm/mach-at91/include/mach/vmalloc.h - * - *  Copyright (C) 2003 SAN People - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - */ - -#ifndef __ASM_ARCH_VMALLOC_H -#define __ASM_ARCH_VMALLOC_H - -#define VMALLOC_END		(AT91_VIRT_BASE & PGDIR_MASK) - -#endif  | 
