Add logic to initialize clocks
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@1108 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
a57e7dd05b
commit
f0ed24d9a9
@ -32,6 +32,35 @@
|
|||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
/****************************************************************************
|
||||||
|
* Features:
|
||||||
|
*
|
||||||
|
* - MCU: STR711FR2T6 16/32 bit ARM7TDMI™ with 256K Bytes Program Flash,
|
||||||
|
* 64K Bytes RAM, USB 2.0, RTC, 12 bit ADC, 4x UARTs, 2x I2C,2x SPI,
|
||||||
|
* 5x 32bit TIMERS, 2x PWM, 2x CCR, WDT, up to 50MHz operation
|
||||||
|
* - Standard JTAG connector with ARM 2x10 pin layout for programming/debugging
|
||||||
|
* with ARM-JTAG
|
||||||
|
* - USB connector
|
||||||
|
* - Two channel RS232 interface and drivers
|
||||||
|
* - SD/MMC card connector
|
||||||
|
* - Two buttons
|
||||||
|
* - Trimpot connected to ADC
|
||||||
|
* - Two status LEDs
|
||||||
|
* - Buzzer
|
||||||
|
* - UEXT - 10 pin extension connector for Olimex addon peripherials like MP3,
|
||||||
|
* RF2.4Ghz, RFID etc. modules
|
||||||
|
* - 2x SPI connectors
|
||||||
|
* - I2C connector
|
||||||
|
* - On board voltage regulator 3.3V with up to 800mA current
|
||||||
|
* - Single power supply: 6V AC or DC required, USB port can power the board
|
||||||
|
* - Power supply LED
|
||||||
|
* - Power supply filtering capacitor
|
||||||
|
* - RESET circuit
|
||||||
|
* - RESET button
|
||||||
|
* - 4 Mhz crystal oscillator
|
||||||
|
* - 32768 Hz crystal and RTC
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
#ifndef _CONFIGS_OLIMEX_STRP711_BOARD_H
|
#ifndef _CONFIGS_OLIMEX_STRP711_BOARD_H
|
||||||
#define _CONFIGS_OLIMEX_STRP711_BOARD_H
|
#define _CONFIGS_OLIMEX_STRP711_BOARD_H
|
||||||
@ -43,6 +72,7 @@
|
|||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
# include <sys/types.h>
|
# include <sys/types.h>
|
||||||
#endif
|
#endif
|
||||||
|
#include "chip.h"
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Definitions
|
* Definitions
|
||||||
@ -50,9 +80,46 @@
|
|||||||
|
|
||||||
/* Clocking *****************************************************************/
|
/* Clocking *****************************************************************/
|
||||||
|
|
||||||
/* RTC Oscillator Frequency value = 32,768 Hz */
|
/* Main Oscillator Frequency = 4MHz */
|
||||||
|
|
||||||
#define STR71X_RCCU_RTC_OSC (32768)
|
#define STR71X_RCCU_MAIN_OSC (4000000)
|
||||||
|
|
||||||
|
/* RTC Oscillator Frequency = 32,768 Hz */
|
||||||
|
|
||||||
|
#define STR71X_RCCU_RTC_OSC (32768)
|
||||||
|
|
||||||
|
/* HCLK driving PLL2 */
|
||||||
|
|
||||||
|
#define STR71X_PCU_HCLK_OSC (4000000) /* ? */
|
||||||
|
|
||||||
|
/* PLL1 Setup:
|
||||||
|
*
|
||||||
|
* PLL1 input clock: CLK2 = Main OSC = 4MHz
|
||||||
|
* PLL1 output clock: PLL1OUT = 16 * CLK2 / 2 = 32MHz
|
||||||
|
* PLL1 output: CLK3 = PLL1OUT = 32MHz (hard coded selection)
|
||||||
|
* RCLK = CLK3 = 32MHz (hard coded selection)
|
||||||
|
* APB1 peripheral clock: PCLK1 = RCLK = 32MHz
|
||||||
|
* APB2 peripheral clock: PCLK2 = RCLK = 32MHz
|
||||||
|
* Main system clock: MCLK = RCLK = 32MHz
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef STR71X_PLL1IN_DIV2 /* Don't divide main OSC by two */
|
||||||
|
#define STR71X_PLL1OUT_MUL STR71X_RCCUPLL1CR_MUL16 /* PLL1OUT = 16 * CLK2 */
|
||||||
|
#define STR71X_PLL1OUT_DIV STR71X_RCCUPLL1CR_DIV2 /* PLL1OUT = CLK2 / 2 */
|
||||||
|
#define STR71X_APB1_DIV STR71X_PCUPDIVR_APB1DIV1 /* PCLK1 = RCLK */
|
||||||
|
#define STR71X_APB2_DIV STR71X_PCUPDIVR_APB1DIV1 /* PCLK2 = RCLK */
|
||||||
|
#define STR71X_MCLK_DIV STR71X_PCUMDIVR_DIV1 /* MCLK = RCLK */
|
||||||
|
|
||||||
|
/* PLL2 Setup -- only needed for HDLC or USB
|
||||||
|
*
|
||||||
|
* USB input: USB clock
|
||||||
|
* HCLK = 4MHz?
|
||||||
|
* USB clock = 12 * HCLK / 1 = 48 MHz
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef STR71X_USBIN_PLL2 /* USB input is USB clock */
|
||||||
|
#define STR71X_PLL2OUT_MUL STR71X_PCUPPL2CR_MUL12 /* PLL2OUT = 12 * HCLK */
|
||||||
|
#define STR71X_PLL2OUT_DIV STR71X_PCUPPL2CR_DIV1 /* PLL2OUT = HCLK / 1 */
|
||||||
|
|
||||||
/* LED definitions **********************************************************/
|
/* LED definitions **********************************************************/
|
||||||
|
|
||||||
|
@ -72,18 +72,48 @@ CONFIG_ARCH_STACKDUMP=y
|
|||||||
#
|
#
|
||||||
# STR71x specific boot/build settings
|
# STR71x specific boot/build settings
|
||||||
#
|
#
|
||||||
|
# CONFIG_STR71X_I2C0, CONFIG_STR71X_I2C1, CONFIG_STR71X_UART0, CONFIG_STR71X_UART1,
|
||||||
|
# CONFIG_STR71X_UART2, CONFIG_STR71X_UART3, CONFIG_STR71X_USB, CONFIG_STR71X_CAN,
|
||||||
|
# CONFIG_STR71X_BSPI0, CONFIG_STR71X_BSPI1, CONFIG_STR71X_HDLC, CONFIG_STR71X_XTI,
|
||||||
|
# CONFIG_STR71X_GPIO0, CONFIG_STR71X_GPIO1, CONFIG_STR71X_GPIO2, CONFIG_STR71X_ADC12,
|
||||||
|
# CONFIG_STR71X_CKOUT, CONFIG_STR71X_TIM1, CONFIG_STR71X_TIM2, CONFIG_STR71X_TIM3, and
|
||||||
|
# CONFIG_STR71X_RTC
|
||||||
|
# Select peripherals to initialize (Timer0 and EIC are always initialized)
|
||||||
# CONFIG_STR71X_BANK0, CONFIG_STR71X_BANK1, CONFIG_STR71X_BANK2, and CONFIG_STR71X_BANK3
|
# CONFIG_STR71X_BANK0, CONFIG_STR71X_BANK1, CONFIG_STR71X_BANK2, and CONFIG_STR71X_BANK3
|
||||||
# Enable initialize of external memory banks 0-3.
|
# Enable initialize of external memory banks 0-3.
|
||||||
# CONFIG_STR71X_BANK0_SIZE, CONFIG_STR71X_BANK1_SIZE, CONFIG_STR71X_BANK2_SIZE, and CONFIG_STR71X_BANK3_SIZE
|
# CONFIG_STR71X_BANK0_SIZE, CONFIG_STR71X_BANK1_SIZE, CONFIG_STR71X_BANK2_SIZE, and
|
||||||
|
# CONFIG_STR71X_BANK3_SIZE
|
||||||
# If a particular external memory bank is configured, then its width must be provided.
|
# If a particular external memory bank is configured, then its width must be provided.
|
||||||
# 8 and 16 (bits) are the only valid options.
|
# 8 and 16 (bits) are the only valid options.
|
||||||
# CONFIG_STR71X_BANK0_WAITSTATES, CONFIG_STR71X_BANK1_WAITSTATES, CONFIG_STR71X_BANK2_WAITSTATES, and CONFIG_STR71X_BANK3_WAITSTATES
|
# CONFIG_STR71X_BANK0_WAITSTATES, CONFIG_STR71X_BANK1_WAITSTATES,
|
||||||
|
# CONFIG_STR71X_BANK2_WAITSTATES, and CONFIG_STR71X_BANK3_WAITSTATES
|
||||||
# If a particular external memory bank is configured, then the number of waistates
|
# If a particular external memory bank is configured, then the number of waistates
|
||||||
# for the bank must also be provided. Valid options are {0, .., 15}
|
# for the bank must also be provided. Valid options are {0, .., 15}
|
||||||
# CONFIG_STR71X_BIGEXTMEM
|
# CONFIG_STR71X_BIGEXTMEM
|
||||||
# The default is to provide 20 bits of address for all external memory regions. If
|
# The default is to provide 20 bits of address for all external memory regions. If
|
||||||
# any memory region is larger than 1Mb, then this option should be selected. In this
|
# any memory region is larger than 1Mb, then this option should be selected. In this
|
||||||
# case, 24 bits of addressing will be used
|
# case, 24 bits of addressing will be used
|
||||||
|
CONFIG_STR71X_I2C0=n
|
||||||
|
CONFIG_STR71X_I2C1=n
|
||||||
|
CONFIG_STR71X_UART0=y
|
||||||
|
CONFIG_STR71X_UART1=y
|
||||||
|
CONFIG_STR71X_UART2=n
|
||||||
|
CONFIG_STR71X_UART3=n
|
||||||
|
CONFIG_STR71X_USB=n
|
||||||
|
CONFIG_STR71X_CAN=n
|
||||||
|
CONFIG_STR71X_BSPI0=n
|
||||||
|
CONFIG_STR71X_BSPI1=n
|
||||||
|
CONFIG_STR71X_HDLC=n
|
||||||
|
CONFIG_STR71X_XTI=n
|
||||||
|
CONFIG_STR71X_GPIO0=y
|
||||||
|
CONFIG_STR71X_GPIO1=n
|
||||||
|
CONFIG_STR71X_GPIO2=n
|
||||||
|
CONFIG_STR71X_ADC12=n
|
||||||
|
CONFIG_STR71X_CKOUT=n
|
||||||
|
CONFIG_STR71X_TIM1=n
|
||||||
|
CONFIG_STR71X_TIM2=n
|
||||||
|
CONFIG_STR71X_TIM3=n
|
||||||
|
CONFIG_STR71X_RTC=n
|
||||||
CONFIG_STR71X_BANK0=n
|
CONFIG_STR71X_BANK0=n
|
||||||
CONFIG_STR71X_BANK0_SIZE=16
|
CONFIG_STR71X_BANK0_SIZE=16
|
||||||
CONFIG_STR71X_BANK0_WAITSTATES=0
|
CONFIG_STR71X_BANK0_WAITSTATES=0
|
||||||
@ -114,18 +144,32 @@ CONFIG_STR71X_BIGEXTMEM=n
|
|||||||
#
|
#
|
||||||
CONFIG_UART0_SERIAL_CONSOLE=y
|
CONFIG_UART0_SERIAL_CONSOLE=y
|
||||||
CONFIG_UART1_SERIAL_CONSOLE=n
|
CONFIG_UART1_SERIAL_CONSOLE=n
|
||||||
|
CONFIG_UART2_SERIAL_CONSOLE=n
|
||||||
|
CONFIG_UART3_SERIAL_CONSOLE=n
|
||||||
CONFIG_UART0_TXBUFSIZE=256
|
CONFIG_UART0_TXBUFSIZE=256
|
||||||
CONFIG_UART1_TXBUFSIZE=256
|
CONFIG_UART1_TXBUFSIZE=256
|
||||||
|
CONFIG_UART2_TXBUFSIZE=256
|
||||||
|
CONFIG_UART3_TXBUFSIZE=256
|
||||||
CONFIG_UART0_RXBUFSIZE=256
|
CONFIG_UART0_RXBUFSIZE=256
|
||||||
CONFIG_UART1_RXBUFSIZE=256
|
CONFIG_UART1_RXBUFSIZE=256
|
||||||
|
CONFIG_UART2_RXBUFSIZE=256
|
||||||
|
CONFIG_UART3_RXBUFSIZE=256
|
||||||
CONFIG_UART0_BAUD=38400
|
CONFIG_UART0_BAUD=38400
|
||||||
CONFIG_UART1_BAUD=38400
|
CONFIG_UART1_BAUD=38400
|
||||||
|
CONFIG_UART2_BAUD=38400
|
||||||
|
CONFIG_UART3_BAUD=38400
|
||||||
CONFIG_UART0_BITS=8
|
CONFIG_UART0_BITS=8
|
||||||
CONFIG_UART1_BITS=8
|
CONFIG_UART1_BITS=8
|
||||||
|
CONFIG_UART2_BITS=8
|
||||||
|
CONFIG_UART3_BITS=8
|
||||||
CONFIG_UART0_PARITY=0
|
CONFIG_UART0_PARITY=0
|
||||||
CONFIG_UART1_PARITY=0
|
CONFIG_UART1_PARITY=0
|
||||||
|
CONFIG_UART2_PARITY=0
|
||||||
|
CONFIG_UART3_PARITY=0
|
||||||
CONFIG_UART0_2STOP=0
|
CONFIG_UART0_2STOP=0
|
||||||
CONFIG_UART1_2STOP=0
|
CONFIG_UART1_2STOP=0
|
||||||
|
CONFIG_UART2_2STOP=0
|
||||||
|
CONFIG_UART3_2STOP=0
|
||||||
|
|
||||||
#
|
#
|
||||||
# General build options
|
# General build options
|
||||||
|
Loading…
Reference in New Issue
Block a user