Progress with C5471 boot

git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@8 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
patacongo 2007-02-19 20:41:40 +00:00
parent b0611894f6
commit c79c1af172
13 changed files with 1423 additions and 57 deletions

View File

@ -43,6 +43,37 @@ CONFIG_ARCH=c5471
CONFIG_ARCH_C5471=y CONFIG_ARCH_C5471=y
CONFIG_ROM_VECTORS=n CONFIG_ROM_VECTORS=n
#
# C5471 specific device driver settings
#
# CONFIG_SERIAL_IRDA_CONSOLE - selects the IRDA UART for the
# console ant ttys0 (default is the modem UART).
# CONFIG_UART_*_HWFLOWCONTROL - enables hardware flow control
# CONFIG_UART_*_RXBUFSIZE - Characters are buffered as received.
# This specific the size of the receive buffer
# CONFIG_UART_*_TXBUFSIZE - Characters are buffered before
# being sent. This specific the size of the transmit buffer
# CONFIG_UART_*_BAUD - The configure BAUD of the UART. Must be
# CONFIG_UART_*_BITS - The number of bits. Must be either 7 or 8.
# CONFIG_UART_*_PARTIY - 0=no parity, 1=odd parity, 2=even parity
# CONFIG_UART_*_2STOP - Two stop bits
#
CONFIG_SERIAL_IRDA_CONSOLE=n
CONFIG_UART_IRDA_HWFLOWCONTROL=y
CONFIG_UART_MODEM_HWFLOWCONTROL=y
CONFIG_UART_IRDA_RXBUFSIZE=256
CONFIG_UART_MODEM_RXBUFSIZE=256
CONFIG_UART_IRDA_TXBUFSIZE=256
CONFIG_UART_MODEM_TXBUFSIZE=256
CONFIG_UART_IRDA_BAUD=115200
CONFIG_UART_MODEM_BAUD=115200
CONFIG_UART_IRDA_BITS=8
CONFIG_UART_MODEM_BITS=8
CONFIG_UART_IRDA_PARITY=0
CONFIG_UART_MODEM_PARITY=0
CONFIG_UART_IRDA_2STOP=0
CONFIG_UART_MODEM_2STOP=0
# #
# General OS setup # General OS setup
# #
@ -69,7 +100,7 @@ CONFIG_ROM_VECTORS=n
CONFIG_EXAMPLE=ostest CONFIG_EXAMPLE=ostest
CONFIG_DEBUG=y CONFIG_DEBUG=y
CONFIG_DEBUG_VERBOSE=n CONFIG_DEBUG_VERBOSE=n
CONFIG_ARCH_LOWPUTC=n CONFIG_ARCH_LOWPUTC=y
CONFIG_RR_INTERVAL=200 CONFIG_RR_INTERVAL=200
CONFIG_SCHED_INSTRUMENTATION=n CONFIG_SCHED_INSTRUMENTATION=n
CONFIG_TASK_NAME_SIZE=0 CONFIG_TASK_NAME_SIZE=0
@ -77,7 +108,7 @@ CONFIG_START_YEAR=2007
CONFIG_START_MONTH=2 CONFIG_START_MONTH=2
CONFIG_START_DAY=13 CONFIG_START_DAY=13
CONFIG_JULIAN_TIME=n CONFIG_JULIAN_TIME=n
CONFIG_DEV_CONSOLE=n CONFIG_DEV_CONSOLE=y
# #
# Allow for artchitecture optimized implementations # Allow for artchitecture optimized implementations
@ -157,9 +188,9 @@ CONFIG_PREALLOC_WDOGS=32
# CONFIG_HEAP_SIZE - The size of the heap # CONFIG_HEAP_SIZE - The size of the heap
# #
CONFIG_BOOT_FROM_FLASH=n CONFIG_BOOT_FROM_FLASH=n
CONFIG_STACK_POINTER=0x02100000 CONFIG_STACK_POINTER=
CONFIG_PROC_STACK_SIZE=0x00001000 CONFIG_PROC_STACK_SIZE=4096
CONFIG_PTHREAD_STACK_MIN=256 CONFIG_PTHREAD_STACK_MIN=256
CONFIG_PTHREAD_STACK_DEFAULT=4096 CONFIG_PTHREAD_STACK_DEFAULT=4096
CONFIG_HEAP_BASE=0x02100000 CONFIG_HEAP_BASE=(0x10300000+90*1024+4096)
CONFIG_HEAP_SIZE=0x00100000 CONFIG_HEAP_SIZE=(0x11000000-CONFIG_HEAP_BASE)

View File

@ -120,7 +120,7 @@
#define C5471_IRQ_API 15 #define C5471_IRQ_API 15
#define C5471_IRQ_WATCHDOG C5471_IRQ_TIMER0 #define C5471_IRQ_WATCHDOG C5471_IRQ_TIMER0
#define C5471_IRQ_SYSTIMER C5471_IRQ_TIMER1 #define C5471_IRQ_SYSTIMER C5471_IRQ_TIMER2
#define NR_IRQS (C5471_IRQ_API+1) #define NR_IRQS (C5471_IRQ_API+1)
/************************************************************ /************************************************************

View File

@ -0,0 +1,66 @@
/************************************************************
* serial.h
*
* Copyright (C) 2007 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* 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
* used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
************************************************************/
#ifndef __ARCH_SERIAL_H
#define __ARCH_SERIAL_H
/************************************************************
* Included Files
************************************************************/
/************************************************************
* Definitions
************************************************************/
/* IOCTL commands supported by the C5471 serial driver */
#define TIOCSBRK 0x5401 /* BSD compatibility */
#define TIOCCBRK 0x5402 /* " " " " */
#define TIOCSERCONFIG 0x5403 /* Reconfigure the port */
#define TIOCSERGSTRUCT 0x5458 /* Get up_dev_t for port */
/************************************************************
* Private Data
************************************************************/
/************************************************************
* Private Functions
************************************************************/
/************************************************************
* Public Functions
************************************************************/
#endif /* __ARCH_SERIAL_H */

View File

