-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ARM: at91: Add machine header file for AT91SAM9N12 SoC
Signed-off-by: Hong Xu <hong.xu@atmel.com> Signed-off-by: Nicolas Ferre <nicolas.ferre@atmel.com> Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
- Loading branch information
Hong Xu
authored and
Jean-Christophe PLAGNIOL-VILLARD
committed
Apr 27, 2012
1 parent
2669086
commit 0205968
Showing
5 changed files
with
129 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
/* | ||
* 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 | ||
|
||
/* | ||
* 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 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -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 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters