Working on HCS12 build
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@2323 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
63447fc718
commit
e032d51cb5
7 changed files with 252 additions and 51 deletions
|
|
@ -939,12 +939,12 @@ static boolean up_txready(struct uart_dev_s *dev)
|
|||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: up_serialinit
|
||||
* Name: up_earlyserialinit
|
||||
*
|
||||
* Description:
|
||||
* Performs the low level USART initialization early in
|
||||
* debug so that the serial console will be available
|
||||
* during bootup. This must be called before up_serialinit.
|
||||
* Performs the low level USART initialization early in debug so that the
|
||||
* serial console will be available during bootup. This must be called
|
||||
* before up_serialinit.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
|
|
|
|||
|
|
@ -36,7 +36,10 @@
|
|||
HEAD_ASRC = mc9s12ne64_vectors.S
|
||||
|
||||
CMN_ASRCS =
|
||||
CMN_CSRCS =
|
||||
CMN_CSRCS = up_allocateheap.c up_createstack.c up_idle.c up_initialize.c \
|
||||
up_interruptcontext.c up_mdelay.c up_modifyreg16.c \
|
||||
up_modifyreg32.c up_modifyreg8.c up_puts.c up_releasestack.c \
|
||||
up_udelay.c up_usestack.c
|
||||
|
||||
CHIP_ASRCS = mc9s12ne64_start.S mc9s12ne64_lowputc.S
|
||||
CHIP_CSRCS =
|
||||
CHIP_CSRCS = mc9s12ne64_serial.c
|
||||
|
|
|
|||
|
|
@ -98,6 +98,7 @@ up_lowputc:
|
|||
jmp PutChar
|
||||
#else
|
||||
# error "up_lowputc not implemented"
|
||||
rts
|
||||
#endif
|
||||
.size up_lowputc, . - up_lowputc
|
||||
.end
|
||||
|
|
|
|||
176
arch/hc/src/mc9s12ne64/mc9s12ne64_serial.c
Executable file
176
arch/hc/src/mc9s12ne64/mc9s12ne64_serial.c
Executable file
|
|
@ -0,0 +1,176 @@
|
|||
/****************************************************************************
|
||||
* arch/hc/src/mc9s12ne64/mc9s12ne64_serial.c
|
||||
*
|
||||
* Copyright (C) 2009 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 NuttX 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.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <sys/types.h>
|
||||
|
||||
#include "up_internal.h"
|
||||
|
||||
/****************************************************************************
|
||||
* Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/* Some sanity checks *******************************************************/
|
||||
|
||||
/* Is there an SCI enabled? */
|
||||
|
||||
#if !defined(CONFIG_HCS12_SCI0) && !defined(CONFIG_HCS12_SCI1)
|
||||
# undef HAVE_SERIAL
|
||||
#else
|
||||
# define HAVE_SERIAL 1
|
||||
#endif
|
||||
|
||||
/* Is there a serial console? Need to have (1) at least SCI enabled, and (2)
|
||||
* serial console and file descriptors selected in the configuration
|
||||
*/
|
||||
|
||||
#if defined(HAVE_SERIAL) && defined(CONFIG_USE_SERIALDRIVER)
|
||||
# if defined(CONFIG_SCI0_SERIAL_CONSOLE) && defined(CONFIG_HCS12_SCI0)
|
||||
# undef CONFIG_SCI1_SERIAL_CONSOLE
|
||||
# define HAVE_SERIAL_CONSOLE 1
|
||||
# elif defined(CONFIG_SCI1_SERIAL_CONSOLE) && defined(CONFIG_HCS12_SCI1)
|
||||
# undef CONFIG_SCI0_SERIAL_CONSOLE
|
||||
# define HAVE_SERIAL_CONSOLE 1
|
||||
# else
|
||||
# undef CONFIG_SCI0_SERIAL_CONSOLE
|
||||
# undef CONFIG_SCI1_SERIAL_CONSOLE
|
||||
# undef HAVE_SERIAL_CONSOLE
|
||||
# endif
|
||||
#else
|
||||
# undef CONFIG_SCI0_SERIAL_CONSOLE
|
||||
# undef CONFIG_SCI1_SERIAL_CONSOLE
|
||||
# undef HAVE_SERIAL_CONSOLE
|
||||
# undef CONFIG_USE_SERIALDRIVER
|
||||
# undef CONFIG_USE_EARLYSERIALINIT
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_USE_SERIALDRIVER
|
||||
|
||||
/****************************************************************************
|
||||
* Private Types
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Function Prototypes
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Variables
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: up_earlyserialinit
|
||||
*
|
||||
* Description:
|
||||
* Performs the low level SCI initialization early in debug so that the
|
||||
* serial console will be available during bootup. This must be called
|
||||
* before up_serialinit.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef CONFIG_USE_EARLYSERIALINIT
|
||||
void up_earlyserialinit(void)
|
||||
{
|
||||
#error "Serial support not-implemented"
|
||||
}
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Name: up_serialinit
|
||||
*
|
||||
* Description:
|
||||
* Register serial console and serial ports. This assumes
|
||||
* that up_earlyserialinit was called previously.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
void up_serialinit(void)
|
||||
{
|
||||
#error "Serial support not-implemented"
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: up_putc
|
||||
*
|
||||
* Description:
|
||||
* Provide priority, low-level access to support OS debug writes
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int up_putc(int ch)
|
||||
{
|
||||
#error "Serial support not-implemented"
|
||||
}
|
||||
|
||||
#else /* CONFIG_USE_SERIALDRIVER */
|
||||
|
||||
/****************************************************************************
|
||||
* Name: up_putc
|
||||
*
|
||||
* Description:
|
||||
* Provide priority, low-level access to support OS debug writes
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int up_putc(int ch)
|
||||
{
|
||||
#ifdef CONFIG_ARCH_LOWPUTC
|
||||
/* Check for LF */
|
||||
|
||||
if (ch == '\n')
|
||||
{
|
||||
/* Add CR */
|
||||
|
||||
up_lowputc('\r');
|
||||
}
|
||||
|
||||
up_lowputc(ch);
|
||||
#endif
|
||||
return ch;
|
||||
}
|
||||
|
||||
#endif /* CONFIG_USE_SERIALDRIVER */
|
||||
|
|
@ -264,24 +264,29 @@ HCS12/DEMO9S12NEC64-specific Configuration Options
|
|||
in this configuration: pages 3e, 3d, then 3f will appear as a
|
||||
contiguous address space in memory.
|
||||
|
||||
HCS12 Sub-system support
|
||||
|
||||
CONFIG_HCS12_SCI0
|
||||
CONFIG_HCS12_SCI1
|
||||
|
||||
HCS12 specific device driver settings:
|
||||
|
||||
CONFIG_SCIO_SERIAL_CONSOLE - selects the SCIO for the
|
||||
console and ttys0 (default is the UART0).
|
||||
CONFIG_SCIn_SERIAL_CONSOLE - selects SCIn for the console and ttys0
|
||||
(default is the SCI0).
|
||||
|
||||
CONFIG_SCIO_RXBUFSIZE - Characters are buffered as received.
|
||||
CONFIG_SCIn_RXBUFSIZE - Characters are buffered as received.
|
||||
This specific the size of the receive buffer
|
||||
|
||||
CONFIG_SCIO_TXBUFSIZE - Characters are buffered before
|
||||
CONFIG_SCIn_TXBUFSIZE - Characters are buffered before
|
||||
being sent. This specific the size of the transmit buffer
|
||||
|
||||
CONFIG_SCIO_BAUD - The configure BAUD of the UART.
|
||||
CONFIG_SCIn_BAUD - The configure BAUD of the UART.
|
||||
|
||||
CONFIG_SCIO_BITS - The number of bits. Must be either 7 or 8.
|
||||
CONFIG_SCIn_BITS - The number of bits. Must be either 7 or 8.
|
||||
|
||||
CONFIG_SCIO_PARTIY - 0=no parity, 1=odd parity, 2=even parity, 3=mark 1, 4=space 0
|
||||
CONFIG_SCIn_PARTIY - 0=no parity, 1=odd parity, 2=even parity, 3=mark 1, 4=space 0
|
||||
|
||||
CONFIG_SCIO_2STOP - Two stop bits
|
||||
CONFIG_SCIn_2STOP - Two stop bits
|
||||
|
||||
Configurations
|
||||
^^^^^^^^^^^^^^
|
||||
|
|
|
|||
|
|
@ -33,7 +33,7 @@
|
|||
#
|
||||
############################################################################
|
||||
#
|
||||
# architecture selection
|
||||
# Architecture selection
|
||||
#
|
||||
# CONFIG_ARCH - identifies the arch subdirectory and, hence, the
|
||||
# processor architecture.
|
||||
|
|
@ -80,10 +80,10 @@ CONFIG_BOARD_LOOPSPERMSEC=5483
|
|||
CONFIG_DRAM_SIZE=0x00010000
|
||||
CONFIG_DRAM_START=0x20000000
|
||||
CONFIG_DRAM_END=(CONFIG_DRAM_START+CONFIG_DRAM_SIZE)
|
||||
CONFIG_ARCH_IRQPRIO=y
|
||||
CONFIG_ARCH_IRQPRIO=n
|
||||
CONFIG_ARCH_INTERRUPTSTACK=n
|
||||
CONFIG_ARCH_STACKDUMP=y
|
||||
CONFIG_ARCH_BOOTLOADER=n
|
||||
CONFIG_ARCH_BOOTLOADER=y
|
||||
CONFIG_ARCH_LEDS=y
|
||||
CONFIG_ARCH_BUTTONS=n
|
||||
CONFIG_ARCH_CALIBRATION=n
|
||||
|
|
@ -104,27 +104,41 @@ CONFIG_ARCH_DMA=n
|
|||
CONFIG_HCS12_SERIALMON=y
|
||||
CONFIG_HCS12_NONBANKED=y
|
||||
|
||||
#
|
||||
# CS12 Sub-system support
|
||||
#
|
||||
CONFIG_HCS12_SCI0=n
|
||||
CONFIG_HCS12_SCI1=n
|
||||
|
||||
#
|
||||
# MC9S12NEC64 specific serial device driver settings
|
||||
#
|
||||
# CONFIG_SCIO_SERIAL_CONSOLE - selects the SCIO for the
|
||||
# console and ttys0 (default is the SCIO).
|
||||
# CONFIG_SCIO_RXBUFSIZE - Characters are buffered as received.
|
||||
# CONFIG_SCIn_SERIAL_CONSOLE - selects SCIn for the
|
||||
# console and ttys0 (default is the SCIn).
|
||||
# CONFIG_SCIn_RXBUFSIZE - Characters are buffered as received.
|
||||
# This specific the size of the receive buffer
|
||||
# CONFIG_SCIO_TXBUFSIZE - Characters are buffered before
|
||||
# CONFIG_SCIn_TXBUFSIZE - Characters are buffered before
|
||||
# being sent. This specific the size of the transmit buffer
|
||||
# CONFIG_SCIO_BAUD - The configure BAUD of the UART. Must be
|
||||
# CONFIG_SCIO_BITS - The number of bits. Must be either 7 or 8.
|
||||
# CONFIG_SCIO_PARTIY - 0=no parity, 1=odd parity, 2=even parity
|
||||
# CONFIG_SCIO_2STOP - Two stop bits
|
||||
# CONFIG_SCIn_BAUD - The configure BAUD of the UART. Must be
|
||||
# CONFIG_SCIn_BITS - The number of bits. Must be either 7 or 8.
|
||||
# CONFIG_SCIn_PARTIY - 0=no parity, 1=odd parity, 2=even parity
|
||||
# CONFIG_SCIn_2STOP - Two stop bits
|
||||
#
|
||||
CONFIG_SCIO_SERIAL_CONSOLE=y
|
||||
CONFIG_SCIO_TXBUFSIZE=32
|
||||
CONFIG_SCIO_RXBUFSIZE=32
|
||||
CONFIG_SCIO_BAUD=115200
|
||||
CONFIG_SCIO_BITS=8
|
||||
CONFIG_SCIO_PARITY=0
|
||||
CONFIG_SCIO_2STOP=0
|
||||
CONFIG_SCI0_SERIAL_CONSOLE=n
|
||||
CONFIG_SCI0_TXBUFSIZE=32
|
||||
CONFIG_SCI0_RXBUFSIZE=32
|
||||
CONFIG_SCI0_BAUD=115200
|
||||
CONFIG_SCI0_BITS=8
|
||||
CONFIG_SCI0_PARITY=0
|
||||
CONFIG_SCI0_2STOP=0
|
||||
|
||||
CONFIG_SCI1_SERIAL_CONSOLE=n
|
||||
CONFIG_SCI1_TXBUFSIZE=32
|
||||
CONFIG_SCI1_RXBUFSIZE=32
|
||||
CONFIG_SCI1_BAUD=115200
|
||||
CONFIG_SCI1_BITS=8
|
||||
CONFIG_SCI1_PARITY=0
|
||||
CONFIG_SCI1_2STOP=0
|
||||
|
||||
#
|
||||
# MC9S12NEC64 specific SSI device driver settings
|
||||
|
|
@ -272,8 +286,8 @@ CONFIG_START_MONTH=12
|
|||
CONFIG_START_DAY=11
|
||||
CONFIG_GREGORIAN_TIME=n
|
||||
CONFIG_JULIAN_TIME=n
|
||||
CONFIG_DEV_CONSOLE=y
|
||||
CONFIG_DEV_LOWCONSOLE=y
|
||||
CONFIG_DEV_CONSOLE=n
|
||||
CONFIG_DEV_LOWCONSOLE=n
|
||||
CONFIG_MUTEX_TYPES=n
|
||||
CONFIG_PRIORITY_INHERITANCE=n
|
||||
CONFIG_SEM_PREALLOCHOLDERS=0
|
||||
|
|
@ -303,11 +317,11 @@ CONFIG_SIG_SIGWORK=4
|
|||
# o pthread_condtimedwait() depends on signals to wake
|
||||
# up waiting tasks.
|
||||
#
|
||||
CONFIG_DISABLE_CLOCK=n
|
||||
CONFIG_DISABLE_POSIX_TIMERS=n
|
||||
CONFIG_DISABLE_PTHREAD=n
|
||||
CONFIG_DISABLE_SIGNALS=n
|
||||
CONFIG_DISABLE_MQUEUE=n
|
||||
CONFIG_DISABLE_CLOCK=y
|
||||
CONFIG_DISABLE_POSIX_TIMERS=y
|
||||
CONFIG_DISABLE_PTHREAD=y
|
||||
CONFIG_DISABLE_SIGNALS=y
|
||||
CONFIG_DISABLE_MQUEUE=y
|
||||
CONFIG_DISABLE_MOUNTPOINT=y
|
||||
CONFIG_DISABLE_ENVIRON=y
|
||||
CONFIG_DISABLE_POLL=y
|
||||
|
|
@ -318,7 +332,7 @@ CONFIG_DISABLE_POLL=y
|
|||
# CONFIG_NOPRINTF_FIELDWIDTH - sprintf-related logic is a
|
||||
# little smaller if we do not support fieldwidthes
|
||||
#
|
||||
CONFIG_NOPRINTF_FIELDWIDTH=n
|
||||
CONFIG_NOPRINTF_FIELDWIDTH=y
|
||||
|
||||
#
|
||||
# Allow for architecture optimized implementations
|
||||
|
|
@ -374,19 +388,19 @@ CONFIG_ARCH_KFREE=n
|
|||
# timer structures to minimize dynamic allocations. Set to
|
||||
# zero for all dynamic allocations.
|
||||
#
|
||||
CONFIG_MAX_TASKS=16
|
||||
CONFIG_MAX_TASKS=8
|
||||
CONFIG_MAX_TASK_ARGS=4
|
||||
CONFIG_NPTHREAD_KEYS=4
|
||||
CONFIG_NFILE_DESCRIPTORS=8
|
||||
CONFIG_NFILE_STREAMS=8
|
||||
CONFIG_NPTHREAD_KEYS=0
|
||||
CONFIG_NFILE_DESCRIPTORS=0
|
||||
CONFIG_NFILE_STREAMS=0
|
||||
CONFIG_NAME_MAX=32
|
||||
CONFIG_STDIO_BUFFER_SIZE=256
|
||||
CONFIG_NUNGET_CHARS=2
|
||||
CONFIG_PREALLOC_MQ_MSGS=4
|
||||
CONFIG_MQ_MAXMSGSIZE=32
|
||||
CONFIG_STDIO_BUFFER_SIZE=0
|
||||
CONFIG_NUNGET_CHARS=0
|
||||
CONFIG_PREALLOC_MQ_MSGS=0
|
||||
CONFIG_MQ_MAXMSGSIZE=0
|
||||
CONFIG_MAX_WDOGPARMS=2
|
||||
CONFIG_PREALLOC_WDOGS=4
|
||||
CONFIG_PREALLOC_TIMERS=4
|
||||
CONFIG_PREALLOC_TIMERS=0
|
||||
|
||||
#
|
||||
# Filesystem configuration
|
||||
|
|
@ -394,6 +408,7 @@ CONFIG_PREALLOC_TIMERS=4
|
|||
# CONFIG_FS_FAT - Enable FAT filesystem support
|
||||
# CONFIG_FAT_SECTORSIZE - Max supported sector size
|
||||
# CONFIG_FS_ROMFS - Enable ROMFS filesystem support
|
||||
#
|
||||
CONFIG_FS_FAT=n
|
||||
CONFIG_FS_ROMFS=n
|
||||
|
||||
|
|
|
|||
|
|
@ -210,7 +210,7 @@ CONFIG_NOPRINTF_FIELDWIDTH=y
|
|||
# Allow for architecture optimized implementations
|
||||
#
|
||||
# The architecture can provide optimized versions of the
|
||||
# following to improve sysem performance
|
||||
# following to improve system performance
|
||||
#
|
||||
CONFIG_ARCH_MEMCPY=n
|
||||
CONFIG_ARCH_MEMCMP=n
|
||||
|
|
@ -229,7 +229,7 @@ CONFIG_ARCH_KFREE=n
|
|||
# Sizes of configurable things (0 disables)
|
||||
#
|
||||
# CONFIG_MAX_TASKS - The maximum number of simultaneously
|
||||
# actived tasks. This value must be a power of two.
|
||||
# active tasks. This value must be a power of two.
|
||||
# CONFIG_MAX_TASK_ARGS - This controls the maximum number of
|
||||
# of parameters that a task may receive (i.e., maxmum value
|
||||
# of 'argc')
|
||||
|
|
@ -300,6 +300,7 @@ CONFIG_PREALLOC_TIMERS=0
|
|||
# CONFIG_NET_BROADCAST - Broadcast support
|
||||
# CONFIG_NET_LLH_LEN - The link level header length
|
||||
# CONFIG_NET_FWCACHE_SIZE - number of packets to remember when looking for duplicates
|
||||
#
|
||||
CONFIG_NET=n
|
||||
CONFIG_NET_IPv6=n
|
||||
CONFIG_NSOCKET_DESCRIPTORS=0
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue