Correct SAM3S-Xplained load address, FLASH wait states, and UART1 pin configuration
This commit is contained in:
parent
a2a91bf8d6
commit
d9cec43398
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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 ******************************************************************/
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user