@ -62,7 +62,7 @@ SECTIONS
/* The OS entry point is here */ /* The OS entry point is here */
. = 0x01030000; . = 0x10300000;
.text : { .text : {
_stext = ABSOLUTE(.); _stext = ABSOLUTE(.);
*(.text) *(.text)

View File

@ -38,8 +38,10 @@
MKDEP = $(TOPDIR)/tools/mkdeps.sh MKDEP = $(TOPDIR)/tools/mkdeps.sh
CFLAGS += -I$(TOPDIR)/sched CFLAGS += -I$(TOPDIR)/sched
ASRCS = up_vectors.S up_saveusercontext.S up_fullcontextrestore.S \ ASRCS = up_vectors.S up_saveusercontext.S up_fullcontextrestore.S
up_lowputc.S ifeq ($(CONFIG_DEBUG),y)
ASRCS += up_lowputc.S
endif
AOBJS = $(ASRCS:.S=.o) AOBJS = $(ASRCS:.S=.o)
CSRCS = up_initialize.c up_initialstate.c up_idle.c \ CSRCS = up_initialize.c up_initialstate.c up_idle.c \
@ -48,7 +50,7 @@ CSRCS = up_initialize.c up_initialstate.c up_idle.c \
up_createstack.c up_usestack.c up_releasestack.c \ up_createstack.c up_usestack.c up_releasestack.c \
up_exit.c up_assert.c up_blocktask.c up_unblocktask.c \ up_exit.c up_assert.c up_blocktask.c up_unblocktask.c \
up_releasepending.c up_reprioritizertr.c up_copystate.c \ up_releasepending.c up_reprioritizertr.c up_copystate.c \
up_schedulesigaction.c up_sigdeliver.c up_schedulesigaction.c up_sigdeliver.c up_serial.c
COBJS = $(CSRCS:.c=.o) COBJS = $(CSRCS:.c=.o)
SRCS = $(ASRCS) $(CSRCS) SRCS = $(ASRCS) $(CSRCS)

View File

@ -72,6 +72,10 @@
#define CC_Z_BIT (1 << 30) #define CC_Z_BIT (1 << 30)
#define CC_N_BIT (1 << 31) #define CC_N_BIT (1 << 31)
/* Clocking *************************************************/
#define C5471_CLOCK 47500000 /* 47.5 MHz */
/* UARTs ****************************************************/ /* UARTs ****************************************************/
#define UART_IRDA_BASE 0xffff0800 #define UART_IRDA_BASE 0xffff0800

View File

@ -44,6 +44,18 @@
* Definitions * Definitions
************************************************************/ ************************************************************/
/* This macro will modify r0, r1, r2 and r14 */
#ifdef CONFIG_DEBUG
.macro showprogress, code
mov r0, #\code
bl up_lowputc
.endm
#else
.macro showprogress, code
.endm
#endif
/************************************************************ /************************************************************
* OS Entry Point * OS Entry Point
************************************************************/ ************************************************************/
@ -56,24 +68,28 @@
.type __start, #function .type __start, #function
__start: __start:
/* First, setup initial processor mode */ /* First, setup initial processor mode */
mov r0, #(SVC_MODE | I_BIT | F_BIT ) mov r0, #(SVC_MODE | I_BIT | F_BIT )
msr cpsr, r0 msr cpsr, r0
/* Setup system stack (and get the BSS range) */ showprogress 'A'
/* Setup system stack (and get the BSS range) */
adr r0, LC0 adr r0, LC0
ldmia r0, {r4, r5, sp} ldmia r0, {r4, r5, sp}
/* Clear system BSS section */ /* Clear system BSS section */
mov r0, #0 mov r0, #0
1: cmp r4, r5 1: cmp r4, r5
strcc r0, [r4], #4 strcc r0, [r4], #4
bcc 1b bcc 1b
/* Copy system .data sections to new home in RAM. */ showprogress 'B'
/* Copy system .data sections to new home in RAM. */
#ifdef CONFIG_BOOT_FROM_FLASH #ifdef CONFIG_BOOT_FROM_FLASH
@ -86,40 +102,33 @@ __start:
blt 1b blt 1b
#endif #endif
/* Perform early serial initialization */
/* Initialize Kernel Stack Contents */
#if 0
mov r1, sp
sub r1, r1, #INITIAL_STACK_SIZE
ldr r0, L_STACK_MAGIC
str r0, [r1], #4
ldr r0, L_STACK_UNTOUCHED_MAGIC
1: cmp r1, sp
strcc r0, [r1], #4
bcc 1b
#endif
/* Jump to OS entry */
mov fp, #0 mov fp, #0
bl up_earlyserialinit
#ifdef CONFIG_DEBUG
mov r0, #'C'
bl up_putc
mov r0, #'\n'
bl up_putc
#endif
/* Then jump to OS entry */
b os_start b os_start
/* Variables */ /* Variables */
LC0: .long _sbss LC0: .long _sbss
.long _ebss .long _ebss
.long CONFIG_STACK_POINTER+CONFIG_PROC_STACK_SIZE-4 .long _ebss+CONFIG_PROC_STACK_SIZE-4
#ifdef CONFIG_BOOT_FROM_FLASH #ifdef CONFIG_BOOT_FROM_FLASH
LC2: .long _eronly @ Where .data defaults are stored in Flash. LC2: .long _eronly /* Where .data defaults are stored in FLASH */
.long _sdata @ Where .data needs to reside in SDRAM. .long _sdata /* Where .data needs to reside in SDRAM */
.long _edata .long _edata
#endif #endif
#if 0
L_STACK_UNTOUCHED_MAGIC: .long 0xfeef1ef0
L_STACK_MAGIC: .long 0xdeadbeef
#endif
.end .end

View File

@ -41,7 +41,6 @@
#include <sys/types.h> #include <sys/types.h>
#include <debug.h> #include <debug.h>
#include <nuttx/arch.h> #include <nuttx/arch.h>
#include <nuttx/fs.h>
#include "up_internal.h" #include "up_internal.h"
/************************************************************ /************************************************************
@ -86,13 +85,15 @@ void up_initialize(void)
up_irqinitialize(); up_irqinitialize();
/* Attach and enable the timer interrupt */ /* Initialize the system timer interrupt */
up_disable_irq(C5471_IRQ_SYSTIMER); up_timerinit();
irq_attach(C5471_IRQ_SYSTIMER, (xcpt_t)up_timerisr);
up_enable_irq(C5471_IRQ_SYSTIMER);
/* Register devices */ /* Register devices */
devnull_register(); /* Standard /dev/null */ devnull_register(); /* Standard /dev/null */
/* Initialize the serial device driver */
up_serialinit();
} }

View File

@ -84,6 +84,12 @@ extern void up_syscall(uint32 *regs);
extern int up_timerisr(int irq, uint32 *regs); extern int up_timerisr(int irq, uint32 *regs);
extern void up_undefinedinsn(uint32 *regs); extern void up_undefinedinsn(uint32 *regs);
#ifdef CONFIG_DEBUG
extern void up_lowputc(char ch);
#else
# define up_lowputc(ch)
#endif
/* Defined in up_vectors.S */ /* Defined in up_vectors.S */
extern void up_vectorundefinsn(void); extern void up_vectorundefinsn(void);
@ -94,6 +100,15 @@ extern void up_vectoraddrexcptn(void);
extern void up_vectorirq(void); extern void up_vectorirq(void);
extern void up_vectorfiq(void); extern void up_vectorfiq(void);
/* Defined in up_serial.c */
extern void up_earlyserialinit(void);
extern void up_serialinit(void);
/* Defined in up_timerisr.c */
extern void up_timerinit(void);
#endif /* __ASSEMBLY__ */ #endif /* __ASSEMBLY__ */
#endif /* __UP_INTERNAL_H */ #endif /* __UP_INTERNAL_H */

