Correct SAM3S-Xplained load address, FLASH wait states, and UART1 pin configuration

This commit is contained in:
Gregory Nutt 2013-06-12 08:18:42 -06:00
parent a2a91bf8d6
commit d9cec43398
5 changed files with 71 additions and 21 deletions

View File

@ -102,8 +102,8 @@
static inline void sam_efcsetup(void) static inline void sam_efcsetup(void)
{ {
putreg32((2 << EEFC_FMR_FWS_SHIFT), SAM_EEFC0_FMR); putreg32((BOARD_FWS << EEFC_FMR_FWS_SHIFT), SAM_EEFC0_FMR);
putreg32((2 << EEFC_FMR_FWS_SHIFT), SAM_EEFC1_FMR); putreg32((BOARD_FWS << EEFC_FMR_FWS_SHIFT), SAM_EEFC1_FMR);
} }
/**************************************************************************** /****************************************************************************
@ -215,7 +215,7 @@ static inline void sam_pmcsetup(void)
putreg32(regval, SAM_PMC_MCKR); putreg32(regval, SAM_PMC_MCKR);
sam_pmcwait(PMC_INT_MCKRDY); sam_pmcwait(PMC_INT_MCKRDY);
/* Settup PLLA and wait for LOCKA */ /* Setup PLLA and wait for LOCKA */
putreg32(BOARD_CKGR_PLLAR, SAM_PMC_CKGR_PLLAR); putreg32(BOARD_CKGR_PLLAR, SAM_PMC_CKGR_PLLAR);
sam_pmcwait(PMC_INT_LOCKA); sam_pmcwait(PMC_INT_LOCKA);

View File

@ -319,6 +319,11 @@ void sam_lowsetup(void)
(void)sam_configgpio(GPIO_UART0_TXD); (void)sam_configgpio(GPIO_UART0_TXD);
#endif #endif
#ifdef CONFIG_SAM34_UART1
(void)sam_configgpio(GPIO_UART1_RXD);
(void)sam_configgpio(GPIO_UART1_TXD);
#endif
#ifdef CONFIG_SAM34_USART0 #ifdef CONFIG_SAM34_USART0
(void)sam_configgpio(GPIO_USART0_RXD); (void)sam_configgpio(GPIO_USART0_RXD);
(void)sam_configgpio(GPIO_USART0_TXD); (void)sam_configgpio(GPIO_USART0_TXD);

View File

@ -96,16 +96,20 @@
/* MCK = 48MHz, CLKDIV = 59, MCI_SPEED = 48MHz / 2 * (59+1) = 400 KHz */ /* MCK = 48MHz, CLKDIV = 59, MCI_SPEED = 48MHz / 2 * (59+1) = 400 KHz */
#define HSMCI_INIT_CLKDIV (59 << HSMCI_MR_CLKDIV_SHIFT) #define HSMCI_INIT_CLKDIV (59 << HSMCI_MR_CLKDIV_SHIFT)
/* MCK = 48MHz, CLKDIV = 1, MCI_SPEED = 48MHz / 2 * (1+1) = 12 MHz */ /* MCK = 48MHz, CLKDIV = 1, MCI_SPEED = 48MHz / 2 * (1+1) = 12 MHz */
#define HSMCI_MMCXFR_CLKDIV (3 << HSMCI_MR_CLKDIV_SHIFT) #define HSMCI_MMCXFR_CLKDIV (3 << HSMCI_MR_CLKDIV_SHIFT)
/* MCK = 48MHz, CLKDIV = 0, MCI_SPEED = 48MHz / 2 * (0+1) = 24 MHz */ /* MCK = 48MHz, CLKDIV = 0, MCI_SPEED = 48MHz / 2 * (0+1) = 24 MHz */
#define HSMCI_SDXFR_CLKDIV (0 << HSMCI_MR_CLKDIV_SHIFT) #define HSMCI_SDXFR_CLKDIV (0 << HSMCI_MR_CLKDIV_SHIFT)
#define HSMCI_SDWIDEXFR_CLKDIV HSMCI_SDXFR_CLKDIV #define HSMCI_SDWIDEXFR_CLKDIV HSMCI_SDXFR_CLKDIV
/* FLASH wait states */
#define BOARD_FWS 2
/* LED definitions ******************************************************************/ /* LED definitions ******************************************************************/

View File

