From b9278cd364531c26504dd5fa8e21e769ae23b979 Mon Sep 17 00:00:00 2001 From: patacongo Date: Wed, 17 Sep 2008 22:12:03 +0000 Subject: [PATCH] Fix LPC2148 PLL setup git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@925 42af7a65-404d-4744-a932-0658087f49c3 --- arch/arm/src/common/up_schedulesigaction.c | 39 ++++++----- arch/arm/src/common/up_sigdeliver.c | 8 +++ arch/arm/src/lpc214x/Make.defs | 7 +- arch/arm/src/lpc214x/Startup.s | 80 ---------------------- arch/arm/src/lpc214x/chip.h | 12 ++++ arch/arm/src/lpc214x/lpc214x_decodeirq.c | 2 + arch/arm/src/lpc214x/lpc214x_head.S | 36 ++++++---- arch/arm/src/lpc214x/lpc214x_lowputc.S | 9 ++- arch/arm/src/lpc214x/lpc214x_uart.h | 2 +- 9 files changed, 81 insertions(+), 114 deletions(-) delete mode 100644 arch/arm/src/lpc214x/Startup.s diff --git a/arch/arm/src/common/up_schedulesigaction.c b/arch/arm/src/common/up_schedulesigaction.c index 1dbecc8e76..a6b2315afa 100644 --- a/arch/arm/src/common/up_schedulesigaction.c +++ b/arch/arm/src/common/up_schedulesigaction.c @@ -1,7 +1,7 @@ -/************************************************************ +/**************************************************************************** * common/up_schedulesigaction.c * - * Copyright (C) 2007 Gregory Nutt. All rights reserved. + * Copyright (C) 2007, 2008 Gregory Nutt. All rights reserved. * Author: Gregory Nutt * * Redistribution and use in source and binary forms, with or without @@ -14,7 +14,7 @@ * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. - * 3. Neither the name Gregory Nutt nor the names of its contributors may be + * 3. Neither the name NuttX nor the names of its contributors may be * used to endorse or promote products derived from this software * without specific prior written permission. * @@ -31,38 +31,43 @@ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * - ************************************************************/ + ****************************************************************************/ -/************************************************************ +/**************************************************************************** * Included Files - ************************************************************/ + ****************************************************************************/ #include + #include #include #include + #include + #include "os_internal.h" #include "up_internal.h" #include "up_arch.h" -/************************************************************ +#ifndef CONFIG_DISABLE_SIGNALS + +/**************************************************************************** * Private Definitions - ************************************************************/ + ****************************************************************************/ -/************************************************************ +/**************************************************************************** * Private Data - ************************************************************/ + ****************************************************************************/ -/************************************************************ +/**************************************************************************** * Private Funtions - ************************************************************/ + ****************************************************************************/ -/************************************************************ +/**************************************************************************** * Public Funtions - ************************************************************/ + ****************************************************************************/ -/************************************************************ +/**************************************************************************** * Name: up_schedule_sigaction * * Description: @@ -93,7 +98,7 @@ * currently executing task -- just call the signal * handler now. * - ************************************************************/ + ****************************************************************************/ void up_schedule_sigaction(_TCB *tcb, sig_deliver_t sigdeliver) { @@ -188,3 +193,5 @@ void up_schedule_sigaction(_TCB *tcb, sig_deliver_t sigdeliver) irqrestore(flags); } } + +#endif /* !CONFIG_DISABLE_SIGNALS */ diff --git a/arch/arm/src/common/up_sigdeliver.c b/arch/arm/src/common/up_sigdeliver.c index 4b2f1c27b6..04202b1a4f 100644 --- a/arch/arm/src/common/up_sigdeliver.c +++ b/arch/arm/src/common/up_sigdeliver.c @@ -38,15 +38,20 @@ ****************************************************************************/ #include + #include #include #include + #include #include + #include "os_internal.h" #include "up_internal.h" #include "up_arch.h" +#ifndef CONFIG_DISABLE_SIGNALS + /**************************************************************************** * Definitions ****************************************************************************/ @@ -135,3 +140,6 @@ void up_sigdeliver(void) up_fullcontextrestore(regs); #endif } + +#endif /* !CONFIG_DISABLE_SIGNALS */ + diff --git a/arch/arm/src/lpc214x/Make.defs b/arch/arm/src/lpc214x/Make.defs index 40b0c44300..6b10e4bada 100644 --- a/arch/arm/src/lpc214x/Make.defs +++ b/arch/arm/src/lpc214x/Make.defs @@ -40,10 +40,13 @@ CMN_CSRCS = up_allocateheap.c up_assert.c up_blocktask.c up_copystate.c \ up_createstack.c up_dataabort.c up_mdelay.c up_udelay.c \ up_exit.c up_idle.c up_initialize.c up_initialstate.c \ up_interruptcontext.c up_prefetchabort.c up_releasepending.c \ - up_releasestack.c up_reprioritizertr.c up_schedulesigaction.c \ - up_sigdeliver.c up_syscall.c up_unblocktask.c \ + up_releasestack.c up_reprioritizertr.c up_syscall.c up_unblocktask.c \ up_undefinedinsn.c up_usestack.c +ifneq ($(CONFIG_DISABLE_SIGNALS),y) +CMN_CSRCS += up_schedulesigaction.c up_sigdeliver.c +endif + CHIP_ASRCS = lpc214x_lowputc.S CHIP_CSRCS = lpc214x_decodeirq.c lpc214x_irq.c lpc214x_timerisr.c \ lpc214x_serial.c diff --git a/arch/arm/src/lpc214x/Startup.s b/arch/arm/src/lpc214x/Startup.s deleted file mode 100644 index ecf692747c..0000000000 --- a/arch/arm/src/lpc214x/Startup.s +++ /dev/null @@ -1,80 +0,0 @@ -/* - * The STARTUP.S code is executed after CPU Reset. This file may be - * translated with the following SET symbols. In uVision these SET - * symbols are entered under Options - ASM - Set. - * - * REMAP: when set the startup code initializes the register MEMMAP - * which overwrites the settings of the CPU configuration pins. The - * startup and interrupt vectors are remapped from: - * 0x00000000 default setting (not remapped) - * 0x80000000 when EXTMEM_MODE is used - * 0x40000000 when RAM_MODE is used - * - * EXTMEM_MODE: when set the device is configured for code execution - * from external memory starting at address 0x80000000. The startup - * vectors are located to 0x80000000. - * - * RAM_MODE: when set the device is configured for code execution - * from on-chip RAM starting at address 0x40000000. The startup - * vectors are located to 0x40000000. - */ - -Reset_Handler: - - - -/* Memory Mapping */ - - -/* Setup Stack for each mode */ - ldr r0, =Top_Stack - -/* Enter Undefined Instruction Mode and set its Stack Pointer */ - msr CPSR_c, #UND_MODE | PSR_I_BIT | PSR_F_BIT - mov SP, r0 - sub r0, r0, #UND_Stack_Size - -/* Enter Abort Mode and set its Stack Pointer */ - msr CPSR_c, #ABT_MODE | PSR_I_BIT | PSR_F_BIT - mov SP, r0 - sub r0, r0, #ABT_Stack_Size - -/* Enter FIQ Mode and set its Stack Pointer */ - msr CPSR_c, #FIQ_MODE | PSR_I_BIT | PSR_F_BIT - mov SP, r0 - sub r0, r0, #FIQ_Stack_Size - -/* Enter IRQ Mode and set its Stack Pointer */ - msr CPSR_c, #IRQ_MODE | PSR_I_BIT | PSR_F_BIT - mov SP, r0 - sub r0, r0, #IRQ_Stack_Size - -/* Enter Supervisor Mode and set its Stack Pointer */ - msr CPSR_c, #SVC_MODE | PSR_I_BIT | PSR_F_BIT - mov SP, r0 - sub r0, r0, #SVC_Stack_Size - -/* Enter User Mode and set its Stack Pointer */ - msr CPSR_c, #USR_MODE - mov SP, r0 - -/* Enter the C code */ - ldr r0,=?C?INIT - tst r0,#1 ; Bit-0 set: INIT is Thumb - ldreq LR,=exit?A ; ARM Mode - ldrne LR,=exit?T ; Thumb Mode - bx r0 - ENDP - -PUBLIC exit?A -exit?A PROC CODE32 - B exit?A - ENDP - -PUBLIC exit?T -exit?T PROC CODE16 -exit: B exit?T - ENDP - - - END diff --git a/arch/arm/src/lpc214x/chip.h b/arch/arm/src/lpc214x/chip.h index d237b39ccb..2d78d8b8cb 100644 --- a/arch/arm/src/lpc214x/chip.h +++ b/arch/arm/src/lpc214x/chip.h @@ -256,8 +256,20 @@ #define LPC214X_PLL_CFG_MSEL (0x1f << 0) /* PLL Multiplier */ #define LPC214X_PLL_CFG_PSEL (0x03 << 5) /* PLL Divider */ + +/* PLL Status Register Bit Settings */ + +#define LPC214X_PLL_STAT_MSEL (0x1f << 0) /* PLL Multiplier Readback */ +#define LPC214X_PLL_STAT_PSEL (0x03 << 5) /* PLL Divider Readback */ +#define LPC214X_PLL_STAT_PLLE (1 << 8) /* PLL Enable Readback */ +#define LPC214X_PLL_STAT_PLLC (1 << 9) /* PLL Connect Readback */ #define LPC214X_PLL_STAT_PLOCK (1 << 10) /* PLL Lock Status */ +/* PLL Feed Register values */ + +#define LPC214X_PLL_FEED1 0xaa +#define LPC214X_PLL_FEED2 0x55 + /* Power Control register offsets */ #define LPC214X_PCON_OFFSET 0x00 /* Control Register */ diff --git a/arch/arm/src/lpc214x/lpc214x_decodeirq.c b/arch/arm/src/lpc214x/lpc214x_decodeirq.c index 6ee78e68c1..12ae2354fd 100644 --- a/arch/arm/src/lpc214x/lpc214x_decodeirq.c +++ b/arch/arm/src/lpc214x/lpc214x_decodeirq.c @@ -67,7 +67,9 @@ /* This type arry maps 4 bits into the bit number of the lowest bit that it set */ +#ifndef CONFIG_SUPPRESS_INTERRUPTS static uint8 g_nibblemap[16] = { 0, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0 }; +#endif /******************************************************************************** * Private Functions diff --git a/arch/arm/src/lpc214x/lpc214x_head.S b/arch/arm/src/lpc214x/lpc214x_head.S index b3c2a9ee69..117ca6a1fa 100644 --- a/arch/arm/src/lpc214x/lpc214x_head.S +++ b/arch/arm/src/lpc214x/lpc214x_head.S @@ -38,6 +38,8 @@ *****************************************************************************/ #include + +#include "chip.h" #include "up_internal.h" #include "up_arch.h" @@ -92,6 +94,12 @@ # define CONFIG_PLLCFG_VALUE 0x00000024 #endif +/* PLL Control register */ + +#ifndef CONFIG_PLLCON_VALUE /* Can be selected from config file */ +# define CONFIG_PLLCON_VALUE LPC214X_PLL_CON_PLLE +#endif + /* Memory Accelerator Module (MAM) initialization values * * MAM Control Register @@ -265,32 +273,32 @@ /* Configure the PLL */ .macro configpll, base, val1, val2, val3 -#ifdef LPC214X_PLL_SETUP +#ifdef CONFIG_PLL_SETUP ldr \base, =LPC214X_PLL_BASE - mov \val1, #0xaa - mov \val2, #0x55 + mov \val1, #LPC214X_PLL_FEED1 + mov \val2, #LPC214X_PLL_FEED2 /* Configure and Enable PLL */ mov \val3, #CONFIG_PLLCFG_VALUE - str \val3, [\base, #LPC214X_PLLCFG_OFFSET] - mov \val3, #LPC214X_PLLCON_PLLE - str \val3, [\base, #LPC214X_PLLCON_OFFSET] - str \val1, [\base, #LPC214X_PLLFEED_OFFSET] - str \val2, [\base, #LPC214X_PLLFEED_OFFSET] + str \val3, [\base, #LPC214X_PLL_CFG_OFFSET] + mov \val3, #CONFIG_PLLCON_VALUE + str \val3, [\base, #LPC214X_PLL_CON_OFFSET] + str \val1, [\base, #LPC214X_PLL_FEED_OFFSET] + str \val2, [\base, #LPC214X_PLL_FEED_OFFSET] /* Wait until PLL Locked */ 1: - ldr \val3, [\base, #LPC214X_PLLSTAT_OFFSET] - ands \val3, \val3, #LPC214X_PLLSTAT_PLOCK + ldr \val3, [\base, #LPC214X_PLL_STAT_OFFSET] + ands \val3, \val3, #LPC214X_PLL_STAT_PLOCK beq 1b /* Switch to PLL Clock */ - mov \val3, #(LPC214X_PLLCON_PLLE | LPC214X_PLLCON_PLLC) - str \val3, [\base, #LPC214X_PLLCON__OFFSET] - str \val1, [\base, #LPC214X_PLLFEED_OFFSET] - str \val2, [\base, #LPC214X_PLLFEED_OFFSET] + mov \val3, #(LPC214X_PLL_CON_PLLE | LPC214X_PLL_CON_PLLC) + str \val3, [\base, #LPC214X_PLL_CON_OFFSET] + str \val1, [\base, #LPC214X_PLL_FEED_OFFSET] + str \val2, [\base, #LPC214X_PLL_FEED_OFFSET] #endif .endm diff --git a/arch/arm/src/lpc214x/lpc214x_lowputc.S b/arch/arm/src/lpc214x/lpc214x_lowputc.S index 23258fce9c..5e00d15cf4 100644 --- a/arch/arm/src/lpc214x/lpc214x_lowputc.S +++ b/arch/arm/src/lpc214x/lpc214x_lowputc.S @@ -99,6 +99,8 @@ #endif #define LPC214X_LCR_VALUE (LPC214X_LCR_CHAR | LPC214X_LCR_PAR | LPC214X_LCR_STOP) +#define LPC214X_FCR_VALUE (LPC214X_FCR_FIFO_TRIG8 | LPC214X_FCR_TX_FIFO_RESET |\ + LPC214X_FCR_RX_FIFO_RESET | LPC214X_FCR_FIFO_ENABLE) /************************************************************************** * Private Types @@ -174,7 +176,7 @@ up_lowsetup: /* Configure parity, data bits, stop bits and set DLAB=1 */ - ldr r0, =LPC214X_UART0_BASE + ldr r0, =LPC214X_UART_BASE mov r1, #(LPC214X_LCR_VALUE | LPC214X_LCR_DLAB_ENABLE) strb r1, [r0, #LPC214X_UART_LCR_OFFSET] @@ -191,6 +193,11 @@ up_lowsetup: mov r1, #LPC214X_LCR_VALUE strb r1, [r0, #LPC214X_UART_LCR_OFFSET] + /* Configure the FIFOs */ + + mov r1, #LPC214X_FCR_VALUE + strb r1, [r0, #LPC214X_UART_FCR_OFFSET] + /* And return */ mov pc, lr diff --git a/arch/arm/src/lpc214x/lpc214x_uart.h b/arch/arm/src/lpc214x/lpc214x_uart.h index e87c7cb288..9e5b6883d2 100755 --- a/arch/arm/src/lpc214x/lpc214x_uart.h +++ b/arch/arm/src/lpc214x/lpc214x_uart.h @@ -78,7 +78,7 @@ /* FIFO Control Register (FCR) bit definitions */ -#define LPC214X_FCR_FIFO_ENABLE (1 << 0) /* FIFO wnable */ +#define LPC214X_FCR_FIFO_ENABLE (1 << 0) /* FIFO enable */ #define LPC214X_FCR_RX_FIFO_RESET (1 << 1) /* Reset receive FIFO */ #define LPC214X_FCR_TX_FIFO_RESET (1 << 2) /* Reset transmit FIFO */ #define LPC214X_FCR_FIFO_TRIG1 (0 << 6) /* Trigger @1 character in FIFO */