View File

@ -79,7 +79,7 @@
*/ */
.text .text
.global up_putc .global up_lowputc
.type up_lowputc, function .type up_lowputc, function
up_lowputc: up_lowputc:
/* On entry, r0 holds the character to be printed */ /* On entry, r0 holds the character to be printed */

1192
arch/c5471/src/up_serial.c Normal file

File diff suppressed because it is too large Load Diff

View File

@ -41,7 +41,30 @@
#include <sys/types.h> #include <sys/types.h>
#include <debug.h> #include <debug.h>
#include <nuttx/arch.h> #include <nuttx/arch.h>
#include "clock_internal.h"
#include "up_internal.h" #include "up_internal.h"
#include "c5471.h"
/************************************************************
* Definitions
************************************************************/
/* We want the general purpose timer running at the rate
* MSEC_PER_TICK. The C5471 clock is 47.5MHz and we're using
* a timer PTV value of 3 (3 == divide incoming frequency by
* 16) which then yields a 16 bitCLKS_PER_INT value
* of 29687.
*
* 47500000 / 16 = 2968750 clocks/sec
* 2968750 / 100 = 29687 clocks/ 100Hz interrupt
*
*/
#define CLKS_PER_INT 29687
#define CLKS_PER_INT_SHIFT 5
#define AR 0x00000010
#define ST 0x00000008
#define PTV 0x00000003
/************************************************************ /************************************************************
* Private Types * Private Types
@ -91,3 +114,23 @@ int up_timerisr(int irq, uint32 *regs)
current_regs = saved_regs; current_regs = saved_regs;
return 0; return 0;
} }
void up_timerinit(void)
{
uint32 val;
up_disable_irq(C5471_IRQ_SYSTIMER);
/* Start the general purpose timer running in auto-reload mode
* so that an interrupt is generated at the rate MSEC_PER_TICK.
*/
val = ((CLKS_PER_INT-1) << CLKS_PER_INT_SHIFT) | AR | ST | PTV;
putreg32(val, C5471_TIMER2_CTRL);
/* Attach and enable the timer interrupt */
irq_attach(C5471_IRQ_SYSTIMER, (xcpt_t)up_timerisr);
up_enable_irq(C5471_IRQ_SYSTIMER);
}

View File

@ -52,16 +52,26 @@ static char *skip_space(char *ptr)
return ptr; return ptr;
} }
static char *find_end(char *ptr) static char *find_name_end(char *ptr)
{ {
while (*ptr && (isalnum(*ptr) || *ptr == '_')) ptr++; while (*ptr && (isalnum(*ptr) || *ptr == '_')) ptr++;
return ptr; return ptr;
} }
static char *find_comment(char *ptr) static char *find_value_end(char *ptr)
{ {
while (*ptr && *ptr != '"' && *ptr != '\n') ptr++; while (*ptr && !isspace(*ptr))
if (*ptr == '"') ptr++; {
if (*ptr == '"')
{
do ptr++; while (*ptr && *ptr != '"');
if (*ptr) ptr++;
}
else
{
do ptr++; while (*ptr && !isspace(*ptr) && *ptr != '"');
}
}
return ptr; return ptr;
} }
@ -92,7 +102,7 @@ static void parse_line(char *ptr, char **varname, char **varval)
*varname = ptr; *varname = ptr;
*varval = NULL; *varval = NULL;
ptr = find_end(ptr); ptr = find_name_end(ptr);
if (*ptr && *ptr != '=') if (*ptr && *ptr != '=')
{ {
*ptr = '\0'; *ptr = '\0';
@ -106,14 +116,7 @@ static void parse_line(char *ptr, char **varname, char **varval)
if (*ptr) if (*ptr)
{ {
*varval = ptr; *varval = ptr;
if (*ptr == '"') ptr = find_value_end(ptr);
{
ptr = find_comment(ptr);
}
else
{
ptr = find_end(ptr);
}
*ptr = '\0'; *ptr = '\0';
} }
} }