@ -115,16 +115,57 @@
/* MCK = 48MHz, CLKDIV = 59, MCI_SPEED = 48MHz / 2 * (59+1) = 400 KHz */ /* MCK = 48MHz, CLKDIV = 59, MCI_SPEED = 48MHz / 2 * (59+1) = 400 KHz */
#define HSMCI_INIT_CLKDIV (59 << HSMCI_MR_CLKDIV_SHIFT) #define HSMCI_INIT_CLKDIV (59 << HSMCI_MR_CLKDIV_SHIFT)
/* MCK = 48MHz, CLKDIV = 1, MCI_SPEED = 48MHz / 2 * (1+1) = 12 MHz */ /* MCK = 48MHz, CLKDIV = 1, MCI_SPEED = 48MHz / 2 * (1+1) = 12 MHz */
#define HSMCI_MMCXFR_CLKDIV (3 << HSMCI_MR_CLKDIV_SHIFT) #define HSMCI_MMCXFR_CLKDIV (3 << HSMCI_MR_CLKDIV_SHIFT)
/* MCK = 48MHz, CLKDIV = 0, MCI_SPEED = 48MHz / 2 * (0+1) = 24 MHz */ /* MCK = 48MHz, CLKDIV = 0, MCI_SPEED = 48MHz / 2 * (0+1) = 24 MHz */
#define HSMCI_SDXFR_CLKDIV (0 << HSMCI_MR_CLKDIV_SHIFT) #define HSMCI_SDXFR_CLKDIV (0 << HSMCI_MR_CLKDIV_SHIFT)
#define HSMCI_SDWIDEXFR_CLKDIV HSMCI_SDXFR_CLKDIV #define HSMCI_SDWIDEXFR_CLKDIV HSMCI_SDXFR_CLKDIV
/* FLASH wait states:
*
* DC Characteristics
*
* Parameter Min Typ Max
* ---------------------- ----- ----- ----
* Vddcore DC Supply Core 1.08V 1.2V 1.32V
* Vvddio DC Supply I/Os 1.62V 3.3V 3.6V
*
* Wait Maximum
* Vddcore Vvddio States Frequency (MHz)
* ------- ---------- ------ ---------------
* 1.08V 1.62-3.6V 0 16
* " " " "-" " 1 33
* " " " "-" " 2 50
* " " " "-" " 3 67
* " " " "-" " 4 84
* " " " "-" " 5 100
* 1.08V 2.7-3.6V 0 20
* " " " "-" " 1 40
* " " " "-" " 2 60
* " " " "-" " 3 80
* " " " "-" " 4 100
* 1.2V 1.62-3.6V 0 17
* " " " "-" " 1 34
* " " " "-" " 2 52
* " " " "-" " 3 69
* " " " "-" " 4 87
* " " " "-" " 5 104
* " " " "-" " 6 121
* 1.2V 2.7-3.6V 0 21
* " " " "-" " 1 42
* " " " "-" " 2 63
* " " " "-" " 3 84
* " " " "-" " 4 105
* " " " "-" " 5 123 << SELECTION
*/
#define BOARD_FWS 5
/* LED definitions ******************************************************************/ /* LED definitions ******************************************************************/
/* There are four LEDs on board the SAM4S Xplained board, two of these can be /* There are four LEDs on board the SAM4S Xplained board, two of these can be
@ -140,14 +181,14 @@
/* LED index values for use with sam_setled() */ /* LED index values for use with sam_setled() */
#define BOARD_D9 0 #define BOARD_D9 0
#define BOARD_D10 1 #define BOARD_D10 1
#define BOARD_NLEDS 2 #define BOARD_NLEDS 2
/* LED bits for use with sam_setleds() */ /* LED bits for use with sam_setleds() */
#define BOARD_D9_BIT (1 << BOARD_D9) #define BOARD_D9_BIT (1 << BOARD_D9)
#define BOARD_D10_BIT (1 << BOARD_D10) #define BOARD_D10_BIT (1 << BOARD_D10)
/* These LEDs are not used by the board port unless CONFIG_ARCH_LEDS is /* These LEDs are not used by the board port unless CONFIG_ARCH_LEDS is
* defined. In that case, the usage by the board port is defined in * defined. In that case, the usage by the board port is defined in
@ -182,10 +223,10 @@
* PA5 BP2 * PA5 BP2
*/ */
#define BUTTON_BP2 0 #define BUTTON_BP2 0
#define NUM_BUTTONS 1 #define NUM_BUTTONS 1
#define BUTTON_BP2_BIT (1 << BUTTON_BP2) #define BUTTON_BP2_BIT (1 << BUTTON_BP2)
/************************************************************************************ /************************************************************************************
* Public Data * Public Data

View File

@ -33,13 +33,13 @@
* *
****************************************************************************/ ****************************************************************************/
/* The ATSAM4S16C has 1MB of FLASH beginning at address 0x0000:0000 and /* The ATSAM4S16C has 1MB of FLASH beginning at address 0x0040:0000 and
* 128KB of SRAM beginning at address 0x2000:0000 * 128KB of SRAM beginning at address 0x2000:0000
*/ */
MEMORY MEMORY
{ {
flash (rx) : ORIGIN = 0x00000000, LENGTH = 1024K flash (rx) : ORIGIN = 0x00400000, LENGTH = 1024K
sram (rwx) : ORIGIN = 0x20000000, LENGTH = 128K sram (rwx) : ORIGIN = 0x20000000, LENGTH = 128K
} }