lpc2378 port contributed by Rommel Marcelo

git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@2579 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
patacongo 2010-04-09 01:14:24 +00:00
parent 9c671715e2
commit 2bd1d18f1a
19 changed files with 5021 additions and 2 deletions

View File

@ -1083,3 +1083,6 @@
(incomplete on initial checkin).
* drivers/usbdev - Several important fixes to the USB mass storage driver
submitted by David Hewson.
* configs/olimex-lpc2378, arch/arm/include/lpc2378, and arch/arm/src/lpc2378 -
Basic port of the NXP 2378 on the Olimex board contributed by
Rommel Marcelo.

View File

@ -8,7 +8,7 @@
<tr align="center" bgcolor="#e4e4e4">
<td>
<h1><big><font color="#3c34ec"><i>NuttX RTOS</i></font></big></h1>
<p>Last Updated: April 4, 2010</p>
<p>Last Updated: April 8, 2010</p>
</td>
</tr>
</table>
@ -1664,6 +1664,10 @@ nuttx-5.3 2010-xx-xx Gregory Nutt &lt;spudmonkey@racsa.co.cr&gt;
* arch/arm/src/sam3u/sam3u_hsmci.c - SD memory card support for AT90SAM3U
(incomplete on initial checkin).
* drivers/usbdev - Several important fixes to the USB mass storage driver
submitted by David Hewson.
* configs/olimex-lpc2378, arch/arm/include/lpc2378, and arch/arm/src/lpc2378 -
Basic port of the NXP 2378 on the Olimex board contributed by
Rommel Marcelo.
pascal-2.1 2010-xx-xx Gregory Nutt &lt;spudmonkey@racsa.co.cr&gt;

63
arch/arm/src/lpc2378/Make.defs Executable file
View File

@ -0,0 +1,63 @@
##############################################################################
# lpc23xx/Make.defs
#
# Copyright (C) 2010 Rommel Marcelo. All rights reserved.
# Author: Rommel Marcelo
#
# This file is part of the NuttX RTOS and based on the lpc2148 port:
#
# Copyright (C) 2010 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.
#
##############################################################################
HEAD_ASRC = lpc23xx_head.S
CMN_ASRCS = up_saveusercontext.S up_fullcontextrestore.S up_vectors.S
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_syscall.c up_unblocktask.c \
up_undefinedinsn.c up_usestack.c up_lowputs.c
ifneq ($(CONFIG_DISABLE_SIGNALS),y)
CMN_CSRCS += up_schedulesigaction.c up_sigdeliver.c
endif
CHIP_ASRCS = lpc23xx_lowputc.S
CHIP_CSRCS = lpc23xx_pllsetup.c lpc23xx_decodeirq.c lpc23xx_irq.c lpc23xx_timerisr.c \
lpc23xx_serial.c lpc23xx_io.c
ifeq ($(CONFIG_USBDEV),y)
#CHIP_CSRCS += lpc23xx_usbdev.c
endif

959
arch/arm/src/lpc2378/chip.h Executable file
View File

@ -0,0 +1,959 @@
/****************************************************************************************************
* arch/arm/src/lpc2378/chip.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
****************************************************************************************************/
#ifndef _ARCH_ARM_SRC_LPC2378_CHIP_H
#define _ARCH_ARM_SRC_LPC2378_CHIP_H
/****************************************************************************************************
* Included Files
****************************************************************************************************/
#include <sys/types.h>
/****************************************************************************************************
* Pre-processor Definitions
****************************************************************************************************/
/* Memory Map ***************************************************************************************/
#define LPC23XX_FLASH_BASE 0x00000000
#define LPC23XX_FIO_BASE 0x3fffc000
#define LPC23XX_ONCHIP_RAM_BASE 0x40000000
#define LPC23XX_USBDMA_RAM_BASE 0x7fd00000
#define LPC23XX_ETHERNET_RAM_BASE 0x7fe00000
#define LPC23XX_BOOT_BLOCK 0x7fffd000
#define LPC23XX_EXTMEM_BASE 0x80000000
#define LPC23XX_APB_BASE 0xe0000000
#define LPC23XX_AHB_BASE 0xf0000000
/* Peripheral Registers ****************************************************************************/
/* APB Register block base addresses */
#define LPC23XX_WD_BASE 0xe0000000 /* Watchdog base address */
#define LPC23XX_TMR0_BASE 0xE0004000 /* Timer 0 base address*/
#define LPC23XX_TMR1_BASE 0xe0008000 /* Timer 1 base address */
#define LPC23XX_UART0_BASE 0xe000c000 /* UART0 base address */
#define LPC23XX_UART1_BASE 0xe0010000 /* UART1 base address */
#define LPC23XX_PWM_BASE 0xe0018000 /* Pulse width modulator (PWM) base address */
#define LPC23XX_I2C0_BASE 0xe001c000 /* I2C0 base address */
#define LPC23XX_SPI0_BASE 0xe0020000 /* Serial Peripheral Interface 0 (SPI0) base */
#define LPC23XX_RTC_BASE 0xe0024000 /* Real Time Clock (RTC) base address */
#define LPC23XX_GPIO0_BASE 0xe0028000 /* General Purpose I/O (GPIO) 0 base address */
#define LPC23XX_GPIO1_BASE 0xe0028010 /* General Purpose I/O (GPIO) 1 base address */
#define LPC23XX_PINSEL_BASE 0xe002c000 /* Pin function select registers */
#define LPC23XX_SSP1_BASE 0xe0030000 /* Synchronous Serial Port 1 base address */
#define LPC23XX_AD0_BASE 0xe0034000 /* Analog to Digital Converter 0 base address*/
//~ #define LPC23XX_CAN_ACCEPT_RAM_BASE 0xe0038000 /* CAN Acceptance Filter RAM base address*/
#define LPC23XX_CAN_ACCEPT_BASE 0xE003C000 /* CAN Acceptance Filter Register base address*/
#define LPC23XX_CAN_COMMON_BASE 0xe0040000 /* CAN Common Register base address*/
#define LPC23XX_CAN1_BASE 0xe0044000 /* CAN 1 Controller base address*/
#define LPC23XX_CAN2_BASE 0xe0048000 /* CAN 2 Controller base address*/
#define LPC23XX_I2C1_BASE 0xe005c000 /* I2C1 base address */
#define LPC23XX_SSP0_BASE 0xE0068000 /* Synchronous Serial Port 0 base address */
#define LPC23XX_DAC_BASE 0xE006C000 /* DAC base address */
#define LPC23XX_TMR2_BASE 0xE0070000 /* Timer 2 base address */
#define LPC23XX_TMR3_BASE 0xE0074000 /* Timer 3 base address */
#define LPC23XX_UART2_BASE 0xE0078000 /* UART2 base address */
#define LPC23XX_UART3_BASE 0xE007C000 /* UART3 base address */
#define LPC23XX_I2C2_BASE 0xE0080000 /* I2C2 base address */
#define LPC23XX_BATT_RAM_BASE 0xE0084000 /* Battery RAM base address */
#define LPC23XX_I2S_BASE 0xE0088000 /* I2S base address */
#define LPC23XX_MCI_BASE 0xE008C000 /* SD/MMC Card Interface base address */
//~ #define LPC23XX_SPI1_BASE 0xe0068000 /* Serial Peripheral Interface 1 (SPI1) base */
#define LPC23XX_EMAC_BASE 0xFFE00000 /* Ethernet MAC base address */
#define LPC23XX_USB_BASE 0xFFE0C200 /* USB base address */
#define LPC23XX_SCB_BASE 0xE01FC000 /* System Control Block (SBC) base address */
#define LPC23XX_EXT_BASE 0xe01fc140 /* External Interrupt base address */
/* AHB Register block base addresses */
#define LPC23XX_EMC_BASE 0xFFE08000 /* External Memory Controller (EMC) base address */
#define LPC23XX_VIC_BASE 0xFFFFF000 /* Vectored Interrupt Controller (VIC) Base */
#define LPC23XX_GPDMA_BASE 0xFFE04000 /* General Purpose DMA */
/* Watchdog Register Offsets */
#define WD_MOD_OFFSET 0x00 /* Watchdog Mode Register */
#define WD_TC_OFFSET 0x04 /* Watchdog Time Constant Register */
#define WD_FEED_OFFSET 0x08 /* Watchdog Feed Register */
#define WD_TV_OFFSET 0x0C /* Watchdog Time Value Register */
/* Timers Base Addresses */
#define TMR0_BASE_ADDR 0xE0004000
#define TMR1_BASE_ADDR 0xE0008000
#define TMR2_BASE_ADDR 0xE0070000
#define TMR3_BASE_ADDR 0xE0074000
/* Timer 0/1/2/3 register offsets */
#define TMR_IR_OFFSET 0x00 /* RW:Interrupt Register */
#define TMR_TCR_OFFSET 0x04 /* RW: Timer Control Register */
#define TMR_TC_OFFSET 0x08 /* RW: Timer Counter */
#define TMR_PR_OFFSET 0x0c /* RW: Prescale Register */
#define TMR_PC_OFFSET 0x10 /* RW: Prescale Counter Register */
#define TMR_MCR_OFFSET 0x14 /* RW: Match Control Register */
#define TMR_MR0_OFFSET 0x18 /* RW: Match Register 0 */
#define TMR_MR1_OFFSET 0x1c /* RW: Match Register 1 */
#define TMR_MR2_OFFSET 0x20 /* RW: Match Register 2 */
#define TMR_MR3_OFFSET 0x24 /* RW: Match Register 3 */
#define TMR_CCR_OFFSET 0x28 /* RW: Capture Control Register */
#define TMR_CR0_OFFSET 0x2c /* R: Capture Register 0 */
#define TMR_CR1_OFFSET 0x30 /* R: Capture Register 1 */
#define TMR_CR2_OFFSET 0x34 /* R: Capture Register 2 */
#define TMR_CR3_OFFSET 0x38 /* RW: Capture Register 3 */
#define TMR_EMR_OFFSET 0x3c /* RW: External Match Register */
#define TMR_CTCR_OFFSET 0x70 /* RW: Count Control Register */
/* Universal Asynchronous Receiver Transmitter Base Addresses */
#define UART0_BASE_ADDR 0xE000C000
#define UART1_BASE_ADDR 0xE0010000
#define UART2_BASE_ADDR 0xE0078000
#define UART3_BASE_ADDR 0xE007C000
/* UART 0/1/2/3 Register Offsets */
#define UART_RBR_OFFSET 0x00 /* R: Receive Buffer Register (DLAB=0) */
#define UART_THR_OFFSET 0x00 /* W: Transmit Holding Register (DLAB=0) */
#define UART_DLL_OFFSET 0x00 /* W: Divisor Latch Register (LSB, DLAB=1) */
#define UART_IER_OFFSET 0x04 /* W: Interrupt Enable Register (DLAB=0) */
#define UART_DLM_OFFSET 0x04 /* RW: Divisor Latch Register (MSB, DLAB=1) */
#define UART_IIR_OFFSET 0x08 /* R: Interrupt ID Register */
#define UART_FCR_OFFSET 0x08 /* W: FIFO Control Register */
#define UART_LCR_OFFSET 0x0c /* RW: Line Control Register */
#define UART_MCR_OFFSET 0x10 /* RW: Modem Control REgister (2146/6/8 UART1 Only) */
#define UART_LSR_OFFSET 0x14 /* R: Scratch Pad Register */
#define UART_MSR_OFFSET 0x18 /* RW: MODEM Status Register (2146/6/8 UART1 Only) */
#define UART_SCR_OFFSET 0x1c /* RW: Line Status Register */
#define UART_ACR_OFFSET 0x20 /* RW: Autobaud Control Register */
#define UART_FDR_OFFSET 0x28 /* RW: Fractional Divider Register */
#define UART_TER_OFFSET 0x30 /* RW: Transmit Enable Register */
/* Pulse Width Modulation Base Address */
#define PWM1_BASE_ADDR 0xE0018000
/* PWM register offsets */
#define PWM_IR_OFFSET 0x00 /* Interrupt Register */
#define PWM_TCR_OFFSET 0x04 /* Timer Control Register */
#define PWM_TC_OFFSET 0x08 /* Timer Counter */
#define PWM_PR_OFFSET 0x0c /* Prescale Register */
#define PWM_PC_OFFSET 0x10 /* Prescale Counter Register */
#define PWM_MCR_OFFSET 0x14 /* Match Control Register */
#define PWM_MR0_OFFSET 0x18 /* Match Register 0 */
#define PWM_MR1_OFFSET 0x1c /* Match Register 1 */
#define PWM_MR2_OFFSET 0x20 /* Match Register 2 */
#define PWM_MR3_OFFSET 0x24 /* Match Register 3 */
#define PWM_CCR_OFFSET 0x28 /* Capture Control Register*/
#define PWM_CCR0_OFFSET 0x2C /* Capture Register 0 */
#define PWM_CCR1_OFFSET 0x30 /* Capture Register 1 */
#define PWM_CCR2_OFFSET 0x34 /* Capture Register 2 */
#define PWM_CCR3_OFFSET 0x38 /* Capture Register 3 */
#define PWM_EMR_OFFSET 0x3C /* */
#define PWM_MR4_OFFSET 0x40 /* Match Register 4 */
#define PWM_MR5_OFFSET 0x44 /* Match Register 5 */
#define PWM_MR6_OFFSET 0x48 /* Match Register 6 */
#define PWM_PCR_OFFSET 0x4c /* Control Register */
#define PWM_LER_OFFSET 0x50 /* Latch Enable Register */
#define PWM_CTCR_OFFSET 0x70
/* I2C Base Addresses */
#define I2C0_BASE_ADDR 0xE001C000
#define I2C1_BASE_ADDR 0xE005C000
#define I2C2_BASE_ADDR 0xE0080000
/* I2C 0/1/2 register offsets */
#define I2C_CONSET_OFFSET 0x00 /* Control Set Register */
#define I2C_STAT_OFFSET 0x04 /* Status Register */
#define I2C_DAT_OFFSET 0x08 /* Data Register */
#define I2C_ADR_OFFSET 0x0c /* Slave Address Register */
#define I2C_SCLH_OFFSET 0x10 /* SCL Duty Cycle Register (high half word) */
#define I2C_SCLL_OFFSET 0x14 /* SCL Duty Cycle Register (low half word) */
#define I2C_CONCLR_OFFSET 0x18 /* Control Clear Register */
/* Pin function select register offsets */
#define PINSEL0_OFFSET 0x00 /* Pin function select register 0 */
#define PINSEL1_OFFSET 0x04 /* Pin function select register 1 */
#define PINSEL2_OFFSET 0x08 /* Pin function select register 2 */
#define PINSEL3_OFFSET 0x0C /* Pin function select register 3 */
#define PINSEL4_OFFSET 0x10 /* Pin function select register 4 */
#define PINSEL5_OFFSET 0x14 /* Pin function select register 5 */
#define PINSEL6_OFFSET 0x18 /* Pin function select register 6 */
#define PINSEL7_OFFSET 0x1C /* Pin function select register 7 */
#define PINSEL8_OFFSET 0x20 /* Pin function select register 8 */
#define PINSEL9_OFFSET 0x24 /* Pin function select register 9 */
#define PINSEL10_OFFSET 0x28 /* Pin function select register 10 */
/* Analog to Digital (AD) Base Address */
#define ADC0_BASE_ADDR 0xE0034000
/* Analog to Digital (AD) Converter registger offsets */
#define AD_ADCR_OFFSET 0x00 /* A/D Control Register */
#define AD_ADGDR_OFFSET 0x04 /* A/D Global Data Register (only one common register!) */
//~ #define AD_ADGSR_OFFSET 0x08 /* A/D Global Start Register */
#define AD_ADINTEN_OFFSET 0x0c /* A/D Interrupt Enable Register */
#define AD_ADDR0_OFFSET 0x10 /* A/D Chanel 0 Data Register */
#define AD_ADDR1_OFFSET 0x14 /* A/D Chanel 0 Data Register */
#define AD_ADDR2_OFFSET 0x18 /* A/D Chanel 0 Data Register */
#define AD_ADDR3_OFFSET 0x1c /* A/D Chanel 0 Data Register */
#define AD_ADDR4_OFFSET 0x20 /* A/D Chanel 0 Data Register */
#define AD_ADDR5_OFFSET 0x24 /* A/D Chanel 0 Data Register */
#define AD_ADDR6_OFFSET 0x28 /* A/D Chanel 0 Data Register */
#define AD_ADDR7_OFFSET 0x2c /* A/D Chanel 0 Data Register */
#define AD_ADSTAT_OFFSET 0x30 /* A/D Status Register */
/* Digital to Analog (DAC) Base Address */
#define DAC_BASE_ADDR 0xE006C000
/* Digital to Analog (DAC) reister offset */
//#define DACR_OFFSET 0x00
/* SPI0 register offsets */
#define SPI0_BASE_ADDR 0xE0020000
#define SPI0_CR_OFFSET 0x00 /* Control Register */
#define SPI0_SR_OFFSET 0x04 /* Status Register */
#define SPI0_DR_OFFSET 0x08 /* Data Register */
#define SPI0_CCR_OFFSET 0x0c /* Clock Counter Register */
#define SPI0_INTF_OFFSET 0x1c /* Interrupt Flag Register */
/* SPI1 register offsets */
//~ #define SPI1_CR0_OFFSET 0x00 /* Control Register 0 */
//~ #define SPI1_CR1_OFFSET 0x04 /* Control Register 1 */
//~ #define SPI1_DR_OFFSET 0x08 /* Data Register */
//~ #define SPI1_SR_OFFSET 0x0c /* Status Register */
//~ #define SPI1_CPSR_OFFSET 0x10 /* Clock Pre-Scale Regisrer */
//~ #define SPI1_IMSC_OFFSET 0x14 /* Interrupt Mask Set and Clear Register */
//~ #define SPI1_RIS_OFFSET 0x18 /* Raw Interrupt Status Register */
//~ #define SPI1_MIS_OFFSET 0x1c /* Masked Interrupt Status Register */
//~ #define SPI1_ICR_OFFSET 0x20 /* Interrupt Clear Register */
/* SSP Base Addresses */
#define SSP0_BASE_ADDR 0xE0068000
#define SSP1_BASE_ADDR 0xE0030000
/* SSP 0/1 register offsets */
#define SSP_CR0_OFFSET 0x00 /* Control Register 0 */
#define SSP_CR1_OFFSET 0x04 /* Control Register 1 */
#define SSP_DR_OFFSET 0x08 /* Data Register */
#define SSP_SR_OFFSET 0x0C /* Status Register*/
#define SSP_CPSR_OFFSET 0x10 /* Clock Prescale Register */
#define SSP_IMSC_OFFSET 0x14 /* Interrupt Mask Set/Clear Register */
#define SSP_RIS_OFFSET 0x18 /* Raw Interrupt Register */
#define SSP_MIS_OFFSET 0x1C /* Masked Interrupt Status Register */
#define SSP_ICR_OFFSET 0x20 /* Interrupt Clear Register */
#define SSP_DMACR_OFFSET 0x24 /* DMA Control Register */
/* Real Time Clock Base Address */
#define RTC_BASE_ADDR 0xE0024000
/* RTC register offsets */
#define RTC_ILR_OFFSET 0x00 /* Interrupt Location Register */
#define RTC_CTC_OFFSET 0x04 /* Clock Tick Counter */
#define RTC_CCR_OFFSET 0x08 /* Clock Control Register */
#define RTC_CIIR_OFFSET 0x0c /* Counter Increment Interrupt Register */
#define RTC_AMR_OFFSET 0x10 /* Alarm Mask Register */
#define RTC_CTIME0_OFFSET 0x14 /* Consolidated Time Register 0 */
#define RTC_CTIME1_OFFSET 0x18 /* Consolidated Time Register 1 */
#define RTC_CTIME2_OFFSET 0x1c /* Consolidated Time Register 2 */
#define RTC_SEC_OFFSET 0x20 /* Seconds Register */
#define RTC_MIN_OFFSET 0x24 /* Minutes Register */
#define RTC_HOUR_OFFSET 0x28 /* Hours Register */
#define RTC_DOM_OFFSET 0x2c /* Day Of Month Register */
#define RTC_DOW_OFFSET 0x30 /* Day Of Week Register */
#define RTC_DOY_OFFSET 0x34 /* Day Of Year Register */
#define RTC_MONTH_OFFSET 0x38 /* Months Register */
#define RTC_YEAR_OFFSET 0x3c /* Years Register */
#define RTC_ALSEC_OFFSET 0x60 /* Alarm Seconds Register */
#define RTC_ALMIN_OFFSET 0x64 /* Alarm Minutes Register */
#define RTC_ALHOUR_OFFSET 0x68 /* Alarm Hours Register */
#define RTC_ALDOM_OFFSET 0x6c /* Alarm Day Of Month Register */
#define RTC_ALDOW_OFFSET 0x70 /* Alarm Day Of Week Register */
#define RTC_ALDOY_OFFSET 0x74 /* Alarm Day Of Year Register */
#define RTC_ALMON_OFFSET 0x78 /* Alarm Months Register */
#define RTC_ALYEAR_OFFSET 0x7c /* Alarm Years Register */
#define RTC_PREINT_OFFSET 0x80 /* Prescale Value Register (integer) */
#define RTC_PREFRAC_OFFSET 0x84 /* Prescale Value Register (fraction) */
/* Watchdog */
//~ WDG_BASE_ADDR 0xE0000000
#define WDMOD_OFFSET 0x00
#define WDTC_OFFSET 0x04
#define WDFEED_OFFSET 0x08
#define WDTV_OFFSET 0x0C
#define WDCLKSEL_OFFSET 0x10
/* CAN CONTROLLERS AND ACCEPTANCE FILTER */
//~ CAN_ACCEPT_BASE_ADDR 0xE003C000
#define CAN_AFMR_OFFSET 0x00
#define CAN_SFF_SA_OFFSET 0x04
#define CAN_SFF_GRP_SA_OFFSET 0x08
#define CAN_EFF_SA_OFFSET 0x0C
#define CAN_EFF_GRP_SA_OFFSET 0x10
#define CAN_EOT_OFFSET 0x14
#define CAN_LUT_ERR_ADR_OFFSET 0x18
#define CAN_LUT_ERR_OFFSET 0x1C
//~ CAN_COMMON_BASE_ADDR 0xE0040000
#define CAN_TX_SR_OFFSET 0x00
#define CAN_RX_SR_OFFSET 0x04
#define CAN_MSR_OFFSET 0x08
//~ CAN1_BASE_ADDR 0xE0044000
#define CAN1MOD_OFFSET 0x00
#define CAN1CMR_OFFSET 0x04
#define CAN1GSR_OFFSET 0x08
#define CAN1ICR_OFFSET 0x0C
#define CAN1IER_OFFSET 0x10
#define CAN1BTR_OFFSET 0x14
#define CAN1EWL_OFFSET 0x18
#define CAN1SR_OFFSET 0x1C
#define CAN1RFS_OFFSET 0x20
#define CAN1RID_OFFSET 0x24
#define CAN1RDA_OFFSET 0x28
#define CAN1RDB_OFFSET 0x2C
#define CAN1TFI1_OFFSET 0x30
#define CAN1TID1_OFFSET 0x34
#define CAN1TDA1_OFFSET 0x38
#define CAN1TDB1_OFFSET 0x3C
#define CAN1TFI2_OFFSET 0x40
#define CAN1TID2_OFFSET 0x44
#define CAN1TDA2_OFFSET 0x48
#define CAN1TDB2_OFFSET 0x4C
#define CAN1TFI3_OFFSET 0x50
#define CAN1TID3_OFFSET 0x54
#define CAN1TDA3_OFFSET 0x58
#define CAN1TDB3_OFFSET 0x5C
//~ CAN2_BASE_ADDR 0xE0048000
#define CAN2MOD_OFFSET 0x00
#define CAN2CMR_OFFSET 0x04
#define CAN2GSR_OFFSET 0x08
#define CAN2ICR_OFFSET 0x0C
#define CAN2IER_OFFSET 0x10
#define CAN2BTR_OFFSET 0x14
#define CAN2EWL_OFFSET 0x18
#define CAN2SR_OFFSET 0x1C
#define CAN2RFS_OFFSET 0x20
#define CAN2RID_OFFSET 0x24
#define CAN2RDA_OFFSET 0x28
#define CAN2RDB_OFFSET 0x2C
#define CAN2TFI1_OFFSET 0x30
#define CAN2TID1_OFFSET 0x34
#define CAN2TDA1_OFFSET 0x38
#define CAN2TDB1_OFFSET 0x3C
#define CAN2TFI2_OFFSET 0x40
#define CAN2TID2_OFFSET 0x44
#define CAN2TDA2_OFFSET 0x48
#define CAN2TDB2_OFFSET 0x4C
#define CAN2TFI3_OFFSET 0x50
#define CAN2TID3_OFFSET 0x54
#define CAN2TDA3_OFFSET 0x58
#define CAN2TDB3_OFFSET 0x5C
/* MultiMedia Card Interface(MCI) Controller */
//~ MCI_BASE_ADDR 0xE008C000
#define MCI_POWER_OFFSET 0x00
#define MCI_CLOCK_OFFSET 0x04
#define MCI_ARGUMENT_OFFSET 0x08
#define MCI_COMMAND_OFFSET 0x0C
#define MCI_RESP_CMD_OFFSET 0x10
#define MCI_RESP0_OFFSET 0x14
#define MCI_RESP1_OFFSET 0x18
#define MCI_RESP2_OFFSET 0x1C
#define MCI_RESP3_OFFSET 0x20
#define MCI_DATA_TMR_OFFSET 0x24
#define MCI_DATA_LEN_OFFSET 0x28
#define MCI_DATA_CTRL_OFFSET 0x2C
#define MCI_DATA_CNT_OFFSET 0x30
#define MCI_STATUS_OFFSET 0x34
#define MCI_CLEAR_OFFSET 0x38
#define MCI_MASK0_OFFSET 0x3C
#define MCI_MASK1_OFFSET 0x40
#define MCI_FIFO_CNT_OFFSET 0x48
#define MCI_FIFO_OFFSET 0x80
/* I2S Interface Controller (I2S) */
//~ I2S_BASE_ADDR 0xE0088000
#define I2S_DAO_OFFSET 0x00
#define I2S_DAI_OFFSET 0x04
#define I2S_TX_FIFO_OFFSET 0x08
#define I2S_RX_FIFO_OFFSET 0x0C
#define I2S_STATE_OFFSET 0x10
#define I2S_DMA1_OFFSET 0x14
#define I2S_DMA2_OFFSET 0x18
#define I2S_IRQ_OFFSET 0x1C
#define I2S_TXRATE_OFFSET 0x20
#define I2S_RXRATE_OFFSET 0x24
/* General-purpose DMA Controller */
/* DMA_BASE_ADDR 0xFFE04000 */
#define GPDMA_INT_STAT_OFFSET 0x4000
#define GPDMA_INT_TCSTAT_OFFSET 0x4004
#define GPDMA_INT_TCCLR_OFFSET 0x4008
#define GPDMA_INT_ERR_STAT_OFFSET 0x400C
#define GPDMA_INT_ERR_CLR_OFFSET 0x4010
#define GPDMA_RAW_INT_TCSTAT_OFFSET 0x4014
#define GPDMA_RAW_INT_ERR_STAT_OFFSET 0x4018
#define GPDMA_ENABLED_CHNS_OFFSET 0x401C
#define GPDMA_SOFT_BREQ_OFFSET 0x4020
#define GPDMA_SOFT_SREQ_OFFSET 0x4024
#define GPDMA_SOFT_LBREQ_OFFSET 0x4028
#define GPDMA_SOFT_LSREQ_OFFSET 0x402C
#define GPDMA_CONFIG_OFFSET 0x4030
#define GPDMA_SYNC_OFFSET 0x4034
/* DMA channel 0 registers */
#define GPDMA_CH0_SRC_OFFSET 0x4100
#define GPDMA_CH0_DEST_OFFSET 0x4104
#define GPDMA_CH0_LLI_OFFSET 0x4108
#define GPDMA_CH0_CTRL_OFFSET 0x410C
#define GPDMA_CH0_CFG_OFFSET 0x4110
/* DMA channel 1 registers */
#define GPDMA_CH1_SRC_OFFSET 0x4120
#define GPDMA_CH1_DEST_OFFSET 0x4124
#define GPDMA_CH1_LLI_OFFSET 0x4128
#define GPDMA_CH1_CTRL_OFFSET 0x412C
#define GPDMA_CH1_CFG_OFFSET 0x4130
/* USB Controller */
#define USB_INT_BASE_ADDR 0xE01FC1C0
#define USB_BASE_ADDR 0xFFE0C200 /* USB Base Address */
/* USB Device Interrupt Registers */
#define USB_INT_STAT_OFFSET 0x00
#define USB_INT_EN_OFFSET 0x04
#define USB_INT_CLR_OFFSET 0x08
#define USB_INT_SET_OFFSET 0x0C
#define USB_INT_PRIO_OFFSET 0x2C
/* USB Device Endpoint Interrupt Registers */
#define USB_EP_INT_STAT_OFFSET 0x30
#define USB_EP_INT_EN_OFFSET 0x34
#define USB_EP_INT_CLR_OFFSET 0x38
#define USB_EP_INT_SET_OFFSET 0x3C
#define USB_EP_INT_PRIO_OFFSET 0x40
/* USB Device Endpoint Realization Registers */
#define USB_REALIZE_EP_OFFSET 0x44
#define USB_EP_INDEX_OFFSET 0x48
#define USB_MAXPACKET_SIZE_OFFSET 0x4C
/* USB Device Command Reagisters */
#define USB_CMD_CODE_OFFSET 0x10
#define USB_CMD_DATA_OFFSET 0x14
/* USB Device Data Transfer Registers */
#define USB_RX_DATA_OFFSET 0x18
#define USB_TX_DATA_OFFSET 0x1C
#define USB_RX_PLENGTH_OFFSET 0x20
#define USB_TX_PLENGTH_OFFSET 0x24
#define USB_USB_CTRL_OFFSET 0x28
/* USB Device DMA Registers */
#define USB_DMA_REQ_STAT_OFFSET 0x50
#define USB_DMA_REQ_CLR_OFFSET 0x54
#define USB_DMA_REQ_SET_OFFSET 0x58
#define USB_UDCA_HEAD_OFFSET 0x80
#define USB_EP_DMA_STAT_OFFSET 0x84
#define USB_EP_DMA_EN_OFFSET 0x88
#define USB_EP_DMA_DIS_OFFSET 0x8C
#define USB_DMA_INT_STAT_OFFSET 0x90
#define USB_DMA_INT_EN_OFFSET 0x94
#define USB_EOT_INT_STAT_OFFSET 0xA0
#define USB_EOT_INT_CLR_OFFSET 0xA4
#define USB_EOT_INT_SET_OFFSET 0xA8
#define USB_NDD_REQ_INT_STAT_OFFSET 0xAC
#define USB_NDD_REQ_INT_CLR_OFFSET 0xB0
#define USB_NDD_REQ_INT_SET_OFFSET 0xB4
#define USB_SYS_ERR_INT_STAT_OFFSET 0xB8
#define USB_SYS_ERR_INT_CLR_OFFSET 0xBC
#define USB_SYS_ERR_INT_SET_OFFSET 0xC0
/* System Control Block(SCB) modules include Memory Accelerator Module,
Phase Locked Loop, VPB divider, Power Control, External Interrupt,
Reset, and Code Security/Debugging */
#define SCB_BASE_ADDR 0xE01FC000
/* Memory Accelerator Module (MAM) Regiser */
#define SCB_MAMCR (*(volatile uint32_t*)(0xE01FC000))
#define SCB_MAMTIM (*(volatile uint32_t*)(0xE01FC004))
#define SCB_MEMMAP (*(volatile uint32_t*)(0xE01FC040))
/* Phase Locked Loop (PLL) Register */
#define SCB_PLLCON (*(volatile uint32_t*)(0xE01FC080))
#define SCB_PLLCFG (*(volatile uint32_t*)(0xE01FC084))
#define SCB_PLLSTAT (*(volatile uint32_t*)(0xE01FC088))
#define SCB_PLLFEED (*(volatile uint32_t*)(0xE01FC08C))
/* Power Control register */
#define SCB_PCON (*(volatile uint32_t*)(0xE01FC0C0))
#define SCB_PCONP (*(volatile uint32_t*)(0xE01FC0C4))
#define SCB_PCONP_OFFSET 0x0C4
/* Clock Divider Register */
#define SCB_CCLKCFG (*(volatile uint32_t*)(0xE01FC104))
#define SCB_USBCLKCFG (*(volatile uint32_t*)(0xE01FC108))
#define SCB_CLKSRCSEL (*(volatile uint32_t*)(0xE01FC10C))
#define SCB_PCLKSEL0 (*(volatile uint32_t*)(0xE01FC1A8))
#define SCB_PCLKSEL1 (*(volatile uint32_t*)(0xE01FC1AC))
#define SCB_PCLKSEL0_OFFSET (0x1A8)
#define SCB_PCLKSEL1_OFFSET (0x1AC)
/* External Interrupt register */
#define SCB_EXTINT (*(volatile uint32_t*)(0xE01FC140))
#define SCB_INTWAKE (*(volatile uint32_t*)(0xE01FC144))
#define SCB_EXTMODE (*(volatile uint32_t*)(0xE01FC148))
#define SCB_EXTPOLAR (*(volatile uint32_t*)(0xE01FC14C))
/* Reser Source Indentification register */
#define SCB_RSIR (*(volatile uint32_t*)(0xE01FC180))
/* RSID, code security protection */
#define SCB_CSPR (*(volatile uint32_t*)(0xE01FC184))
#define SCB_AHBCFG1 (*(volatile uint32_t*)(0xE01FC188))
#define SCB_AHBCFG2 (*(volatile uint32_t*)(0xE01FC18C))
/* System Controls and Status Register */
#define SCB_SCS (*(volatile uint32_t*)(0xE01FC1A0))
//~ /* External Memory Controller (EMC) definitions */
/* MPMC(EMC) registers, note: all the external memory controller(EMC) registers
are for LPC24xx only. */
#define STATIC_MEM0_BASE 0x80000000
#define STATIC_MEM1_BASE 0x81000000
#define STATIC_MEM2_BASE 0x82000000
#define STATIC_MEM3_BASE 0x83000000
#define DYNAMIC_MEM0_BASE 0xA0000000
#define DYNAMIC_MEM1_BASE 0xB0000000
#define DYNAMIC_MEM2_BASE 0xC0000000
#define DYNAMIC_MEM3_BASE 0xD0000000
/* External Memory Controller (EMC) */
//~ #define EMC_BASE_ADDR 0xFFE08000
#define EMC_CTRL_OFFSET 0x000
#define EMC_STAT_OFFSET 0x004
#define EMC_CONFIG_OFFSET 0x008
/* Dynamic RAM access registers */
#define EMC_DYN_CTRL_OFFSET 0x020
#define EMC_DYN_RFSH_OFFSET 0x024
#define EMC_DYN_RD_CFG_OFFSET 0x028
#define EMC_DYN_RP_OFFSET 0x030
#define EMC_DYN_RAS_OFFSET 0x034
#define EMC_DYN_SREX_OFFSET 0x038
#define EMC_DYN_APR_OFFSET 0x03C
#define EMC_DYN_DAL_OFFSET 0x040
#define EMC_DYN_WR_OFFSET 0x044
#define EMC_DYN_RC_OFFSET 0x048
#define EMC_DYN_RFC_OFFSET 0x04C
#define EMC_DYN_XSR_OFFSET 0x050
#define EMC_DYN_RRD_OFFSET 0x054
#define EMC_DYN_MRD_OFFSET 0x058
#define EMC_DYN_CFG0_OFFSET 0x100
#define EMC_DYN_RASCAS0_OFFSET 0x104
#define EMC_DYN_CFG1_OFFSET 0x140
#define EMC_DYN_RASCAS1_OFFSET 0x144
#define EMC_DYN_CFG2_OFFSET 0x160
#define EMC_DYN_RASCAS2_OFFSET 0x164
#define EMC_DYN_CFG3_OFFSET 0x180
#define EMC_DYN_RASCAS3_OFFSET 0x184
/* static RAM access registers */
#define EMC_STA_CFG0_OFFSET 0x200
#define EMC_STA_WAITWEN0_OFFSET 0x204
#define EMC_STA_WAITOEN0_OFFSET 0x208
#define EMC_STA_WAITRD0_OFFSET 0x20C
#define EMC_STA_WAITPAGE0_OFFSET 0x210
#define EMC_STA_WAITWR0_OFFSET 0x214
#define EMC_STA_WAITTURN0_OFFSET 0x218
#define EMC_STA_CFG1_OFFSET 0x220
#define EMC_STA_WAITWEN1_OFFSET 0x224
#define EMC_STA_WAITOEN1_OFFSET 0x228
#define EMC_STA_WAITRD1_OFFSET 0x22C
#define EMC_STA_WAITPAGE1_OFFSET 0x230
#define EMC_STA_WAITWR1_OFFSET 0x234
#define EMC_STA_WAITTURN1_OFFSET 0x238
#define EMC_STA_CFG2_OFFSET 0x240
#define EMC_STA_WAITWEN2_OFFSET 0x244
#define EMC_STA_WAITOEN2_OFFSET 0x248
#define EMC_STA_WAITRD2_OFFSET 0x24C
#define EMC_STA_WAITPAGE2_OFFSET 0x250
#define EMC_STA_WAITWR2_OFFSET 0x254
#define EMC_STA_WAITTURN2_OFFSET 0x258
#define EMC_STA_CFG3 0x260
#define EMC_STA_WAITWEN3_OFFSET 0x264
#define EMC_STA_WAITOEN3_OFFSET 0x268
#define EMC_STA_WAITRD3_OFFSET 0x26C
#define EMC_STA_WAITPAGE3_OFFSET 0x270
#define EMC_STA_WAITWR3_OFFSET 0x274
#define EMC_STA_WAITTURN3_OFFSET 0x278
#define EMC_STA_EXT_WAIT_OFFSET 0x880
/* GPIO register offsets WORD access */
#define GPIO0_PIN_OFFSET 0x00 /* Pin Value Register */
#define GPIO0_SET_OFFSET 0x04 /* Pin Output Set Register */
#define GPIO0_DIR_OFFSET 0x08 /* Pin Direction Register */
#define GPIO0_CLR_OFFSET 0x0c /* Pin Output Clear Register */
#define GPIO1_PIN_OFFSET 0x10 /* Pin Value Register */
#define GPIO1_SET_OFFSET 0x14 /* Pin Output Set Register */
#define GPIO1_DIR_OFFSET 0x18 /* Pin Direction Register */
#define GPIO1_CLR_OFFSET 0x1c /* Pin Output Clear Register */
/* Fast I0 Base Address */
#define FIO_BASE_ADDR 0x3FFFC000
/* FIO register offsets WORD access */
#define FIO0_DIR_OFFSET 0x00 /* Fast GPIO Port Direction Register */
#define FIO0_MASK_OFFSET 0x10 /* Fast GPIO Mask Register */
#define FIO0_PIN_OFFSET 0x14 /* Fast GPIO Pin Value Register */
#define FIO0_SET_OFFSET 0x18 /* Fast GPIO Port Output Set Register */
#define FIO0_CLR_OFFSET 0x1c /* Fast GPIO Port Output Clear Register */
#define FIO1_DIR_OFFSET 0x20 /* Fast GPIO Port Direction Register */
#define FIO1_MASK_OFFSET 0x30 /* Fast GPIO Mask Register */
#define FIO1_PIN_OFFSET 0x34 /* Fast GPIO Pin Value Register */
#define FIO1_SET_OFFSET 0x38 /* Fast GPIO Port Output Set Register */
#define FIO1_CLR_OFFSET 0x3c /* Fast GPIO Port Output Clear Register */
#define FIO2_DIR_OFFSET 0x40 /* Fast GPIO Port Direction Register */
#define FIO2_MASK_OFFSET 0x50 /* Fast GPIO Mask Register */
#define FIO2_PIN_OFFSET 0x54 /* Fast GPIO Pin Value Register */
#define FIO2_SET_OFFSET 0x58 /* Fast GPIO Port Output Set Register */
#define FIO2_CLR_OFFSET 0x5c /* Fast GPIO Port Output Clear Register */
#define FIO3_DIR_OFFSET 0x60 /* Fast GPIO Port Direction Register */
#define FIO3_MASK_OFFSET 0x70 /* Fast GPIO Mask Register */
#define FIO3_PIN_OFFSET 0x74 /* Fast GPIO Pin Value Register */
#define FIO3_SET_OFFSET 0x78 /* Fast GPIO Port Output Set Register */
#define FIO3_CLR_OFFSET 0x7c /* Fast GPIO Port Output Clear Register */
#define FIO4_DIR_OFFSET 0x80 /* Fast GPIO Port Direction Register */
#define FIO4_MASK_OFFSET 0x90 /* Fast GPIO Mask Register */
#define FIO4_PIN_OFFSET 0x94 /* Fast GPIO Pin Value Register */
#define FIO4_SET_OFFSET 0x98 /* Fast GPIO Port Output Set Register */
#define FIO4_CLR_OFFSET 0x9c /* Fast GPIO Port Output Clear Register */
/* FIO register offsets HALF-WORD access */
#define FIO0MASKL_OFFSET 0x10 /* Fast IO Mask Lower HALF-WORD */
#define FIO1MASKL_OFFSET 0x30
#define FIO2MASKL_OFFSET 0x50
#define FIO3MASKL_OFFSET 0x70
#define FIO4MASKL_OFFSET 0x90
#define FIO0MASKU_OFFSET 0x12 /* Fast IO Mask Upper HALF-WORD */
#define FIO1MASKU_OFFSET 0x32
#define FIO2MASKU_OFFSET 0x52
#define FIO3MASKU_OFFSET 0x72
#define FIO4MASKU_OFFSET 0x92
#define FIO0PINL_OFFSET 0x14 /* Fast IOPIN Lower HALF-WORD */
#define FIO1PINL_OFFSET 0x34
#define FIO2PINL_OFFSET 0x54
#define FIO3PINL_OFFSET 0x74
#define FIO4PINL_OFFSET 0x94
#define FIO0PINU_OFFSET 0x16 /* Fast IOPIN Upper HALF-WORD */
#define FIO1PINU_OFFSET 0x36
#define FIO2PINU_OFFSET 0x56
#define FIO3PINU_OFFSET 0x76
#define FIO4PINU_OFFSET 0x96
#define FIO0SETL_OFFSET 0x18 /* Fast IOSET Lower HALF-WORD */
#define FIO1SETL_OFFSET 0x38
#define FIO2SETL_OFFSET 0x58
#define FIO3SETL_OFFSET 0x78
#define FIO4SETL_OFFSET 0x98
#define FIO0SETU_OFFSET 0x1A /* Fast IOSET Upper HALF-WORD */
#define FIO1SETU_OFFSET 0x3A
#define FIO2SETU_OFFSET 0x5A
#define FIO3SETU_OFFSET 0x7A
#define FIO4SETU_OFFSET 0x9A
#define FIO0CLRL_OFFSET 0x1C /* Fast IOCLR Lower HALF-WORD */
#define FIO1CLRL_OFFSET 0x3C
#define FIO2CLRL_OFFSET 0x5C
#define FIO3CLRL_OFFSET 0x7C
#define FIO4CLRL_OFFSET 0x9C
#define FIO0CLRU_OFFSET 0x1E /* Fast IOCLR Upper HALF-WORD */
#define FIO1CLRU_OFFSET 0x3E
#define FIO2CLRU_OFFSET 0x5E
#define FIO3CLRU_OFFSET 0x7E
#define FIO4CLRU_OFFSET 0x9E
#define FIO0DIRL_OFFSET 0x00 /* Fast IODIR Lower HALF-WORD */
#define FIO1DIRL_OFFSET 0x20
#define FIO2DIRL_OFFSET 0x40
#define FIO3DIRL_OFFSET 0x60
#define FIO4DIRL_OFFSET 0x80
#define FIO0DIRU_OFFSET 0x02 /* Fast IODIR Upper HALF-WORD */
#define FIO1DIRU_OFFSET 0x22
#define FIO2DIRU_OFFSET 0x42
#define FIO3DIRU_OFFSET 0x62
#define FIO4DIRU_OFFSET 0x82
/* FIO register offsets BYTE access */
#define FIO0DIR0_OFFSET 0x00
#define FIO1DIR0_OFFSET 0x20
#define FIO2DIR0_OFFSET 0x40
#define FIO3DIR0_OFFSET 0x60
#define FIO4DIR0_OFFSET 0x80
#define FIO0DIR1_OFFSET 0x01
#define FIO1DIR1_OFFSET 0x21
#define FIO2DIR1_OFFSET 0x41
#define FIO3DIR1_OFFSET 0x61
#define FIO4DIR1_OFFSET 0x81
#define FIO0DIR2_OFFSET 0x02
#define FIO1DIR2_OFFSET 0x22
#define FIO2DIR2_OFFSET 0x42
#define FIO3DIR2_OFFSET 0x62
#define FIO4DIR2_OFFSET 0x82
#define FIO0DIR3_OFFSET 0x03
#define FIO1DIR3_OFFSET 0x23
#define FIO2DIR3_OFFSET 0x43
#define FIO3DIR3_OFFSET 0x63
#define FIO4DIR3_OFFSET 0x83
#define FIO0MASK0_OFFSET 0x10
#define FIO1MASK0_OFFSET 0x30
#define FIO2MASK0_OFFSET 0x50
#define FIO3MASK0_OFFSET 0x70
#define FIO4MASK0_OFFSET 0x90
#define FIO0MASK1_OFFSET 0x11
#define FIO1MASK1_OFFSET 0x21
#define FIO2MASK1_OFFSET 0x51
#define FIO3MASK1_OFFSET 0x71
#define FIO4MASK1_OFFSET 0x91
#define FIO0MASK2_OFFSET 0x12
#define FIO1MASK2_OFFSET 0x32
#define FIO2MASK2_OFFSET 0x52
#define FIO3MASK2_OFFSET 0x72
#define FIO4MASK2_OFFSET 0x92
#define FIO0MASK3_OFFSET 0x13
#define FIO1MASK3_OFFSET 0x33
#define FIO2MASK3_OFFSET 0x53
#define FIO3MASK3_OFFSET 0x73
#define FIO4MASK3_OFFSET 0x93
#define FIO0PIN0_OFFSET 0x14
#define FIO1PIN0_OFFSET 0x34
#define FIO2PIN0_OFFSET 0x54
#define FIO3PIN0_OFFSET 0x74
#define FIO4PIN0_OFFSET 0x94
#define FIO0PIN1_OFFSET 0x15
#define FIO1PIN1_OFFSET 0x25
#define FIO2PIN1_OFFSET 0x55
#define FIO3PIN1_OFFSET 0x75
#define FIO4PIN1_OFFSET 0x95
#define FIO0PIN2_OFFSET 0x16
#define FIO1PIN2_OFFSET 0x36
#define FIO2PIN2_OFFSET 0x56
#define FIO3PIN2_OFFSET 0x76
#define FIO4PIN2_OFFSET 0x96
#define FIO0PIN3_OFFSET 0x17
#define FIO1PIN3_OFFSET 0x37
#define FIO2PIN3_OFFSET 0x57
#define FIO3PIN3_OFFSET 0x77
#define FIO4PIN3_OFFSET 0x97
#define FIO0SET0_OFFSET 0x18
#define FIO1SET0_OFFSET 0x38
#define FIO2SET0_OFFSET 0x58
#define FIO3SET0_OFFSET 0x78
#define FIO4SET0_OFFSET 0x98
#define FIO0SET1_OFFSET 0x19
#define FIO1SET1_OFFSET 0x29
#define FIO2SET1_OFFSET 0x59
#define FIO3SET1_OFFSET 0x79
#define FIO4SET1_OFFSET 0x99
#define FIO0SET2_OFFSET 0x1A
#define FIO1SET2_OFFSET 0x3A
#define FIO2SET2_OFFSET 0x5A
#define FIO3SET2_OFFSET 0x7A
#define FIO4SET2_OFFSET 0x9A
#define FIO0SET3_OFFSET 0x1B
#define FIO1SET3_OFFSET 0x3B
#define FIO2SET3_OFFSET 0x5B
#define FIO3SET3_OFFSET 0x7B
#define FIO4SET3_OFFSET 0x9B
#define FIO0CLR0_OFFSET 0x1C
#define FIO1CLR0_OFFSET 0x3C
#define FIO2CLR0_OFFSET 0x5C
#define FIO3CLR0_OFFSET 0x7C
#define FIO4CLR0_OFFSET 0x9C
#define FIO0CLR1_OFFSET 0x1D
#define FIO1CLR1_OFFSET 0x2D
#define FIO2CLR1_OFFSET 0x5D
#define FIO3CLR1_OFFSET 0x7D
#define FIO4CLR1_OFFSET 0x9D
#define FIO0CLR2_OFFSET 0x1E
#define FIO1CLR2_OFFSET 0x3E
#define FIO2CLR2_OFFSET 0x5E
#define FIO3CLR2_OFFSET 0x7E
#define FIO4CLR2_OFFSET 0x9E
#define FIO0CLR3_OFFSET 0x1F
#define FIO1CLR3_OFFSET 0x3F
#define FIO2CLR3_OFFSET 0x5F
#define FIO3CLR3_OFFSET 0x7F
#define FIO4CLR3_OFFSET 0x9F
/* Vectored Interrupt Controller (VIC) register offsets */
#define VIC_IRQSTATUS_OFFSET 0x000 /* R: IRQ Status Register */
#define VIC_FIQSTATUS_OFFSET 0x004 /* R: FIQ Status Register */
#define VIC_RAWINTR_OFFSET 0x008 /* R: Raw Interrupt Status Register */
#define VIC_INTSELECT_OFFSET 0x00c /* RW: Interrupt Select Register */
#define VIC_INTENABLE_OFFSET 0x010 /* RW: Interrupt Enable Register */
#define VIC_INTENCLEAR_OFFSET 0x014 /* W: Interrupt Enable Clear Register */
#define VIC_SOFTINT_OFFSET 0x018 /* RW: Software Interrupt Register */
#define VIC_SOFTINTCLEAR_OFFSET 0x01c /* W: Software Interrupt Clear Register */
#define VIC_PROTECTION_OFFSET 0x020 /* Protection Enable Register */
#define VIC_PRIORITY_MASK_OFFSET 0x024 /* Priority Mask Register */
//~ #define LPC23XX_VIC_BASE 0xfffff000 /* Vectored Interrupt Controller (VIC) Base */
#define VIC_ADDRESS_OFFSET 0xF00 /* RW: Vector Address Register */
#define VIC_VECTADDR0_OFFSET 0x100 /* RW: Vector Address 0 Register */
#define VIC_VECTADDR1_OFFSET 0x104 /* RW: Vector Address 1 Register */
#define VIC_VECTADDR2_OFFSET 0x108 /* RW: Vector Address 2 Register */
#define VIC_VECTADDR3_OFFSET 0x10c /* RW: Vector Address 3 Register */
#define VIC_VECTADDR4_OFFSET 0x110 /* RW: Vector Address 4 Register */
#define VIC_VECTADDR5_OFFSET 0x114 /* RW: Vector Address 5 Register */
#define VIC_VECTADDR6_OFFSET 0x118 /* RW: Vector Address 6 Register */
#define VIC_VECTADDR7_OFFSET 0x11c /* RW: Vector Address 7 Register */
#define VIC_VECTADDR8_OFFSET 0x120 /* RW: Vector Address 8 Register */
#define VIC_VECTADDR9_OFFSET 0x124 /* RW: Vector Address 9 Register */
#define VIC_VECTADDR10_OFFSET 0x128 /* RW: Vector Address 10 Register */
#define VIC_VECTADDR11_OFFSET 0x12c /* RW: Vector Address 11 Register */
#define VIC_VECTADDR12_OFFSET 0x130 /* RW: Vector Address 12 Register */
#define VIC_VECTADDR13_OFFSET 0x134 /* RW: Vector Address 13 Register */
#define VIC_VECTADDR14_OFFSET 0x138 /* RW: Vector Address 14 Register */
#define VIC_VECTADDR15_OFFSET 0x13c /* RW: Vector Address 15 Register */
#define VIC_VECTADDR16_OFFSET 0x140 /* RW: Vector Address 16 Register */
#define VIC_VECTADDR17_OFFSET 0x144 /* RW: Vector Address 17 Register */
#define VIC_VECTADDR18_OFFSET 0x148 /* RW: Vector Address 18 Register */
#define VIC_VECTADDR19_OFFSET 0x14c /* RW: Vector Address 19 Register */
#define VIC_VECTADDR20_OFFSET 0x150 /* RW: Vector Address 20 Register */
#define VIC_VECTADDR21_OFFSET 0x154 /* RW: Vector Address 21 Register */
#define VIC_VECTADDR22_OFFSET 0x158 /* RW: Vector Address 22 Register */
#define VIC_VECTADDR23_OFFSET 0x15c /* RW: Vector Address 23 Register */
#define VIC_VECTADDR24_OFFSET 0x160 /* RW: Vector Address 24 Register */
#define VIC_VECTADDR25_OFFSET 0x164 /* RW: Vector Address 25 Register */
#define VIC_VECTADDR26_OFFSET 0x168 /* RW: Vector Address 26 Register */
#define VIC_VECTADDR27_OFFSET 0x16c /* RW: Vector Address 27 Register */
#define VIC_VECTADDR28_OFFSET 0x170 /* RW: Vector Address 28 Register */
#define VIC_VECTADDR29_OFFSET 0x174 /* RW: Vector Address 29 Register */
#define VIC_VECTADDR30_OFFSET 0x178 /* RW: Vector Address 30 Register */
#define VIC_VECTADDR31_OFFSET 0x17c /* RW: Vector Address 31 Register */
/*VICVectPriority */
#define VIC_VECTPRIORITY0_OFFSET 0x200 /* RW: Vector Control 0 Register */
#define VIC_VECTPRIORITY1_OFFSET 0x204 /* RW: Vector Control 1 Register */
#define VIC_VECTPRIORITY2_OFFSET 0x208 /* RW: Vector Control 2 Register */
#define VIC_VECTPRIORITY3_OFFSET 0x20c /* RW: Vector Control 3 Register */
#define VIC_VECTPRIORITY4_OFFSET 0x210 /* RW: Vector Control 4 Register */
#define VIC_VECTPRIORITY5_OFFSET 0x214 /* RW: Vector Control 5 Register */
#define VIC_VECTPRIORITY6_OFFSET 0x218 /* RW: Vector Control 6 Register */
#define VIC_VECTPRIORITY7_OFFSET 0x21c /* RW: Vector Control 7 Register */
#define VIC_VECTPRIORITY8_OFFSET 0x220 /* RW: Vector Control 8 Register */
#define VIC_VECTPRIORITY9_OFFSET 0x224 /* RW: Vector Control 9 Register */
#define VIC_VECTPRIORITY10_OFFSET 0x228 /* RW: Vector Control 10 Register */
#define VIC_VECTPRIORITY11_OFFSET 0x22c /* RW: Vector Control 11 Register */
#define VIC_VECTPRIORITY12_OFFSET 0x230 /* RW: Vector Control 12 Register */
#define VIC_VECTPRIORITY13_OFFSET 0x234 /* RW: Vector Control 13 Register */
#define VIC_VECTPRIORITY14_OFFSET 0x238 /* RW: Vector Control 14 Register */
#define VIC_VECTPRIORITY15_OFFSET 0x23c /* RW: Vector Control 15 Register */
#define VIC_VECTPRIORITY16_OFFSET 0x240 /* RW: Vector Control 16 Register */
#define VIC_VECTPRIORITY17_OFFSET 0x244 /* RW: Vector Control 17 Register */
#define VIC_VECTPRIORITY18_OFFSET 0x248 /* RW: Vector Control 18 Register */
#define VIC_VECTPRIORITY19_OFFSET 0x24c /* RW: Vector Control 19 Register */
#define VIC_VECTPRIORITY20_OFFSET 0x250 /* RW: Vector Control 20 Register */
#define VIC_VECTPRIORITY21_OFFSET 0x254 /* RW: Vector Control 21 Register */
#define VIC_VECTPRIORITY22_OFFSET 0x258 /* RW: Vector Control 22 Register */
#define VIC_VECTPRIORITY23_OFFSET 0x25c /* RW: Vector Control 23 Register */
#define VIC_VECTPRIORITY24_OFFSET 0x260 /* RW: Vector Control 24 Register */
#define VIC_VECTPRIORITY25_OFFSET 0x264 /* RW: Vector Control 25 Register */
#define VIC_VECTPRIORITY26_OFFSET 0x268 /* RW: Vector Control 26 Register */
#define VIC_VECTPRIORITY27_OFFSET 0x26c /* RW: Vector Control 27 Register */
#define VIC_VECTPRIORITY28_OFFSET 0x270 /* RW: Vector Control 28 Register */
#define VIC_VECTPRIORITY29_OFFSET 0x274 /* RW: Vector Control 29 Register */
#define VIC_VECTPRIORITY30_OFFSET 0x278 /* RW: Vector Control 30 Register */
#define VIC_VECTPRIORITY31_OFFSET 0x27c /* RW: Vector Control 31 Register */
/****************************************************************************************************
* Inline Functions
****************************************************************************************************/
/****************************************************************************************************
* Global Function Prototypes
****************************************************************************************************/
#endif /* _ARCH_ARM_SRC_LPC2378_CHIP_H */

70
arch/arm/src/lpc2378/internal.h Executable file
View File

@ -0,0 +1,70 @@
/****************************************************************************************************
* arch/arm/src/lpc2378/chip.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
****************************************************************************************************/
#ifndef _ARCH_ARM_SRC_LPC2378_INTERNAL_H
#define _ARCH_ARM_SRC_LPC2378_INTERNAL_H
/****************************************************************************************************
* Included Files
****************************************************************************************************/
#include "up_internal.h"
#include "chip.h"
/****************************************************************************************************
* Pre-processor Definitions
****************************************************************************************************/
//~ #define CONFIG_VECTORED_INTERRUPTS
/****************************************************************************************************
* Global Function Prototypes
****************************************************************************************************/
#ifndef __ASSEMBLY__
#ifdef CONFIG_ARCH_LEDS
extern void up_statledoff(void);
extern void up_statledon(void);
#endif
#endif
#endif /* _ARCH_ARM_SRC_LPC2378_INTERNAL_H */

View File

@ -0,0 +1,168 @@
/********************************************************************************
* arch/arm/src/lpc2378/lpc23xx_decodeirq.c
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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 <stdint.h>
#include <nuttx/irq.h>
#include <nuttx/arch.h>
#include <assert.h>
#include <debug.h>
#include <arch/board/board.h>
#include "up_arch.h"
#include "os_internal.h"
#include "internal.h"
#include "lpc23xx_vic.h"
/********************************************************************************
* Definitions
********************************************************************************/
/********************************************************************************
* Private Types
********************************************************************************/
/********************************************************************************
* Public Data
********************************************************************************/
/********************************************************************************
* Private Data
********************************************************************************/
/********************************************************************************
* Private Functions
********************************************************************************/
/********************************************************************************
* Public Funstions
********************************************************************************/
/********************************************************************************
* up_decodeirq() and/or lpc23xx_decodeirq()
*
* Description:
* The vectored interrupt controller (VIC) takes 32 interrupt request inputs
* and programmatically assigns them into 2 categories: FIQ, vectored IRQ.
*
* - FIQs have the highest priority. There is a single FIQ vector, but multiple
* interrupt sources can be ORed to this FIQ vector.
*
* - Vectored IRQs have the middle priority. Any of the 32 interrupt sources
* can be assigned to vectored IRQs.
*
* - Non-vectored IRQs have the lowest priority.
*
* The general flow of IRQ processing is to simply read the VICAddress
* and jump to the address of the vector provided in the register. The VIC will
* provide the address of the highest priority vectored IRQ. If a non-vectored
* IRQ is requesting, the address of a default handler is provided.
*
********************************************************************************/
#ifndef CONFIG_VECTORED_INTERRUPTS
void up_decodeirq(uint32_t *regs)
#else
static void lpc23xx_decodeirq( uint32_t *regs)
#endif
{
#ifdef CONFIG_SUPPRESS_INTERRUPTS
lib_lowprintf("Unexpected IRQ\n");
current_regs = regs;
PANIC(OSERR_ERREXCEPTION);
#else
/* Check which IRQ fires */
uint32_t irqbits = vic_getreg(VIC_IRQSTATUS_OFFSET) & 0xFFFFFFFF;
unsigned int irq;
for (irq = 0; irq < NR_IRQS; irq++)
{
if( irqbits & (uint32_t)(1<<irq) ) break;
}
/* Verify that the resulting IRQ number is valid */
if (irq < NR_IRQS) /* redundant check ?? */
{
/* Current regs non-zero indicates that we are processing an interrupt;
* current_regs is also used to manage interrupt level context switches.
*/
DEBUGASSERT(current_regs == NULL);
current_regs = regs;
/* Mask and acknowledge the interrupt */
up_maskack_irq(irq);
/* Deliver the IRQ */
irq_dispatch(irq, regs);
/* Indicate that we are no longer in an interrupt handler */
current_regs = NULL;
}
#endif
}
#ifdef CONFIG_VECTORED_INTERRUPTS
void up_decodeirq(uint32_t *regs)
{
vic_vector_t vector = (vic_vector_t)vic_getreg(VIC_ADDRESS_OFFSET);
/* Mask and acknowledge the interrupt */
up_maskack_irq(irq);
/* Valid Interrupt */
if(vector != NULL)
(vector)(regs);
}
#endif

View File

@ -0,0 +1,71 @@
/************************************************************************************
* arch/arm/src/lpc2378/lpc231x_gpio.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
************************************************************************************/
#ifndef _ARCH_ARM_SRC_LPC2378_LPC23XX_GPIO_H
#define _ARCH_ARM_SRC_LPC2378_LPC23XX_GPIO_H
/************************************************************************************
* Included Files
************************************************************************************/
#include "chip.h"
/************************************************************************************
* Definitions
************************************************************************************/
#define io_getreg8(o) getreg8(LPC23XX_FIO_BASE+(o))
#define io_getreg(r) getreg32(LPC23XX_FIO_BASE+ (r))
#define dir_getreg8(o) getreg8(LPC23XX_FIO_BASE+(o))
#define dir_getreg(r) getreg32(LPC23XX_FIO_BASE+ (r))
#define dir_putreg8(v,o) putreg8((v), LPC23XX_FIO_BASE+(o))
#define dir_putreg(v,r) putreg32((v),LPC23XX_FIO_BASE+ (r))
#define fio_putreg8(v,o) putreg8((v), LPC23XX_FIO_BASE+(o))
#define fio_getreg8(o) getreg8(LPC23XX_FIO_BASE+(o))
/************************************************************************************
* Public Types
************************************************************************************/
/************************************************************************************
* Inline Functions
************************************************************************************/
/************************************************************************************
* Public Function Prototypes
************************************************************************************/
#endif /* _ARCH_ARM_SRC_LPC2378_LPC23XX_GPIO_H */

View File

@ -0,0 +1,235 @@
/****************************************************************************
* arch/arm/src/arm/lpc2378/lpc23xx_head.S
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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 <arch/board/board.h>
#include "arm.h"
#include "internal.h"
#include "up_arch.h"
#include "lpc23xx_uart.h"
#include "lpc23xx_scb.h"
#include "lpc23xx_pinsel.h"
/****************************************************************************
* Macros
****************************************************************************/
/* Print a character on the UART to show boot status. 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
/*****************************************************************************
* Text
*****************************************************************************/
.text
/*****************************************************************************
* Name: _vector_table
*
* Description:
* Interrrupt vector table. This must be located at the beginning
* of the memory space (at CONFIG_CODE_BASE). The first entry in
* the vector table is the reset vector and this is the code that
* will execute whn the processor is reset.
*
*****************************************************************************/
.globl _vector_table
.type _vector_table, %function
_vector_table:
ldr pc, .Lresethandler /* 0x00: Reset */
ldr pc, .Lundefinedhandler /* 0x04: Undefined instruction */
ldr pc, .Lswihandler /* 0x08: Software interrupt */
ldr pc, .Lprefetchaborthandler /* 0x0c: Prefetch abort */
ldr pc, .Ldataaborthandler /* 0x10: Data abort */
.long 0xB8A06F58 /* 0x14: Vector checksum */
ldr pc, .Lirqhandler /* 0x18: IRQ */
ldr pc, .Lfiqhandler /* 0x1c: FIQ */
.globl __start
.globl up_vectorundefinsn
.globl up_vectorswi
.globl up_vectorprefetch
.globl up_vectordata
.globl up_vectorirq
.globl up_vectorfiq
.Lresethandler:
.long __start
.Lundefinedhandler:
.long up_vectorundefinsn
.Lswihandler:
.long up_vectorswi
.Lprefetchaborthandler:
.long up_vectorprefetch
.Ldataaborthandler:
.long up_vectordata
.Lirqhandler:
.long up_vectorirq
.Lfiqhandler:
.long up_vectorfiq
.size _vector_table, . - _vector_table
/****************************************************************************
* OS Entry Point
****************************************************************************/
/* We assume the bootloader has already initialized most of the h/w for
* us and that only leaves us having to do some os specific things
* below.
*/
.text
.globl __start
.type __start, #function
__start:
/* Call lowlevel init C-function */
.extern ConfigurePLL
ldr r0, =ConfigurePLL
mov lr, pc
bx r0
/* First, setup initial processor mode */
mov r0, #(SVC_MODE | PSR_I_BIT | PSR_F_BIT )
msr cpsr, r0
/* Configure the uart so that we can get debug output as soon
* as possible. Modifies r0, r1, r2, and r14.
*/
bl up_lowsetup
showprogress 'A'
/* Setup system stack (and get the BSS range) */
adr r0, LC0
ldmia r0, {r4, r5, sp}
/* Clear system BSS section (Initialize with 0) */
mov r0, #0
1: cmp r4, r5
strcc r0, [r4], #4
bcc 1b
showprogress 'B'
/* Copy system .data sections to new home in RAM. */
adr r3, LC2
ldmia r3, {r0, r1, r2}
2: ldmia r0!, {r3 - r10}
stmia r1!, {r3 - r10}
cmp r1, r2
blt 2b
/* Perform early serial initialization */
mov fp, #0
#ifdef CONFIG_USE_EARLYSERIALINIT
bl up_earlyserialinit
showprogress 'S'
#endif
showprogress 'C'
showprogress '\n'
/* Initialize onboard LEDs */
#ifdef CONFIG_ARCH_LEDS
bl up_ledinit
#endif
/* Then jump to OS entry */
b os_start
/* Variables:
* _sbss is the start of the BSS region (see ld.script)
* _ebss is the end of the BSS regsion (see ld.script)
* The idle task stack starts at the end of BSS and is
* of size CONFIG_IDLETHREAD_STACKSIZE. The heap continues
* from there until the end of memory. See g_heapbase
* below.
*/
LC0: .long _sbss
.long _ebss
.long _ebss+CONFIG_IDLETHREAD_STACKSIZE-4
LC2: .long _eronly /* Where .data defaults are stored in FLASH */
.long _sdata /* Where .data needs to reside in SDRAM */
.long _edata
.size __start, .-__start
/* This global variable is unsigned long g_heapbase and is
* exported from here only because of its coupling to LCO
* above.
*/
.data
.align 4
.globl g_heapbase
.type g_heapbase, object
g_heapbase:
.long _ebss+CONFIG_IDLETHREAD_STACKSIZE
.size g_heapbase, .-g_heapbase
.end

View File

@ -0,0 +1,93 @@
/***********************************************************************
* arch/arm/src/arm/lpc2378/lpc23xx_head.S
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS:
*
* Copyright (C) 2010 Gregory Nutt. All rights reserved.
*
* 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 "up_arch.h"
#include <sys/types.h>
#include "lpc23xx_scb.h"
#include "lpc23xx_pinsel.h"
#include "lpc23xx_uart.h"
#include "lpc23xx_gpio.h"
/***********************************************************************
* Definitions
***********************************************************************/
/******************************************************************************
* Name: IO_Init()
*
* Descriptions: Initialize the target board before running the main()
*
******************************************************************************/
void IO_Init( void )
{
uint32_t regval;
/* Reset all GPIO pins to default */
pinsel_putreg(0, PINSEL0_OFFSET);
pinsel_putreg(0, PINSEL1_OFFSET);
pinsel_putreg(0, PINSEL2_OFFSET);
pinsel_putreg(0, PINSEL3_OFFSET);
pinsel_putreg(0, PINSEL4_OFFSET);
pinsel_putreg(0, PINSEL5_OFFSET);
pinsel_putreg(0, PINSEL6_OFFSET);
pinsel_putreg(0, PINSEL7_OFFSET);
pinsel_putreg(0, PINSEL8_OFFSET);
pinsel_putreg(0, PINSEL9_OFFSET);
pinsel_putreg(0, PINSEL10_OFFSET);
/*
regval = scb_getreg(SCB_PCONP_OFFSET) & \
~(PCSDC | PCUART1 | PCI2C0 | PCSSP1 | PCEMC | );
scb_getreg( regval, SCB_PCONP_OFFSET );
*/
/* Turn off all peripheral power */
scb_putreg( 0, SCB_PCONP_OFFSET );
/* Turn on UART0/2 / Timer0 */
//~ regval = PCUART0 | PCUART2 | PCTIM0 | PCRTC ;
regval = PCUART0 | PCUART2 | PCTIM0 ;
scb_putreg( regval , SCB_PCONP_OFFSET );
/* Status LED P1.19 */
dir_putreg8((1 << 3), FIO1DIR2_OFFSET);
/* other io setup here */
return;
}

View File

@ -0,0 +1,291 @@
/****************************************************************************
* arch/arm/src/lpc2378/lpc23xx_irq.c
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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 <stdint.h>
#include <errno.h>
#include <debug.h>
#include <nuttx/irq.h>
#include "arm.h"
#include "chip.h"
#include "up_arch.h"
#include "os_internal.h"
#include "internal.h"
#include "lpc23xx_vic.h"
/****************************************************************************
* Definitions
****************************************************************************/
/****************************************************************************
* Public Data
****************************************************************************/
uint32_t *current_regs;
/****************************************************************************
* Private Data
****************************************************************************/
/****************************************************************************
* Private Functions
****************************************************************************/
/****************************************************************************
* Public Functions
****************************************************************************/
/****************************************************************************
* Name: up_irqinitialize
****************************************************************************/
void up_irqinitialize(void)
{
int reg;
/* Disable all interrupts. We do this by writing ones to the IntClearEnable
* register.
*/
vic_putreg(0xffffffff, VIC_INTENCLEAR_OFFSET);
/* Select all IRQs, FIQs are not used */
vic_putreg(0, VIC_INTSELECT_OFFSET);
/* Clear priority interrupts */
for (reg = 0; reg < NR_IRQS; reg++)
{
vic_putreg(0, VIC_VECTADDR0_OFFSET + (reg << 2));
vic_putreg(0x0F, VIC_VECTPRIORITY0_OFFSET + (reg << 2));
}
/* currents_regs is non-NULL only while processing an interrupt */
current_regs = NULL;
/* Enable global ARM interrupts */
#ifndef CONFIG_SUPPRESS_INTERRUPTS
irqrestore(SVC_MODE | PSR_F_BIT);
#endif
}
/***********************************************************************
* Name: up_enable_irq_protect
* VIC registers can be accessed in User or privileged mode
***********************************************************************/
static void up_enable_irq_protect(void)
{
//~ uint32_t reg32 = vic_getreg(VIC_PROTECTION_OFFSET);
//~ reg32 &= ~(0xFFFFFFFF);
vic_putreg(0x01, VIC_PROTECTION_OFFSET);
}
/***********************************************************************
* Name: up_disable_irq_protect
* VIC registers can only be accessed in privileged mode
***********************************************************************/
static void up_disable_irq_protect(void)
{
vic_putreg(0, VIC_PROTECTION_OFFSET);
}
/***********************************************************************
* Name: up_disable_irq
*
* Description:
* Disable the IRQ specified by 'irq'
*
***********************************************************************/
void up_disable_irq(int irq)
{
/* Verify that the IRQ number is within range */
if (irq < NR_IRQS)
{
/* Disable the irq by setting the corresponding bit in the VIC
* Interrupt Enable Clear register.
*/
vic_putreg((1 << irq), VIC_INTENCLEAR_OFFSET);
}
}
/***********************************************************************
* Name: up_enable_irq
*
* Description:
* Enable the IRQ specified by 'irq'
*
***********************************************************************/
void up_enable_irq(int irq)
{
/* Verify that the IRQ number is within range */
if (irq < NR_IRQS)
{
/* Disable all interrupts */
irqstate_t flags = irqsave();
/* Enable the irq by setting the corresponding bit in the VIC
* Interrupt Enable register.
*/
uint32_t val = vic_getreg(VIC_INTENABLE_OFFSET);
vic_putreg(val | (1 << irq), VIC_INTENABLE_OFFSET);
irqrestore(flags);
}
}
/****************************************************************************
* Name: up_maskack_irq
*
* Description:
* Mask the IRQ and acknowledge it
*
****************************************************************************/
void up_maskack_irq(int irq)
{
uint32_t reg32;
if ((unsigned)irq < NR_IRQS)
{
/* Mask the IRQ by clearing the associated bit in Software Priority Mask register */
reg32 = vic_getreg(VIC_PRIORITY_MASK_OFFSET);
reg32 &= ~(1 << irq);
vic_putreg(reg32, VIC_PRIORITY_MASK_OFFSET);
}
/* Clear interrupt */
vic_putreg((1<<irq), VIC_SOFTINTCLEAR_OFFSET);
#ifdef CONFIG_VECTORED_INTERRUPTS
vic_putreg(0, VIC_ADDRESS_OFFSET); /* dummy write to clear VICADDRESS */
#endif
}
/****************************************************************************
* Name: up_prioritize_irq
*
* Description:
* set interrupt priority
* MOD
****************************************************************************/
int up_prioritize_irq(int irq, int priority)
{
/* The default priority on reset is 16 */
if (irq < NR_IRQS && priority > 0 && priority < 16)
{
int offset = irq << 2;
vic_putreg( priority, VIC_VECTPRIORITY0_OFFSET + offset );
return OK;
}
return -EINVAL;
}
/****************************************************************************
* Name: up_attach_vector
*
* Description:
* Attach a user-supplied handler to a vectored interrupt
*
****************************************************************************/
#ifndef CONFIG_VECTORED_INTERRUPTS
void up_attach_vector(int irq, int vector, vic_vector_t handler)
{
/* Verify that the IRQ number and vector number are within range */
if (irq < NR_IRQS && vector < 32 && handler)
{
int offset = vector << 2;
/* Disable all interrupts */
irqstate_t flags = irqsave();
/* Save the vector address */
vic_putreg((uint32_t)handler, VIC_VECTADDR0_OFFSET + offset);
/* Set the interrupt priority */
up_prioritize_irq(irq, vector);
/* Enable the vectored interrupt */
uint32_t val = vic_getreg(VIC_INTENABLE_OFFSET);
vic_putreg(val | (1 << irq), VIC_INTENABLE_OFFSET);
irqrestore(flags);
}
}
#endif
/****************************************************************************
* Name: up_detach_vector
*
* Description:
* Detach a user-supplied handler from a vectored interrupt
*
****************************************************************************/
#ifdef CONFIG_VECTORED_INTERRUPTS
void up_detach_vector(int vector)
{
/* Verify that the vector number is within range */
if (vector < 32)
{
/* Disable the vectored interrupt */
int offset = vector << 2;
vic_putreg(0, (VIC_VECTADDR0_OFFSET + offset));
}
}
#endif

View File

@ -0,0 +1,262 @@
/**************************************************************************
* arch/arm/src/lpc2378/lpc23xx_lowputc.S
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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 "up_internal.h"
#include "up_arch.h"
#include "lpc23xx_pinsel.h"
#include "lpc23xx_scb.h"
#include "lpc23xx_uart.h"
/**************************************************************************
* Private Definitions
**************************************************************************/
@ //-- Pins
@ PINSEL0 |= (0x01<<4) | //-- P0.2 TXD0
@ (0x01<<6); //-- P0.3 RXD0
@PCLKSEL0 |= (0x01 << 6); //-- bit 7:6 =01-> Clock div = 1 for UART0
#if defined(CONFIG_UART0_SERIAL_CONSOLE)
# define UARTxBASE UART0_BASE_ADDR
# define PINSELECT LPC23XX_PINSEL0
# define UARTxPCLKSEL 0xE01FC1A8
# define PCLKSEL_MASK U0_PCLKSEL_MASK
# define UARTxPINSEL UART0_PINSEL
# define UARTxPINMASK UART0_PINMASK
# define UARTxBAUD CONFIG_UART0_BAUD
# define UARTxBITS CONFIG_UART0_BITS
# define UARTxPARITY CONFIG_UART0_PARITY
# define UARTx2STOP CONFIG_UART0_2STOP
#elif defined(CONFIG_UART1_SERIAL_CONSOLE)
# define UARTxBASE UART1_BASE_ADDR
/* # define PINSELECT LPC23XX_PINSEL1 only Uart0/Uart2 share same Pinsel */
# define UARTxPCLKSEL 0xE01FC1A8
# define PCLKSEL_MASK U1_PCLKSEL_MASK
# define UARTxPINSEL UART1_PINSEL
# define UARTxPINMASK UART1_PINMASK
# define UARTxBAUD CONFIG_UART1_BAUD
# define UARTxBITS CONFIG_UART1_BITS
# define UARTxPARITY CONFIG_UART1_PARITY
# define UARTx2STOP CONFIG_UART1_2STOP
#elif defined(CONFIG_UART2_SERIAL_CONSOLE)
# define UARTxBASE UART2_BASE_ADDR
# define PINSELECT LPC23XX_PINSEL0
# define UARTxPCLKSEL 0xE01FC1AC
# define PCLKSEL_MASK U2_PCLKSEL_MASK
# define UARTxPINSEL UART2_PINSEL
# define UARTxPINMASK UART2_PINMASK
# define UARTxBAUD CONFIG_UART2_BAUD
# define UARTxBITS CONFIG_UART2_BITS
# define UARTxPARITY CONFIG_UART2_PARITY
# define UARTx2STOP CONFIG_UART2_2STOP
#elif defined(CONFIG_UART3_SERIAL_CONSOLE)
# define PINSELECT LPC23XX_PINSEL0
# define UARTxBASE UART3_BASE_ADDR
# define UARTxPCLKSEL 0xE01FC1AC
# define PCLKSEL_MASK U2_PCLKSEL_MASK
# define UARTxPINSEL UART3_PINSEL
# define UARTxPINMASK UART3_PINMASK
# define UARTxBAUD CONFIG_UART3_BAUD
# define UARTxBITS CONFIG_UART3_BITS
# define UARTxPARITY CONFIG_UART3_PARITY
# define UARTx2STOP CONFIG_UART3_2STOP
#else
# error "No CONFIG_UARTn_SERIAL_CONSOLE Setting"
#endif
#if UARTxBITS == 5
# define LCR_CHAR LCR_CHAR_5
#elif UARTxBITS == 6
# define LCR_CHAR LCR_CHAR_6
#elif UARTxBITS == 7
# define LCR_CHAR LCR_CHAR_7
#elif UARTxBITS == 8
# define LCR_CHAR LCR_CHAR_8
#else
# error "No CONFIG_UARTn_BITS Setting"
#endif
#if UARTxPARITY == 0
# define LCR_PAR LCR_PAR_NONE
#elif UARTxPARITY == 1
# define LCR_PAR LCR_PAR_ODD
#elif UARTxPARITY == 2
# define LCR_PAR LCR_PAR_EVEN
#elif UARTxPARITY == 3
# define LCR_PAR LCR_PAR_MARK
#elif UARTxPARITY == 4
# define LCR_PAR LCR_PAR_SPACE
#else
# error "No CONFIG_UARTn_PARITY Setting"
#endif
#if UARTx2STOP != 0
# define LCR_STOP LCR_STOP_2
#else
# define LCR_STOP LCR_STOP_1
#endif
#define LCR_VALUE (LCR_CHAR | LCR_PAR | LCR_STOP)
#define FCR_VALUE (FCR_FIFO_TRIG8 | FCR_TX_FIFO_RESET | \
FCR_RX_FIFO_RESET | FCR_FIFO_ENABLE)
@#define MULVAL (12 << 4)
@#define DIVADDVAL 3
/**************************************************************************
* Private Types
**************************************************************************/
/**************************************************************************
* Private Function Prototypes
**************************************************************************/
/**************************************************************************
* Global Variables
**************************************************************************/
/**************************************************************************
* Private Variables
**************************************************************************/
/**************************************************************************
* Private Functions
**************************************************************************/
/**************************************************************************
* Public Functions
**************************************************************************/
/**************************************************************************
* Name: up_lowputc
**************************************************************************/
/* This assembly language version has the advantage that it does not
* require a C stack and uses only r0-r1. Hence it can be used during
* early boot phases.
*/
.text
.global up_lowputc
.type up_lowputc, function
up_lowputc:
/* On entry, r0 holds the character to be printed */
ldr r1, =UARTxBASE
strb r0, [r1, #UART_THR_OFFSET]
/* Wait for the byte to be transferred */
1: ldr r0, [r1, #UART_LSR_OFFSET]
ands r0, #LSR_TEMT /* Transmitter empty */
beq 1b
/* And return */
mov pc, lr
.size up_lowputc, . - up_lowputc
/* This performs basic initialization of the UART. This can be called very
* early in initialization because it does not depend on having a stack. It
* modifies r0-r2 and r14.
*/
.text
.globl up_lowsetup
.type up_lowsetup, function
up_lowsetup:
/* Configure PINSEL0 */
ldr r0, =PINSELECT /* TODO: generalize this for different uart pins */
ldr r1, [r0]
ldr r2, =(~UARTxPINMASK)
and r1, r2
ldr r2, =(UARTxPINSEL)
orr r1, r2
str r1, [r0]
/* Power Up Uart0 */
ldr r0, =UARTxPCLKSEL /* PCLKSEL0 address */
ldr r1, [r0]
ldr r2, =(~PCLKSEL_MASK)
and r1, r2
ldr r2, =(U0_PCLKSEL)
orr r1, r2
str r1, [r0]
/* Configure parity, data bits, stop bits and set DLAB=1 */
ldr r0, =UARTxBASE
mov r1, #(LCR_VALUE | LCR_DLAB_ENABLE)
strb r1, [r0, #UART_LCR_OFFSET]
/* Set the BAUD divisor */
mov r1, #((MULVAL << 4) | DIVADDVAL)
strb r1, [r0, #UART_FDR_OFFSET]
mov r1, #DLMVAL
strb r1, [r0, #UART_DLM_OFFSET]
mov r1, #DLLVAL
strb r1, [r0, #UART_DLL_OFFSET]
/* Clear DLAB and Set format 8N1 */
mov r1, #LCR_VALUE
strb r1, [r0, #UART_LCR_OFFSET]
/* Configure the FIFOs */
mov r1, #FCR_VALUE
strb r1, [r0, #UART_FCR_OFFSET]
mov r1, #LCR_VALUE
strb r1, [r0, #UART_LCR_OFFSET]
/* And return */
mov pc, lr
.size up_lowsetup, . - up_lowsetup
.end

View File

@ -0,0 +1,792 @@
/************************************************************************************
* arch/arm/src/lpc2378/lpc23xx_pinsel.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
************************************************************************************/
#ifndef _ARCH_ARM_SRC_LPC23XX_PINSEL_H
#define _ARCH_ARM_SRC_LPC23XX_PINSEL_H
/************************************************************************************
* Included Files
************************************************************************************/
#include "chip.h"
/************************************************************************************
* Definitions
************************************************************************************/
#define PINSEL_BASE 0xE002C000
#define pinsel_putreg8(v,o) putreg8( (v), LPC23XX_PINSEL_BASE+(o) )
#define pinsel_putreg(v,r) putreg32( (v),LPC23XX_PINSEL_BASE+ (r) )
#define pinsel_getreg(o) getreg32( PINSEL_BASE+(o) )
/* Register address definitions *****************************************************/
#define LPC23XX_PINSEL0 (PINSEL_BASE + PINSEL0_OFFSET)
#define LPC23XX_PINSEL1 (PINSEL_BASE + PINSEL1_OFFSET)
#define LPC23XX_PINSEL2 (PINSEL_BASE + PINSEL2_OFFSET)
#define LPC23XX_PINSEL3 (PINSEL_BASE + PINSEL3_OFFSET)
#define LPC23XX_PINSEL4 (PINSEL_BASE + PINSEL4_OFFSET)
#define LPC23XX_PINSEL5 (PINSEL_BASE + PINSEL5_OFFSET)
#define LPC23XX_PINSEL6 (PINSEL_BASE + PINSEL6_OFFSET)
#define LPC23XX_PINSEL7 (PINSEL_BASE + PINSEL7_OFFSET)
#define LPC23XX_PINSEL8 (PINSEL_BASE + PINSEL8_OFFSET)
#define LPC23XX_PINSEL9 (PINSEL_BASE + PINSEL9_OFFSET)
#define LPC23XX_PINSEL10 (PINSEL_BASE + PINSEL10_OFFSET)
/* PINSEL 0 */
#define PSEL0_P00_GPIO (0x00000000)
#define PSEL0_P00_RD1 (0x00000001)
#define PSEL0_P00_TXD3 (0x00000002)
#define PSEL0_P00_SDA1 (0x00000003)
#define PSEL0_P00_MASK (0x00000003)
#define PSEL0_P0_1_GPIO (0x00000000)
#define PSEL0_P0_1_TD1 (0x00000004)
#define PSEL0_P0_1_RXD3 (0x00000008)
#define PSEL0_P0_1_SCL1 (0x0000000c)
#define PSEL0_P0_1_MASK (0x0000000c)
#define PSEL0_P0_2_GPIO (0x00000000)
#define PSEL0_P0_2_TXD0 (0x00000010)
#define PSEL0_P0_2_RSVD2 (0x00000020)
#define PSEL0_P0_2_RSVD3 (0x00000030)
#define PSEL0_P0_2_MASK (0x00000030)
#define PSEL0_P0_3_GPIO (0x00000000)
#define PSEL0_P0_3_RXD0 (0x00000040)
#define PSEL0_P0_3_RSVD2 (0x00000080)
#define PSEL0_P0_3_RSVD3 (0x000000c0)
#define PSEL0_P0_3_MASK (0x000000c0)
#define PSEL0_P0_4_GPIO (0x00000000)
#define PSEL0_P0_4_I2SRX_CLK (0x00000100)
#define PSEL0_P0_4_RD2 (0x00000200)
#define PSEL0_P0_4_CAP20 (0x00000300)
#define PSEL0_P0_4_MASK (0x00000400)
#define PSEL0_P0_5_GPIO (0x00000000)
#define PSEL0_P0_5_I2SRX_WS (0x00000400)
#define PSEL0_P0_5_TD2 (0x00000800)
#define PSEL0_P0_5_CAP21 (0x00000c00)
#define PSEL0_P0_5_MASK (0x00000c00)
#define PSEL0_P0_6_GPIO (0x00000000)
#define PSEL0_P0_6_I2SRX_SDA (0x00001000)
#define PSEL0_P0_6_SSEL1 (0x00002000)
#define PSEL0_P0_6_MAT20 (0x00003000)
#define PSEL0_P0_6_MASK (0x00003000)
#define PSEL0_P0_7_GPIO (0x00000000)
#define PSEL0_P0_7_I2STX_CLK (0x00004000)
#define PSEL0_P0_7_SCK1 (0x00008000)
#define PSEL0_P0_7_MAT21 (0x0000c000)
#define PSEL0_P0_7_MASK (0x0000c000)
#define PSEL0_P0_8_GPIO (0x00000000)
#define PSEL0_P0_8_I2STX_WS (0x00010000)
#define PSEL0_P0_8_MISO1 (0x00020000)
#define PSEL0_P0_8_MAT22 (0x00030000)
#define PSEL0_P0_8_MASK (0x00030000)
#define PSEL0_P0_9_GPIO (0x00000000)
#define PSEL0_P0_9_I2STX_SDA (0x00040000)
#define PSEL0_P0_9_MOSI1 (0x00080000)
#define PSEL0_P0_9_MAT23 (0x000c0000)
#define PSEL0_P0_9_MASK (0x000c0000)
#define PSEL0_P0_10_GPIO (0x00000000)
#define PSEL0_P0_10_TXD2 (0x00100000)
#define PSEL0_P0_10_SDA2 (0x00200000)
#define PSEL0_P0_10_MAT30 (0x00300000)
#define PSEL0_P0_10_MASK (0x00300000)
#define PSEL0_P0_11_GPIO (0x00000000)
#define PSEL0_P0_11_RXD2 (0x00400000)
#define PSEL0_P0_11_SCL2 (0x00800000)
#define PSEL0_P0_11_MAT31 (0x00c00000)
#define PSEL0_P0_11_MASK (0x00c00000)
#define PSEL0_P0_12_GPIO (0x00000000)
#define PSEL0_P0_12_RSVD1 (0x01000000)
#define PSEL0_P0_12_MISO1 (0x02000000)
#define PSEL0_P0_12_AD06 (0x03000000)
#define PSEL0_P0_12_MASK (0x03000000)
#define PSEL0_P0_13_GPIO (0x00000000)
#define PSEL0_P0_13_USB_UPLED2 (0x04000000)
#define PSEL0_P0_13_MOSI1 (0x08000000)
#define PSEL0_P0_13_AD07 (0x0c000000)
#define PSEL0_P0_13_MASK (0x0c000000)
#define PSEL0_P0_14_GPIO (0x00000000)
#define PSEL0_P0_14_RSVD1 (0x10000000)
#define PSEL0_P0_14_USB_CONNECT2 (0x20000000)
#define PSEL0_P0_14_SSEL1 (0x30000000)
#define PSEL0_P0_14_MASK (0x30000000)
#define PSEL0_P0_15_GPIO (0x00000000)
#define PSEL0_P0_15_TXD1 (0x40000000)
#define PSEL0_P0_15_SCK0 (0x80000000)
#define PSEL0_P0_15_SCK (0xc0000000)
#define PSEL0_P0_15_MASK (0xc0000000)
/* PINSEL 1 */
#define PSEL1_P0_16_GPIO (0x00000000)
#define PSEL1_P0_16_RXD1 (0x00000001)
#define PSEL1_P0_16_SSEL0 (0x00000002)
#define PSEL1_P0_16_SSEL (0x00000003)
#define PSEL1_P0_16_MASK (0x00000003)
#define PSEL1_P0_17_GPIO (0x00000000)
#define PSEL1_P0_17_CTS1 (0x00000004)
#define PSEL1_P0_17_MISO0 (0x00000008)
#define PSEL1_P0_17_MISO (0x0000000c)
#define PSEL1_P0_17_MASK (0x0000000c)
#define PSEL1_P0_18_GPIO (0x00000000)
#define PSEL1_P0_18_DCD1 (0x00000010)
#define PSEL1_P0_18_MOSI0 (0x00000020)
#define PSEL1_P0_18_MOSI (0x00000030)
#define PSEL1_P0_18_MASK (0x00000030)
#define PSEL1_P0_19_GPIO (0x00000000)
#define PSEL1_P0_19_DSR1 (0x00000040)
#define PSEL1_P0_19_MCICLK (0x00000080)
#define PSEL1_P0_19_SDA1 (0x000000c0)
#define PSEL1_P0_19_MASK (0x000000c0)
#define PSEL1_P0_20_GPIO (0x00000000)
#define PSEL1_P0_20_DTR1 (0x00000100)
#define PSEL1_P0_20_MCICMD (0x00000200)
#define PSEL1_P0_20_SCL1 (0x00000300)
#define PSEL1_P0_20_MASK (0x00000300)
#define PSEL1_P0_21_GPIO (0x00000000)
#define PSEL1_P0_21_RI1 (0x00000400)
#define PSEL1_P0_21_MCIPWR (0x00000800)
#define PSEL1_P0_21_RD1 (0x00000c00)
#define PSEL1_P0_21_MASK (0x00000c00)
#define PSEL1_P0_22_GPIO (0x00000000)
#define PSEL1_P0_22_RTS1 (0x00001000)
#define PSEL1_P0_22_MCIDA0 (0x00002000)
#define PSEL1_P0_22_TD1 (0x00003000)
#define PSEL1_P0_22_MASK (0x00003000)
#define PSEL1_P0_23_GPIO (0x00000000)
#define PSEL1_P0_23_AD00 (0x00004000)
#define PSEL1_P0_23_I2SRX_CLK (0x00008000)
#define PSEL1_P0_23_CAP30 (0x0000c000)
#define PSEL1_P0_23_MASK (0x0000c000)
#define PSEL1_P0_24_GPIO (0x00000000)
#define PSEL1_P0_24_AD01 (0x00010000)
#define PSEL1_P0_24_I2SRX_WS (0x00020000)
#define PSEL1_P0_24_CAP31 (0x00030000)
#define PSEL1_P0_24_MASK (0x00030000)
#define PSEL1_P0_25_GPIO (0x00000000)
#define PSEL1_P0_25_AD02 (0x00040000)
#define PSEL1_P0_25_I2SRX_SDA (0x00080000)
#define PSEL1_P0_25_TXD3 (0x000c0000)
#define PSEL1_P0_25_MASK (0x000c0000)
#define PSEL1_P0_26_GPI0 (0x00000000)
#define PSEL1_P0_26_AD031 (0x00100000)
#define PSEL1_P0_26_AOUT (0x00200000)
#define PSEL1_P0_26_RXD3 (0x00300000)
#define PSEL1_P0_26_MASK (0x00300000)
#define PSEL1_P0_27_GPI0 (0x00000000)
#define PSEL1_P0_27_SDA0 (0x00400000)
#define PSEL1_P0_27_RSVD2 (0x00800000)
#define PSEL1_P0_27_RSVD3 (0x00c00000)
#define PSEL1_P0_27_MASK (0x00c00000)
#define PSEL1_P0_28_GPIO (0x00000000)
#define PSEL1_P0_28_SCL0 (0x01000000)
#define PSEL1_P0_28_RSVD2 (0x02000000)
#define PSEL1_P0_28_RSVD3 (0x03000000)
#define PSEL1_P0_28_MASK (0x03000000)
#define PSEL1_P0_29_GPIO (0x00000000)
#define PSEL1_P0_29_USB_DPOS1 (0x04000000)
#define PSEL1_P0_29_RSVD2 (0x08000000)
#define PSEL1_P0_29_RSVD3 (0x0c000000)
#define PSEL1_P0_29_MASK (0x0c000000)
#define PSEL1_P0_30_GPIO (0x00000000)
#define PSEL1_P0_30_USB_DNEG1 (0x10000000)
#define PSEL1_P0_30_RSVD2 (0x20000000)
#define PSEL1_P0_30_RSVD3 (0x30000000)
#define PSEL1_P0_30_MASK (0x30000000)
#define PSEL1_P0_31_GPIO (0x00000000)
#define PSEL1_P0_31_USB_DPOS2 (0x40000000)
#define PSEL1_P0_31_RSVD2 (0x80000000)
#define PSEL1_P0_31_RSVD3 (0xc0000000)
#define PSEL1_P0_31_MASK (0xc0000000)
/* PINSEL 2 */
#define PSEL2_P1_0_GPIO (0x00000000)
#define PSEL2_P1_0_ENET_TXD0 (0x00000001)
#define PSEL2_P1_0_RSVD2 (0x00000002)
#define PSEL2_P1_0_RSVD3 (0x00000003)
#define PSEL2_P1_0_MASK (0x00000003)
#define PSEL2_P1_1_GPIO (0x00000000)
#define PSEL2_P1_1_ENET_TXD1 (0x00000004)
#define PSEL2_P1_1_RSVD2 (0x00000008)
#define PSEL2_P1_1_RSVD3 (0x0000000c)
#define PSEL2_P1_1_MASK (0x0000000c)
#define PSEL2_P1_2_RSVD0 (0x00000000)
#define PSEL2_P1_2_RSVD1 (0x00000010)
#define PSEL2_P1_2_RSVD2 (0x00000020)
#define PSEL2_P1_2_RSVD3 (0x00000030)
#define PSEL2_P1_2_MASK (0x00000030)
#define PSEL2_P1_3_RSVD0 (0x00000000)
#define PSEL2_P1_3_RSVD1 (0x00000040)
#define PSEL2_P1_3_RSVD2 (0x00000080)
#define PSEL2_P1_3_RSVD3 (0x000000c0)
#define PSEL2_P1_3_MASK (0x000000c0)
#define PSEL2_P1_4_GPIO (0x00000000)
#define PSEL2_P1_4_ENET_TX_EN (0x00000100)
#define PSEL2_P1_4_RSVD2 (0x00000200)
#define PSEL2_P1_4_RSVD3 (0x00000300)
#define PSEL2_P1_4_MASK (0x00000300)
#define PSEL2_P1_5_RSVDO (0x00000000)
#define PSEL2_P1_5_RSVD1 (0x00000400)
#define PSEL2_P1_5_RSVD2 (0x00000800)
#define PSEL2_P1_5_RSVD3 (0x00000c00)
#define PSEL2_P1_5_MASK (0x00000c00)
#define PSEL2_P1_6_RSVD0 (0x00000000)
#define PSEL2_P1_6_RSVD1 (0x00001000)
#define PSEL2_P1_6_RSVD2 (0x00002000)
#define PSEL2_P1_6_RSVD3 (0x00003000)
#define PSEL2_P1_6_MASK (0x00003000)
#define PSEL2_P1_7_RSVD0 (0x00000000)
#define PSEL2_P1_7_RSVD1 (0x00004000)
#define PSEL2_P1_7_RSVD2 (0x00008000)
#define PSEL2_P1_7_RSVD3 (0x0000c000)
#define PSEL2_P1_7_MASK (0x0000c000)
#define PSEL2_P1_8_GPIO (0x00000000)
#define PSEL2_P1_8_ENET_CRS (0x00010000)
#define PSEL2_P1_8_RSVD2 (0x00020000)
#define PSEL2_P1_8_RSVD3 (0x00030000)
#define PSEL2_P1_8_MASK (0x00030000)
#define PSEL2_P1_9_GPIO (0x00000000)
#define PSEL2_P1_9_ENET_RXD0 (0x00040000)
#define PSEL2_P1_9_RSVD2 (0x00080000)
#define PSEL2_P1_9_RSVD3 (0x000c0000)
#define PSEL2_P1_9_MASK (0x000c0000)
#define PSEL2_P1_10_GPI0 (0x00000000)
#define PSEL2_P1_10_ENET_RXD1 (0x00100000)
#define PSEL2_P1_10_RSVD2 (0x00200000)
#define PSEL2_P1_10_RSVD3 (0x00300000)
#define PSEL2_P1_10_MASK (0x00300000)
#define PSEL2_P1_11_RSVD0 (0x00000000)
#define PSEL2_P1_11_RSVD1 (0x00400000)
#define PSEL2_P1_11_RSVD2 (0x00800000)
#define PSEL2_P1_11_RSVD3 (0x00c00000)
#define PSEL2_P1_11_MASK (0x00c00000)
#define PSEL2_P1_12_RSVD0 (0x00000000)
#define PSEL2_P1_12_RSVD1 (0x01000000)
#define PSEL2_P1_12_RSVD2 (0x02000000)
#define PSEL2_P1_12_RSVD3 (0x03000000)
#define PSEL2_P1_12_MASK (0x03000000)
#define PSEL2_P1_13_RSVD0 (0x00000000)
#define PSEL2_P1_13_RSVD1 (0x04000000)
#define PSEL2_P1_13_RSVD2 (0x08000000)
#define PSEL2_P1_13_RSVD3 (0x0c000000)
#define PSEL2_P1_13_MASK (0x0c000000)
#define PSEL2_P1_14_GPIO (0x00000000)
#define PSEL2_P1_14_ENET_RX_ER (0x10000000)
#define PSEL2_P1_14_RSVD2 (0x20000000)
#define PSEL2_P1_14_RSVD3 (0x30000000)
#define PSEL2_P1_14_MASK (0x30000000)
#define PSEL2_P1_15_GPIO (0x00000000)
#define PSEL2_P1_15_ENET_REF_CLK (0x40000000)
#define PSEL2_P1_15_RSVD2 (0x80000000)
#define PSEL2_P1_15_RSVD3 (0xc0000000)
#define PSEL2_P1_15_MASK (0xc0000000)
/* PINSEL 3 */
#define PSEL3_P1_16_GPIO (0x00000000)
#define PSEL3_P1_16_ENET_MDC (0x00000001)
#define PSEL3_P1_16_RSVD2 (0x00000002)
#define PSEL3_P1_16_RSVD3 (0x00000003)
#define PSEL3_P1_16_MASK (0x00000003)
#define PSEL3_P1_17_GPIO (0x00000000)
#define PSEL3_P1_17_ENET_MDIO (0x00000004)
#define PSEL3_P1_17_RSVD2 (0x00000008)
#define PSEL3_P1_17_RSVD3 (0x0000000c)
#define PSEL3_P1_17_MASK (0x0000000c)
#define PSEL3_P1_18_GPIO (0x00000000)
#define PSEL3_P1_18_USB_UP_LED1 (0x00000010)
#define PSEL3_P1_18_PWM1_1 (0x00000020)
#define PSEL3_P1_18_CAP1_0 (0x00000030)
#define PSEL3_P1_18_MASK (0x00000030)
#define PSEL3_P1_19_GPIO (0x00000000)
#define PSEL3_P1_19_USB_TX_E1 (0x00000040) /* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_19_USB_PPWR1 (0x00000080) /* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_19_CAP1_1 (0x000000c0)
#define PSEL3_P1_19_MASK (0x000000c0)
#define PSEL3_P1_20_GPIO (0x00000000)
#define PSEL3_P1_20_USB_TX_DP1 (0x00000100)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_20_PWM1_2 (0x00000200)
#define PSEL3_P1_20_SCK0 (0x00000300)
#define PSEL3_P1_20_MASK (0x00000300)
#define PSEL3_P1_21_GPIO (0x00000000)
#define PSEL3_P1_21_USB_TX_DM1 (0x00000400)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_21_PWM1_3 (0x00000800)
#define PSEL3_P1_21_SSEL0 (0x00000c00)
#define PSEL3_P1_21_MASK (0x00000c00)
#define PSEL3_P1_22_GPIO (0x00000000)
#define PSEL3_P1_22_USB_RCV1 (0x00001000) /* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_22_USB_PWRD1 (0x00002000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_22_MAT1_0 (0x00003000)
#define PSEL3_P1_22_MASK (0x00003000)
#define PSEL3_P1_23_GPIO (0x00000000)
#define PSEL3_P1_23_USB_RX_DP1 (0x00004000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_23_PWM1_4 (0x00008000)
#define PSEL3_P1_23_MISO0 (0x0000c000)
#define PSEL3_P1_23_MASK (0x0000c000)
#define PSEL3_P1_24_GPIO (0x00000000)
#define PSEL3_P1_24_USB_RX_DM1 (0x00010000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_24_PWM1_5 (0x00020000)
#define PSEL3_P1_24_MOSI0 (0x00030000)
#define PSEL3_P1_24_MASK (0x00030000)
#define PSEL3_P1_25_GPIO (0x00000000)
#define PSEL3_P1_25_USB_LS1 (0x00040000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_25_USB_HSTEN1 (0x00080000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_25_MAT1_1 (0x000c0000)
#define PSEL3_P1_25_MASK (0x000c0000)
#define PSEL3_P1_26_GPI0 (0x00000000)
#define PSEL3_P1_26_USB_SSPND1 (0x00100000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_26_PWM1_6 (0x00200000)
#define PSEL3_P1_26_CAP0_0 (0x00300000)
#define PSEL3_P1_26_MASK (0x00300000)
#define PSEL3_P1_27_GPIO (0x00000000)
#define PSEL3_P1_27_USB_INT1 (0x00400000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_27_USB_OVRCR1 (0x00800000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_27_CAP0_1 (0x00c00000)
#define PSEL3_P1_27_MASK (0x00c00000)
#define PSEL3_P1_28_GPIO (0x00000000)
#define PSEL3_P1_28_USB_SCL1 (0x01000000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_28_PCAP1_0 (0x02000000)
#define PSEL3_P1_28_MAT0_0 (0x03000000)
#define PSEL3_P1_28_MASK (0x03000000)
#define PSEL3_P1_29_GPIO (0x00000000)
#define PSEL3_P1_29_USB_SDA1 (0x04000000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_29_PCAP1_1 (0x08000000)
#define PSEL3_P1_29_MAT0_1 (0x0c000000)
#define PSEL3_P1_29_MASK (0x0c000000)
#define PSEL3_P1_30_GPIO (0x00000000)
#define PSEL3_P1_30_USB_PWRD2 (0x10000000)
#define PSEL3_P1_30_VBUS (0x20000000)
#define PSEL3_P1_30_AD0_4 (0x30000000)
#define PSEL3_P1_30_MASK (0x30000000)
#define PSEL3_P1_31_GPIO (0x00000000)
#define PSEL3_P1_31_USB_OVRCR2 (0x40000000)/* 2388 only Reserved on 2377/78 */
#define PSEL3_P1_31_SCK1 (0x80000000)
#define PSEL3_P1_31_AD0_5 (0xc0000000)
#define PSEL3_P1_31_MASK (0xc0000000)
/* PINSEL 4 */
#define PSEL4_P2_0_GPIO (0x00000000)
#define PSEL4_P2_0_PWM1_1 (0x00000001)
#define PSEL4_P2_0_TXD1 (0x00000002)
#define PSEL4_P2_0_TRACECLK (0x00000003)
#define PSEL4_P2_0_MASK (0x00000003)
#define PSEL4_P2_1_GPIO (0x00000000)
#define PSEL4_P2_1_PWM1_2 (0x00000004)
#define PSEL4_P2_1_RXD1 (0x00000008)
#define PSEL4_P2_1_PIPESTAT0 (0x0000000c)
#define PSEL4_P2_1_MASK (0x0000000c)
#define PSEL4_P2_2_GPIO (0x00000000)
#define PSEL4_P2_2_PWM1_3 (0x00000010)
#define PSEL4_P2_2_CTS1 (0x00000020)
#define PSEL4_P2_2_PIPESTAT1 (0x00000030)
#define PSEL4_P2_2_MASK (0x00000030)
#define PSEL4_P2_3_GPIO (0x00000000)
#define PSEL4_P2_3_PWM1_4 (0x00000040)
#define PSEL4_P2_3_DCD1 (0x00000080)
#define PSEL4_P2_3_PIPESTAT2 (0x000000c0)
#define PSEL4_P2_3_MASK (0x000000c0)
#define PSEL4_P2_4_GPIO (0x00000000)
#define PSEL4_P2_4_PWM1_5 (0x00000100)
#define PSEL4_P2_4_DSR1 (0x00000200)
#define PSEL4_P2_4_TRACESYNC (0x00000300)
#define PSEL4_P2_4_MASK (0x00000300)
#define PSEL4_P2_5_GPIO (0x00000000)
#define PSEL4_P2_5_PWM1_6 (0x00000400)
#define PSEL4_P2_5_DTR1 (0x00000800)
#define PSEL4_P2_5_TRACEPKT0 (0x00000c00)
#define PSEL4_P2_5_MASK (0x00000c00)
#define PSEL4_P2_6_GPIO (0x00000000)
#define PSEL4_P2_6_PCAP1_0 (0x00001000)
#define PSEL4_P2_6_RI1 (0x00002000)
#define PSEL4_P2_6_TRACEPKT1 (0x00003000)
#define PSEL4_P2_6_MASK (0x00003000)
#define PSEL4_P2_7_GPIO (0x00000000)
#define PSEL4_P2_7_RD2 (0x00004000)
#define PSEL4_P2_7_RTS1 (0x00008000)
#define PSEL4_P2_7_TRACEPKT2 (0x0000c000)
#define PSEL4_P2_7_MASK (0x0000c000)
#define PSEL4_P2_8_GPIO (0x00000000)
#define PSEL4_P2_8_TD2 (0x00010000)
#define PSEL4_P2_8_TXD2 (0x00020000)
#define PSEL4_P2_8_TRACEPKT3 (0x00030000)
#define PSEL4_P2_8_MASK (0x00030000)
#define PSEL4_P2_9_GPIO (0x00000000)
#define PSEL4_P2_9_USB_CONNECT1 (0x00040000)
#define PSEL4_P2_9_RXD2 (0x00080000)
#define PSEL4_P2_9_EXTIN0 (0x000c0000)
#define PSEL4_P2_9_MASK (0x000c0000)
#define PSEL4_P2_10_GPI0 (0x00000000)
#define PSEL4_P2_10_EINT0 (0x00100000)
#define PSEL4_P2_10_RSVD2 (0x00200000)
#define PSEL4_P2_10_RSVD3 (0x00300000)
#define PSEL4_P2_10_MASK (0x00300000)
#define PSEL4_P2_11_GPIO (0x00000000)
#define PSEL4_P2_11_EINT1 (0x00400000)
#define PSEL4_P2_11_MCIDAT1 (0x00800000)
#define PSEL4_P2_11_I2STX_CLK (0x00c00000)
#define PSEL4_P2_11_MASK (0x00c00000)
#define PSEL4_P2_12_GPIO (0x00000000)
#define PSEL4_P2_12_EINT2 (0x01000000)
#define PSEL4_P2_12_MCIDAT2 (0x02000000)
#define PSEL4_P2_12_I2STX_WS (0x03000000)
#define PSEL4_P2_12_MASK (0x03000000)
#define PSEL4_P2_13_GPIO (0x00000000)
#define PSEL4_P2_13_EINT3 (0x04000000)
#define PSEL4_P2_13_MCIDAT3 (0x08000000)
#define PSEL4_P2_13_I2STX_SDA (0x0c000000)
#define PSEL4_P2_13_MASK (0x0c000000)
#define PSEL4_P2_14_RSVD0 (0x00000000)
#define PSEL4_P2_14_RSVD1 (0x10000000)
#define PSEL4_P2_14_RSVD2 (0x20000000)
#define PSEL4_P2_14_RSVD3 (0x30000000)
#define PSEL4_P2_14_MASK (0x30000000)
#define PSEL4_P2_15_RSVD0 (0x00000000)
#define PSEL4_P2_15_RSVD1 (0x40000000)
#define PSEL4_P2_15_RSVD2 (0x80000000)
#define PSEL4_P2_15_RSVD3 (0xc0000000)
#define PSEL4_P2_15_MASK (0xc0000000)
/* PINSEL 5 All reserved */
/* PINSEL 6 */
#define PSEL6_P3_0_GPIO (0x00000000)
#define PSEL6_P3_0_D0 (0x00000001)
#define PSEL6_P3_0_RSVD2 (0x00000002)
#define PSEL6_P3_0_RSVD3 (0x00000003)
#define PSEL6_P3_0_MASK (0x00000003)
#define PSEL6_P3_1_GPIO (0x00000000)
#define PSEL6_P3_1_D1 (0x00000004)
#define PSEL6_P3_1_RSVD2 (0x00000008)
#define PSEL6_P3_1_RSVD3 (0x0000000c)
#define PSEL6_P3_1_MASK (0x0000000c)
#define PSEL6_P3_2_GPIO (0x00000000)
#define PSEL6_P3_2_D2 (0x00000010)
#define PSEL6_P3_2_RSVD2 (0x00000020)
#define PSEL6_P3_2_RSVD3 (0x00000030)
#define PSEL6_P3_2_MASK (0x00000030)
#define PSEL6_P3_3_GPIO (0x00000000)
#define PSEL6_P3_3_D3 (0x00000040)
#define PSEL6_P3_3_RSVD2 (0x00000080)
#define PSEL6_P3_3_RSVD3 (0x000000c0)
#define PSEL6_P3_3_MASK (0x000000c0)
#define PSEL6_P3_4_GPIO (0x00000000)
#define PSEL6_P3_4_D4 (0x00000100)
#define PSEL6_P3_4_RSVD2 (0x00000200)
#define PSEL6_P3_4_RSVD3 (0x00000300)
#define PSEL6_P3_4_MASK (0x00000400)
#define PSEL6_P3_5_GPIO (0x00000000)
#define PSEL6_P3_5_D5 (0x00000400)
#define PSEL6_P3_5_RSVD2 (0x00000800)
#define PSEL6_P3_5_RSVD3 (0x00000c00)
#define PSEL6_P3_5_MASK (0x00000c00)
#define PSEL6_P3_6_GPIO (0x00000000)
#define PSEL6_P3_6_D6 (0x00001000)
#define PSEL6_P3_6_RSVD2 (0x00002000)
#define PSEL6_P3_6_RSVD3 (0x00003000)
#define PSEL6_P3_6_MASK (0x00003000)
#define PSEL6_P3_7_GPIO (0x00000000)
#define PSEL6_P3_7_D7 (0x00004000)
#define PSEL6_P3_7_RSVD2 (0x00008000)
#define PSEL6_P3_7_RSVD3 (0x0000c000)
#define PSEL6_P3_7_MASK (0x0000c000)
/* Rest of PSEL 6 are reserved */
/* PINSEL 7 */
/* PINSEL 7 bit 0:13 are reserved */
#define PSEL7_P3_23_GPIO (0x00000000)
#define PSEL7_P3_23_RSVD1 (0x00004000)
#define PSEL7_P3_23_CAP0_0 (0x00008000)
#define PSEL7_P3_23_PCAP1_0 (0x0000c000)
#define PSEL7_P3_23_MASK (0x0000c000)
#define PSEL7_P3_24_GPIO (0x00000000)
#define PSEL7_P3_24_RSVD1 (0x00010000)
#define PSEL7_P3_24_CAP0_1 (0x00020000)
#define PSEL7_P3_24_PWM1_1 (0x00030000)
#define PSEL7_P3_24_MASK (0x00030000)
#define PSEL7_P3_25_GPIO (0x00000000)
#define PSEL7_P3_25_RSVD1 (0x00040000)
#define PSEL7_P3_25_MAT0_0 (0x00080000)
#define PSEL7_P3_25_PWM1_2 (0x000c0000)
#define PSEL7_P3_25_MASK (0x000c0000)
#define PSEL7_P3_26_GPI0 (0x00000000)
#define PSEL7_P3_26_RSVD1 (0x00100000)
#define PSEL7_P3_26_MAT0_1 (0x00200000)
#define PSEL7_P3_26_PWM1_3 (0x00300000)
#define PSEL7_P3_26_MASK (0x00300000)
/* PINSEL 7 rest are reserved */
/* PINSEL 8 */
#define PSEL8_P4_0_GPIO (0x00000000)
#define PSEL8_P4_0_A0 (0x00000001)
#define PSEL8_P4_0_RSVD2 (0x00000002)
#define PSEL8_P4_0_RSVD3 (0x00000003)
#define PSEL8_P4_0_MASK (0x00000003)
#define PSEL8_P4_1_GPIO (0x00000000)
#define PSEL8_P4_1_A1 (0x00000004)
#define PSEL8_P4_1_RXD3 (0x00000008)
#define PSEL8_P4_1_SCL1 (0x0000000c)
#define PSEL8_P4_1_MASK (0x0000000c)
#define PSEL8_P4_2_GPIO (0x00000000)
#define PSEL8_P4_2_A2 (0x00000010)
#define PSEL8_P4_2_RSVD2 (0x00000020)
#define PSEL8_P4_2_RSVD3 (0x00000030)
#define PSEL8_P4_2_MASK (0x00000030)
#define PSEL8_P4_3_GPIO (0x00000000)
#define PSEL8_P4_3_A3 (0x00000040)
#define PSEL8_P4_3_RSVD2 (0x00000080)
#define PSEL8_P4_3_RSVD3 (0x000000c0)
#define PSEL8_P4_3_MASK (0x000000c0)
#define PSEL8_P4_4_GPIO (0x00000000)
#define PSEL8_P4_4_A4 (0x00000100)
#define PSEL8_P4_4_RSVD2 (0x00000200)
#define PSEL8_P4_4_RSVD3 (0x00000300)
#define PSEL8_P4_4_MASK (0x00000400)
#define PSEL8_P4_5_GPIO (0x00000000)
#define PSEL8_P4_5_A5 (0x00000400)
#define PSEL8_P4_5_RSVD2 (0x00000800)
#define PSEL8_P4_5_RSVD3 (0x00000c00)
#define PSEL8_P4_5_MASK (0x00000c00)
#define PSEL8_P4_6_GPIO (0x00000000)
#define PSEL8_P4_6_A6 (0x00001000)
#define PSEL8_P4_6_RSVD2 (0x00002000)
#define PSEL8_P4_6_RSVD3 (0x00003000)
#define PSEL8_P4_6_MASK (0x00003000)
#define PSEL8_P4_7_GPIO (0x00000000)
#define PSEL8_P4_7_A7 (0x00004000)
#define PSEL8_P4_7_RSVD2 (0x00008000)
#define PSEL8_P4_7_RSVD3 (0x0000c000)
#define PSEL8_P4_7_MASK (0x0000c000)
#define PSEL8_P4_8_GPIO (0x00000000)
#define PSEL8_P4_8_A8 (0x00010000)
#define PSEL8_P4_8_RSVD2 (0x00020000)
#define PSEL8_P4_8_RSVD3 (0x00030000)
#define PSEL8_P4_8_MASK (0x00030000)
#define PSEL8_P4_9_GPIO (0x00000000)
#define PSEL8_P4_9_A9 (0x00040000)
#define PSEL8_P4_9_RSVD2 (0x00080000)
#define PSEL8_P4_9_RSVD3 (0x000c0000)
#define PSEL8_P4_9_MASK (0x000c0000)
#define PSEL8_P4_10_GPIO (0x00000000)
#define PSEL8_P4_10_A10 (0x00100000)
#define PSEL8_P4_10_RSVD2 (0x00200000)
#define PSEL8_P4_10_RSVD3 (0x00300000)
#define PSEL8_P4_10_MASK (0x00300000)
#define PSEL8_P4_11_GPIO (0x00000000)
#define PSEL8_P4_11_A11 (0x00400000)
#define PSEL8_P4_11_RSVD2 (0x00800000)
#define PSEL8_P4_11_RSVD3 (0x00c00000)
#define PSEL8_P4_11_MASK (0x00c00000)
#define PSEL8_P4_12_GPIO (0x00000000)
#define PSEL8_P4_12_A12 (0x01000000)
#define PSEL8_P4_12_RSVD2 (0x02000000)
#define PSEL8_P4_12_RSVD3 (0x03000000)
#define PSEL8_P4_12_MASK (0x03000000)
#define PSEL8_P4_13_GPIO (0x00000000)
#define PSEL8_P4_13_A13 (0x04000000)
#define PSEL8_P4_13_RSVD2 (0x08000000)
#define PSEL8_P4_13_RSVD3 (0x0c000000)
#define PSEL8_P4_13_MASK (0x0c000000)
#define PSEL8_P4_14_GPIO (0x00000000)
#define PSEL8_P4_14_A14 (0x10000000)
#define PSEL8_P4_14_RSVD2 (0x20000000)
#define PSEL8_P4_14_RSVD3 (0x30000000)
#define PSEL8_P4_14_MASK (0x30000000)
#define PSEL8_P4_15_GPIO (0x00000000)
#define PSEL8_P4_15_A15 (0x40000000)
#define PSEL8_P4_15_RSVD2 (0x80000000)
#define PSEL8_P4_15_RSVD3 (0xc0000000)
#define PSEL8_P4_15_MASK (0xc0000000)
/* PINSEL 9 */
/* PINSEL 9 bit 0:15 are reserved */
#define PSEL9_P4_24_GPIO (0x00000000)
#define PSEL9_P4_24_OE (0x00010000)
#define PSEL9_P4_24_RSVD2 (0x00020000)
#define PSEL9_P4_24_RSVD3 (0x00030000)
#define PSEL9_P4_24_MASK (0x00030000)
#define PSEL9_P4_25_GPIO (0x00000000)
#define PSEL9_P4_25_ (0x00040000)
#define PSEL9_P4_25_BLS0 (0x00080000)
#define PSEL9_P4_25_RSVD3 (0x000c0000)
#define PSEL9_P4_25_MASK (0x000c0000)
/* PINSEL 9 bit 26:27 are reserved */
#define PSEL9_P4_28_GPIO (0x00000000)
#define PSEL9_P4_28_RSVD1 (0x01000000)
#define PSEL9_P4_28_MAT2_0 (0x02000000)
#define PSEL9_P4_28_TXD3 (0x03000000)
#define PSEL9_P4_28_MASK (0x03000000)
#define PSEL9_P4_29_GPIO (0x00000000)
#define PSEL9_P4_29_RSVD1 (0x04000000)
#define PSEL9_P4_29_MAT2_1 (0x08000000)
#define PSEL9_P4_29_RXD3 (0x0c000000)
#define PSEL9_P4_29_MASK (0x0c000000)
#define PSEL9_P4_30_GPIO (0x00000000)
#define PSEL9_P4_30_CS0 (0x10000000)
#define PSEL9_P4_30_RSVD2 (0x20000000)
#define PSEL9_P4_30_RSVD3 (0x30000000)
#define PSEL9_P4_30_MASK (0x30000000)
#define PSEL9_P4_31_GPIO (0x00000000)
#define PSEL9_P4_31_CS1 (0x40000000)
#define PSEL9_P4_31_RSVD2 (0x80000000)
#define PSEL9_P4_31_RSVD3 (0xc0000000)
#define PSEL9_P4_31_MASK (0xc0000000)
/* PINSEL 10 */
#define PSEL10_ETM (0x00000002)
/* TODO PINMODE pullup/pulldown resistor configuration */
/************************************************************************************
* Public Types
************************************************************************************/
/************************************************************************************
* Inline Functions
************************************************************************************/
/************************************************************************************
* Public Function Prototypes
************************************************************************************/
#endif /* _ARCH_ARM_SRC_LPC23XX_PINSEL_H */

View File

@ -0,0 +1,238 @@
/****************************************************************************
* arch/arm/src/lpc2378/lpc23xx_irq.c
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS:
*
* Copyright (C) 2010 Gregory Nutt. All rights reserved.
*
* 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.
*
****************************************************************************/
/* This file holds the NuttX start logic that runs when the LPC2378
* is reset. This logic must be located at address 0x0000:0000 in
* flash but may be linked to run at different locations based on
* the selected mode:
*
* default: Executes from 0x0000:0000. In non-default modes, the
* MEMAP register is set override the settings of the CPU configuration
* pins.
*
* CONFIG_EXTMEM_MODE: Code executes from external memory starting at
* address 0x8000:0000.
*
* CONFIG_RAM_MODE: Code executes from on-chip RAM at address
* 0x4000:0000.
*
* Starupt Code must be linked to run at the correct address
* corresponding to the selected mode.
*/
/***********************************************************************
* Included Files
**********************************************************************/
#include <nuttx/config.h>
#include <arch/board/board.h>
#include <sys/types.h>
#include "arm.h"
#include "up_arch.h"
#include "internal.h"
#include "lpc23xx_pinsel.h"
#include "lpc23xx_scb.h"
extern void IO_Init(void);
/***********************************************************************
* Definitions
**********************************************************************/
#if ((FOSC < 32000) || (FOSC > 50000000))
# error Fosc out of range (32KHz-50MHz)
# error correct and recompile
#endif
#if ((CCLK < 10000000) || (CCLK > 72000000))
# error cclk out of range (10MHz-72MHz)
# error correct PLL MULTIPLIER and recompile
#endif
#if ((FCCO < 275000000) || (FCCO > 550000000))
# error Fcco out of range (275MHz-550MHz)
# error internal algorithm error
#endif
/* Phase Locked Loop (PLL) initialization values
*
* Bit 0:14 MSEL: PLL Multiplier "M" Value
* CCLK = 57 600 000 Hz
* Bit 16:23 NSEL: PLL Divider "N" Value
* Fcco = (2 * M * F_in) / N
* 275MHz <= Fcco <= 550MHz
*
* PLL clock sources:
* Internal RC 0 default on reset
* Main Oscillator 1
* RTC 2
*/
#ifdef CONFIG_PLL_CLKSRC
# if ( (CONFIG_PLL_CLKSRC < 0) || (CONFIG_PLL_CLKSRC > 2) )
# error "PLL clock source not valid, check configuration "
# endif
#else
# error "PLL clock source not defined, check configuration file"
#endif
/* PLL provides CCLK and must always be configured */
#define PLL ( PLL_M | (PLL_N << 16) )
/* Memory Accelerator Module (MAM) initialization values
*
* MAM Control Register
* Bit 0:1 Mode
* 0 = Disabled
* 1 = Partially Enabled
* 2 = Fully Enabled
* MAM Timing Register
* Bit 0:2 Fetch Cycles
* 0 = Reserved
* 1 = 1 CCLK
* 2 = 2 CCLK
* 3 = 3 CCLK
* 4 = 4 CCLK
* 5 = 5 CCLK
* 6 = 6 CCLK
* 7 = 7 CCLK
*/
/* LPC2378 Rev. '-' errata MAM may not work if fully enabled */
#ifdef CONFIG_MAM_SETUP
# ifndef CONFIG_MAMCR_VALUE /* Can be selected from config file */
# define CONFIG_MAMCR_VALUE (MAMCR_PART)
# endif
# ifndef CONFIG_MAMTIM_VALUE /* Can be selected from config file */
# define CONFIG_MAMTIM_VALUE (0x00000003)
# endif
#endif
/****************************************************************************
* Private Functions
****************************************************************************/
/****************************************************************************
* Name: up_scbpllfeed
****************************************************************************/
static inline void up_scbpllfeed(void)
{
SCB_PLLFEED = 0xAA;
SCB_PLLFEED = 0x55;
}
/****************************************************************************
* Name: ConfigurePLL
****************************************************************************/
void ConfigurePLL ( void )
{
uint32_t MSel, NSel;
/* LPC2378 Rev.'-' errata Enable the Ethernet block to enable 16k EnetRAM */
SCB_PCONP |= PCENET;
/* Vectors are remapped to Flash */
SCB_MEMMAP = MEMMAP2FLASH;
/* Enable PLL, disconnected */
if(SCB_PLLSTAT & (1 << 25))
{
SCB_PLLCON = 0x01;
up_scbpllfeed();
}
/* Disable PLL, disconnected */
SCB_PLLCON = 0;
up_scbpllfeed();
/* Enable main OSC */
SCB_SCS |= 0x20;
/* Wait until main OSC is usable */
while( !(SCB_SCS & 0x40) );
/* select main OSC, 12MHz, as the PLL clock source */
SCB_CLKSRCSEL = CONFIG_PLL_CLKSRC;
/* Reconfigure PLL */
SCB_PLLCFG = PLL;
up_scbpllfeed();
/* Enable PLL */
SCB_PLLCON = 0x01;
up_scbpllfeed();
/* Set clock divider */
SCB_CCLKCFG = CCLK_DIV;
#ifdef CONFIG_USBDEV
/* usbclk = 288 MHz/6 = 48 MHz */
SCB_USBCLKCFG = USBCLK_DIV;
/* Turn On USB PCLK */
SCB_PCONP |= PCUSB;
#endif
/* Wait for PLL to lock */
while( ( SCB_PLLSTAT & (1 << 26) ) == 0);
MSel = SCB_PLLSTAT & 0x00007FFF;
NSel = ( SCB_PLLSTAT & 0x00FF0000 ) >> 16;
while( (MSel != PLL_M) && (NSel != PLL_N) );
/* Enable and connect */
SCB_PLLCON = 0x03;
up_scbpllfeed();
/* Check connect bit status */
while( ( SCB_PLLSTAT & ( 1 << 25 ) ) == 0 );
/* Set memory accelerater module*/
SCB_MAMCR = 0;
SCB_MAMTIM = CONFIG_MAMTIM_VALUE;
SCB_MAMCR = CONFIG_MAMCR_VALUE;
/* Enable FastIO on P0:P1 */
SCB_SCS |= 0x01;
IO_Init();
return;
}

View File

@ -0,0 +1,131 @@
/****************************************************************************************************
* arch/arm/src/lpc2378/lpc23xx_scb.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
****************************************************************************************************/
#ifndef __ARCH_ARM_SRC_LPC2378_LPC23XX_SCB_H
#define __ARCH_ARM_SRC_LPC2378_LPC23XX_SCB_H
/****************************************************************************************************
* Included Files
****************************************************************************************************/
#include <chip.h>
#include "lpc23xx_vic.h"
/****************************************************************************************************
* Definitions
****************************************************************************************************/
#define scb_getreg(o) getreg32(LPC23XX_SCB_BASE + (o))
#define scb_putreg(v,o) putreg32((v),LPC23XX_SCB_BASE + (o))
/* Memory Accelerator Mode */
#define MAMCR_OFF 0
#define MAMCR_PART 1
#define MAMCR_FULL 2
/* Memory Mapping */
#define MEMMAP2BBLK 0 /* Interrupt Vectors in Boot Block */
#define MEMMAP2FLASH 1 /* Interrupt Vectors in FLASH */
#define MEMMAP2SRAM 2 /* Interrupt Vectors in RAM */
/* Register bit settings */
/* PLL Control Register Bit Settings */
#define PLLCON_PLLE (1 << 0) /* PLL Enable */
#define PLLCON_PLLC (1 << 1) /* PLL Connect */
/* PLL Configuration Register Bit Settings */
#define PLLCFG_MSEL (0x0000FFFF << 0) /* PLL Multiplier (minus 1) */
#define PLLCFG_NSEL (0x000000FF << 16) /* PLL Divider */
/* PLL Status Register Bit Settings */
#define PLLSTAT_MSEL (0x7FFF << 0) /* PLL Multiplier Readback */
#define PLLSTAT_NSEL (0xFF << 16) /* PLL Divider Readback */
#define PLLSTAT_PLLE (1 << 24) /* PLL Enable Readback */
#define PLLSTAT_PLLC (1 << 25) /* PLL Connect Readback */
#define PLLSTAT_PLOCK (1 << 26) /* PLL Lock Status */
/* PLL Feed Register values */
#define PLLFEED1 0xaa
#define PLLFEED2 0x55
/* Peripheral Power Control (PCONP) Register 0xE01FC0C4 */
#define PCTIM0 (1 << 1) /* Timer/Counter 0 */
#define PCTIM1 (1 << 2) /* Timer/Counter 1 */
#define PCUART0 (1 << 3) /* UART0 power/clock */
#define PCUART1 (1 << 4) /* UART1 power/clock */
#define PCPWM1 (1 << 5) /* Unused, always 0 */
#define PWM1 (1 << 6) /* Pulse Width Modulation 1 */
#define PCI2C0 (1 << 7) /* I2C0 interface */
#define PCSPI (1 << 8) /* SPI */
#define PCRTC (1 << 9) /* Real Time Clock*/
#define PCSSP1 (1 << 10) /* SSP1 */
#define PCEMC (1 << 11) /* External Memory Controller */
#define PCAD (1 << 12) /* A/D converter (ADC) Note: Clear the PDN bit in the AD0CR before
clearing this bit, and set this bit before setting PDN */
#define PCAN1 (1 << 13) /* CAN Controller 1 */
#define PCAN2 (1 << 14) /* CAN Controller 2 */
#define PCI2C1 (1 << 19) /* The I2C1 interface power/clock control bit */
#define PCSSP0 (1 << 21) /* The SSP0 interface power/clock control bit */
#define PCTIM2 (1 << 22) /* Timer 2 */
#define PCTIM3 (1 << 23) /* Timer 3 */
#define PCUART2 (1 << 24) /* UART 2 */
#define PCUART3 (1 << 25) /* UART 3 */
#define PCI2C2 (1 << 26) /* I2C interface 2 */
#define PCI2S (1 << 27) /* I2S interface */
#define PCSDC (1 << 28) /* SD card interface */
#define PCGPDMA (1 << 29) /* GP DMA function */
#define PCENET (1 << 30) /* Ethernet block */
#define PCUSB (1 << 31) /* USB interface */
/****************************************************************************************************
* Inline Functions
****************************************************************************************************/
/****************************************************************************************************
* Global Function Prototypes
****************************************************************************************************/
#endif /* __ARCH_ARM_SRC_LPC2378_LPC23XX_SCB_H */

View File

@ -0,0 +1,976 @@
/****************************************************************************
* arch/arm/src/lpc2378/lpc23xx_serial.c
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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 <stdint.h>
#include <stdbool.h>
#include <unistd.h>
#include <semaphore.h>
#include <string.h>
#include <errno.h>
#include <debug.h>
#include <nuttx/irq.h>
#include <nuttx/arch.h>
#include <nuttx/serial.h>
#include <arch/serial.h>
#include "chip.h"
#include "up_arch.h"
#include "os_internal.h"
#include "internal.h"
#include "lpc23xx_scb.h"
#include "lpc23xx_pinsel.h"
#include "lpc23xx_uart.h"
#include "lpc23xx_vic.h"
#ifdef CONFIG_USE_SERIALDRIVER
/****************************************************************************
* Definitions
****************************************************************************/
/****************************************************************************
* Private Types
****************************************************************************/
struct up_dev_s
{
uint32_t uartbase; /* Base address of UART registers */
uint32_t baud; /* Configured baud */
uint8_t ier; /* Saved IER value */
uint8_t irq; /* IRQ associated with this UART */
uint8_t parity; /* 0=none, 1=odd, 2=even */
uint8_t bits; /* Number of bits (7 or 8) */
bool stopbits2; /* true: Configure with 2 stop bits instead of 1 */
};
/****************************************************************************
* Private Function Prototypes
****************************************************************************/
static int up_setup(struct uart_dev_s *dev);
static void up_shutdown(struct uart_dev_s *dev);
static int up_attach(struct uart_dev_s *dev);
static void up_detach(struct uart_dev_s *dev);
static int up_interrupt(int irq, void *context);
static int up_ioctl(struct file *filep, int cmd, unsigned long arg);
static int up_receive(struct uart_dev_s *dev, uint32_t *status);
static void up_rxint(struct uart_dev_s *dev, bool enable);
static bool up_rxavailable(struct uart_dev_s *dev);
static void up_send(struct uart_dev_s *dev, int ch);
static void up_txint(struct uart_dev_s *dev, bool enable);
static bool up_txready(struct uart_dev_s *dev);
static bool up_txempty(struct uart_dev_s *dev);
/****************************************************************************
* Private Variables
****************************************************************************/
struct uart_ops_s g_uart_ops =
{
.setup = up_setup,
.shutdown = up_shutdown,
.attach = up_attach,
.detach = up_detach,
.ioctl = up_ioctl,
.receive = up_receive,
.rxint = up_rxint,
.rxavailable = up_rxavailable,
.send = up_send,
.txint = up_txint,
.txready = up_txready,
.txempty = up_txempty,
};
/* I/O buffers */
static char g_uart0rxbuffer[CONFIG_UART0_RXBUFSIZE];
static char g_uart0txbuffer[CONFIG_UART0_TXBUFSIZE];
static char g_uart2rxbuffer[CONFIG_UART2_RXBUFSIZE];
static char g_uart2txbuffer[CONFIG_UART2_TXBUFSIZE];
/* This describes the state of the LPC214X uart0 port. */
#ifdef CONFIG_UART0
static struct up_dev_s g_uart0priv =
{
.uartbase = UART0_BASE_ADDR,
.baud = CONFIG_UART0_BAUD,
.irq = UART0_IRQ,
.parity = CONFIG_UART0_PARITY,
.bits = CONFIG_UART0_BITS,
.stopbits2 = CONFIG_UART0_2STOP,
};
static uart_dev_t g_uart0port =
{
.recv =
{
.size = CONFIG_UART0_RXBUFSIZE,
.buffer = g_uart0rxbuffer,
},
.xmit =
{
.size = CONFIG_UART0_TXBUFSIZE,
.buffer = g_uart0txbuffer,
},
.ops = &g_uart_ops,
.priv = &g_uart0priv,
};
#endif
#ifdef CONFIG_UART2
/* This describes the state of the LPC23XX uart2 port. */
static struct up_dev_s g_uart2priv =
{
.uartbase = UART2_BASE_ADDR,
.baud = CONFIG_UART2_BAUD,
.irq = UART2_IRQ,
.parity = CONFIG_UART2_PARITY,
.bits = CONFIG_UART2_BITS,
.stopbits2 = CONFIG_UART2_2STOP,
};
static uart_dev_t g_uart2port =
{
.recv =
{
.size = CONFIG_UART2_RXBUFSIZE,
.buffer = g_uart2rxbuffer,
},
.xmit =
{
.size = CONFIG_UART2_TXBUFSIZE,
.buffer = g_uart2txbuffer,
},
.ops = &g_uart_ops,
.priv = &g_uart2priv,
};
#endif
/* Now, which one with be tty0/console and which tty1? */
#if defined(CONFIG_UART0_SERIAL_CONSOLE)
# define CONSOLE_DEV g_uart0port
# define TTYS0_DEV g_uart0port
# define TTYS1_DEV g_uart2port
#elif defined(CONFIG_UART1_SERIAL_CONSOLE)
# define CONSOLE_DEV g_uart2port
# define TTYS0_DEV g_uart2port
# define TTYS1_DEV g_uart0port
#else
# error "No CONFIG_UARTn_SERIAL_CONSOLE Setting"
#endif
/****************************************************************************
* Private Functions
****************************************************************************/
/****************************************************************************
* Name: up_serialin
****************************************************************************/
static inline uint8_t up_serialin(struct up_dev_s *priv, int offset)
{
return getreg8(priv->uartbase + offset);
}
/****************************************************************************
* Name: up_serialout
****************************************************************************/
static inline void up_serialout(struct up_dev_s *priv, int offset, uint8_t value)
{
putreg8(value, priv->uartbase + offset);
}
/****************************************************************************
* Name: up_disableuartint
****************************************************************************/
static inline void up_disableuartint(struct up_dev_s *priv, uint8_t *ier)
{
if (ier)
{
*ier = priv->ier & IER_ALLIE;
}
priv->ier &= ~IER_ALLIE;
up_serialout(priv, UART_IER_OFFSET, priv->ier);
}
/****************************************************************************
* Name: up_restoreuartint
****************************************************************************/
static inline void up_restoreuartint(struct up_dev_s *priv, uint8_t ier)
{
priv->ier |= ier & IER_ALLIE;
up_serialout(priv, UART_IER_OFFSET, priv->ier);
}
/****************************************************************************
* Name: up_waittxready
****************************************************************************/
static inline void up_waittxready(struct up_dev_s *priv)
{
int tmp;
/* Limit how long we will wait for the TX available condition */
for (tmp = 1000 ; tmp > 0 ; tmp--)
{
/* Check if the tranmitter holding register (THR) is empty */
if ((up_serialin(priv, UART_LSR_OFFSET) & LSR_THRE) != 0)
{
/* The THR is empty, return */
break;
}
}
}
/****************************************************************************
* Name: up_enablebreaks
****************************************************************************/
static inline void up_enablebreaks(struct up_dev_s *priv, bool enable)
{
uint8_t lcr = up_serialin(priv, UART_LCR_OFFSET);
if (enable)
{
lcr |= LCR_BREAK_ENABLE;
}
else
{
lcr &= ~LCR_BREAK_ENABLE;
}
up_serialout(priv, UART_LCR_OFFSET, lcr);
}
/****************************************************************************
* Name: up_configbaud
****************************************************************************/
static inline void up_configbaud(struct up_dev_s *priv)
{
/* In a buckled-up, embedded system, there is no reason to constantly
* calculate the following. The calculation can be skipped if the
* MULVAL, DIVADDVAL, and DIVISOR values are provided in the configuration
* file.
*/
#ifndef CONFIG_UART_MULVAL
uint32_t qtrclk;
/* Test values calculated for every multiplier/divisor combination */
uint32_t tdiv;
uint32_t terr;
int tmulval;
int tdivaddval;
/* Optimal multiplier/divider values */
uint32_t div = 0;
uint32_t err = 100000;
int mulval = 1;
int divaddval = 0;
/* Baud is generated using FDR and DLL-DLM registers
*
* baud = clock * (mulval/(mulval+divaddval) / (16 * div)
*
* Or
*
* div = (clock/16) * (mulval/(mulval+divaddval) / baud
*
* Where mulval = Fractional divider multiplier
* divaddval = Fractional divider pre-scale div
* div = DLL-DLM divisor
*/
/* Get UART block clock divided by 16 */
qtrclk = U0_PCLK >> 4; /* TODO: Different Uart port with different clocking */
/* Try every valid multiplier, tmulval (or until a perfect
* match is found).
*/
for (tmulval = 1 ; tmulval <= 15 && err > 0; tmulval++)
{
/* Try every valid pre-scale div, tdivaddval (or until a perfect
* match is found).
*/
for (tdivaddval = 0 ; tdivaddval <= 15 && err > 0; tdivaddval++)
{
/* Calculate the divisor with these fractional divider settings */
uint32_t tmp = (tmulval * qtrclk) / ((tmulval + tdivaddval));
tdiv = (tmp + (priv->baud >>1)) / priv->baud;
/* Check if this candidate divisor is within a valid range */
if (tdiv > 2 && tdiv < 0x10000)
{
/* Calculate the actual baud and the error */
uint32_t actualbaud = tmp / tdiv;
if (actualbaud <= priv->baud)
{
terr = priv->baud - actualbaud;
}
else
{
terr = actualbaud - priv->baud;
}
/* Is this the smallest error we have encountered? */
if (terr < err)
{
/* Yes, save these settings as the new, candidate optimal settings */
mulval = tmulval ;
divaddval = tdivaddval;
div = tdiv;
err = terr;
}
}
}
}
/* Configure the MS and LS DLAB registers */
up_serialout(priv, UART_DLM_OFFSET, div >> 8);
up_serialout(priv, UART_DLL_OFFSET, div & 0xff);
/* Configure the Fractional Divider Register (FDR) */
up_serialout(priv, UART_FDR_OFFSET, ((mulval << 4) | divaddval) );
#else
/* Configure the MS and LS DLAB registers */
up_serialout(priv, UART_DLM_OFFSET, DLMVAL >> 8);
up_serialout(priv, UART_DLL_OFFSET, DLLVAL & 0xff);
/* Configure the Fractional Divider Register (FDR) */
up_serialout(priv, UART_FDR_OFFSET, ((MULVAL << 4) | DIVADDVAL) );
#endif
}
/****************************************************************************
* Name: up_setup
*
* Description:
* Configure the UART baud, bits, parity, fifos, etc. This
* method is called the first time that the serial port is
* opened.
*
****************************************************************************/
static int up_setup(struct uart_dev_s *dev)
{
#ifndef CONFIG_SUPPRESS_LPC214X_UART_CONFIG
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
uint8_t lcr;
/* Clear fifos */
up_serialout(priv, UART_FCR_OFFSET,
(FCR_RX_FIFO_RESET|FCR_TX_FIFO_RESET));
/* Set trigger */
up_serialout(priv, UART_FCR_OFFSET,
(FCR_FIFO_ENABLE|FCR_FIFO_TRIG14));
/* Set up the IER */
priv->ier = up_serialin(priv, UART_IER_OFFSET);
/* Set up the Line Control Register */
lcr = 0;
lcr |= (priv->bits == 7) ? LCR_CHAR_7 : LCR_CHAR_8;
if (priv->stopbits2)
{
lcr |= LCR_STOP_2;
}
if (priv->parity == 1)
{
lcr |= LCR_PAR_ODD;
}
else if (priv->parity == 2)
{
lcr |= LCR_PAR_EVEN;
}
/* Enable access to latch divisor DLAB=1 */
up_serialout( priv, UART_LCR_OFFSET, (lcr | LCR_DLAB_ENABLE) );
/* find values for DLL, DLM, DIVADDVAL, MULVAL */
up_configbaud(priv);
/* Disable access to latch divisor Clear DLAB */
up_serialout(priv, UART_LCR_OFFSET, lcr);
/* Configure the FIFOs */
up_serialout(priv, UART_FCR_OFFSET,
(FCR_FIFO_TRIG8 | FCR_TX_FIFO_RESET | \
FCR_RX_FIFO_RESET | FCR_FIFO_ENABLE));
/* The NuttX serial driver waits for the first THRE interrrupt before
* sending serial data... However, it appears that the LPC2378 hardware too
* does not generate that interrupt until a transition from not-empty
* to empty. So, the current kludge here is to send one NULL at
* startup to kick things off.
*/
up_serialout(priv, UART_THR_OFFSET, '\0');
#endif
return OK;
}
/****************************************************************************
* Name: up_shutdown
*
* Description:
* Disable the UART. This method is called when the serial
* port is closed
*
****************************************************************************/
static void up_shutdown(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
up_disableuartint(priv, NULL);
}
/****************************************************************************
* Name: up_attach
*
* Description:
* Configure the UART to operation in interrupt driven mode. This method is
* called when the serial port is opened. Normally, this is just after the
* the setup() method is called, however, the serial console may operate in
* a non-interrupt driven mode during the boot phase.
*
* RX and TX interrupts are not enabled when by the attach method (unless the
* hardware supports multiple levels of interrupt enabling). The RX and TX
* interrupts are not enabled until the txint() and rxint() methods are called.
*
****************************************************************************/
static int up_attach(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
int ret;
/* Attach and enable the IRQ */
ret = irq_attach(priv->irq, up_interrupt);
if (ret == OK)
{
/* Enable the interrupt (RX and TX interrupts are still disabled
* in the UART
*/
up_enable_irq(priv->irq);
/* Set the uart interrupt priority (the default value is one) */
if (priv->uartbase == UART0_BASE_ADDR)
{
up_prioritize_irq(priv->irq, PRIORITY_LOWEST);
}
else if (priv->uartbase == UART2_BASE_ADDR)
{
up_prioritize_irq(priv->irq, 10);
}
}
return ret;
}
/****************************************************************************
* Name: up_detach
*
* Description:
* Detach UART interrupts. This method is called when the serial port is
* closed normally just before the shutdown method is called. The exception is
* the serial console which is never shutdown.
*
****************************************************************************/
static void up_detach(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
up_disable_irq(priv->irq);
irq_detach(priv->irq);
}
/****************************************************************************
* Name: up_interrupt
*
* Description:
* This is the UART interrupt handler. It will be invoked
* when an interrupt received on the 'irq' It should call
* uart_transmitchars or uart_receivechar to perform the
* appropriate data transfers. The interrupt handling logic\
* must be able to map the 'irq' number into the approprite
* uart_dev_s structure in order to call these functions.
*
****************************************************************************/
static int up_interrupt(int irq, void *context)
{
struct uart_dev_s *dev = NULL;
struct up_dev_s *priv;
uint8_t status;
int passes;
if (g_uart0priv.irq == irq)
{
dev = &g_uart0port;
}
else if (g_uart2priv.irq == irq)
{
dev = &g_uart2port;
}
else
{
PANIC(OSERR_INTERNAL);
}
priv = (struct up_dev_s*)dev->priv;
/* Loop until there are no characters to be transferred or,
* until we have been looping for a long time.
*/
for (passes = 0; passes < 256; passes++)
{
/* Get the current UART status and check for loop
* termination conditions
*/
status = up_serialin(priv, UART_IIR_OFFSET);
/* The NO INTERRUPT should be zero if there are pending
* interrupts
*/
if ((status & IIR_NO_INT) != 0)
{
/* Break out of the loop when there is no longer a
* pending interrupt
*/
break;
}
/* Handle the interrupt by its interrupt ID field */
switch (status & IIR_MASK)
{
/* Handle incoming, receive bytes (with or without timeout) */
case IIR_RDA_INT:
case IIR_CTI_INT:
{
uart_recvchars(dev);
break;
}
/* Handle outgoing, transmit bytes */
case IIR_THRE_INT:
{
uart_xmitchars(dev);
break;
}
/* Just clear modem status interrupts (UART1 only) */
case IIR_MS_INT:
{
/* Read the modem status register (MSR) to clear */
status = up_serialin(priv, UART_MSR_OFFSET);
vdbg("MSR: %02x\n", status);
break;
}
/* Just clear any line status interrupts */
case IIR_RLS_INT:
{
/* Read the line status register (LSR) to clear */
status = up_serialin(priv, UART_LSR_OFFSET);
vdbg("LSR: %02x\n", status);
break;
}
/* There should be no other values */
default:
{
dbg("Unexpected IIR: %02x\n", status);
break;
}
}
}
return OK;
}
/****************************************************************************
* Name: up_ioctl
*
* Description:
* All ioctl calls will be routed through this method
*
****************************************************************************/
static int up_ioctl(struct file *filep, int cmd, unsigned long arg)
{
struct inode *inode = filep->f_inode;
struct uart_dev_s *dev = inode->i_private;
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
int ret = OK;
switch (cmd)
{
case TIOCSERGSTRUCT:
{
struct up_dev_s *user = (struct up_dev_s*)arg;
if (!user)
{
*get_errno_ptr() = EINVAL;
ret = ERROR;
}
else
{
memcpy(user, dev, sizeof(struct up_dev_s));
}
}
break;
case TIOCSBRK: /* BSD compatibility: Turn break on, unconditionally */
{
irqstate_t flags = irqsave();
up_enablebreaks(priv, true);
irqrestore(flags);
}
break;
case TIOCCBRK: /* BSD compatibility: Turn break off, unconditionally */
{
irqstate_t flags;
flags = irqsave();
up_enablebreaks(priv, false);
irqrestore(flags);
}
break;
default:
*get_errno_ptr() = ENOTTY;
ret = ERROR;
break;
}
return ret;
}
/****************************************************************************
* Name: up_receive
*
* Description:
* Called (usually) from the interrupt level to receive one
* character from the UART. Error bits associated with the
* receipt are provided in the return 'status'.
*
****************************************************************************/
static int up_receive(struct uart_dev_s *dev, uint32_t *status)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
uint8_t rbr;
*status = up_serialin(priv, UART_LSR_OFFSET);
rbr = up_serialin(priv, UART_RBR_OFFSET);
return rbr;
}
/****************************************************************************
* Name: up_rxint
*
* Description:
* Call to enable or disable RX interrupts
*
****************************************************************************/
static void up_rxint(struct uart_dev_s *dev, bool enable)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
if (enable)
{
#ifndef CONFIG_SUPPRESS_SERIAL_INTS
priv->ier |= IER_ERBFI;
#endif
}
else
{
priv->ier &= ~IER_ERBFI;
}
up_serialout(priv, UART_IER_OFFSET, priv->ier);
}
/****************************************************************************
* Name: up_rxavailable
*
* Description:
* Return true if the receive fifo is not empty
*
****************************************************************************/
static bool up_rxavailable(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
return ((up_serialin(priv, UART_LSR_OFFSET) & LSR_RDR) != 0);
}
/****************************************************************************
* Name: up_send
*
* Description:
* This method will send one byte on the UART
*
****************************************************************************/
static void up_send(struct uart_dev_s *dev, int ch)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
up_serialout(priv, UART_THR_OFFSET, (uint8_t)ch);
}
/****************************************************************************
* Name: up_txint
*
* Description:
* Call to enable or disable TX interrupts
*
****************************************************************************/
static void up_txint(struct uart_dev_s *dev, bool enable)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
if (enable)
{
#ifndef CONFIG_SUPPRESS_SERIAL_INTS
priv->ier |= IER_ETBEI;
#endif
}
else
{
priv->ier &= ~IER_ETBEI;
}
up_serialout(priv, UART_IER_OFFSET, priv->ier);
}
/****************************************************************************
* Name: up_txready
*
* Description:
* Return true if the tranmsit fifo is not full
*
****************************************************************************/
static bool up_txready(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
return ((up_serialin(priv, UART_LSR_OFFSET) & LSR_THRE) != 0);
}
/****************************************************************************
* Name: up_txempty
*
* Description:
* Return true if the transmit fifo is empty
*
****************************************************************************/
static bool up_txempty(struct uart_dev_s *dev)
{
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
return ((up_serialin(priv, UART_LSR_OFFSET) & LSR_THRE) != 0);
}
/****************************************************************************
* Public Funtions
****************************************************************************/
/****************************************************************************
* Name: up_serialinit
*
* Description:
* Performs the low level UART initialization early in
* debug so that the serial console will be available
* during bootup. This must be called before up_serialinit.
*
****************************************************************************/
void up_earlyserialinit(void)
{
/* Enable UART0 and 2 */
uint32_t pinsel = getreg32(LPC23XX_PINSEL0);
pinsel &= ~( UART0_PINMASK | UART2_PINMASK );
pinsel |= ( UART0_PINSEL | UART2_PINSEL );
putreg32(pinsel, LPC23XX_PINSEL0);
/* Set Uart PCLK divider */
SCB_PCLKSEL0 = (SCB_PCLKSEL0 & ~U0_PCLKSEL_MASK) | U0_PCLKSEL;
SCB_PCLKSEL1 = (SCB_PCLKSEL1 & ~U2_PCLKSEL_MASK) | U2_PCLKSEL;
/* Disable both UARTS */
up_disableuartint(TTYS0_DEV.priv, NULL);
up_disableuartint(TTYS1_DEV.priv, NULL);
/* Configuration whichever one is the console */
CONSOLE_DEV.isconsole = true;
up_setup(&CONSOLE_DEV);
}
/****************************************************************************
* Name: up_serialinit
*
* Description:
* Register serial console and serial ports. This assumes
* that up_earlyserialinit was called previously.
*
****************************************************************************/
void up_serialinit(void)
{
(void)uart_register("/dev/console", &CONSOLE_DEV);
(void)uart_register("/dev/ttyS0", &TTYS0_DEV);
(void)uart_register("/dev/ttyS1", &TTYS1_DEV);
}
/****************************************************************************
* Name: up_putc
*
* Description:
* Provide priority, low-level access to support OS debug writes
*
****************************************************************************/
int up_putc(int ch)
{
struct up_dev_s *priv = (struct up_dev_s*)CONSOLE_DEV.priv;
uint8_t ier;
up_disableuartint(priv, &ier);
up_waittxready(priv);
up_serialout(priv, UART_THR_OFFSET, (uint8_t)ch);
/* Check for LF */
if (ch == '\n')
{
/* Add CR */
up_waittxready(priv);
up_serialout(priv, UART_THR_OFFSET, '\r');
}
up_waittxready(priv);
up_restoreuartint(priv, ier);
return ch;
}
#else /* CONFIG_USE_SERIALDRIVER */
/****************************************************************************
* Name: up_putc
*
* Description:
* Provide priority, low-level access to support OS debug writes
*
****************************************************************************/
int up_putc(int ch)
{
/* Check for LF */
if (ch == '\n')
{
/* Add CR */
up_lowputc('\r');
}
up_lowputc(ch);
return ch;
}
#endif /* CONFIG_USE_SERIALDRIVER */

View File

@ -0,0 +1,163 @@
/************************************************************************************
* arch/arm/src/lpc2378/lpc23xx_timer.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
************************************************************************************/
#ifndef __ARCH_ARM_SRC_LPC2378_LPC23XX_TIMER_H
#define __ARCH_ARM_SRC_LPC2378_LPC23XX_TIMER_H
/************************************************************************************
* Included Files
************************************************************************************/
/************************************************************************************
* Definitions
************************************************************************************/
#define tmr_getreg8(o) getreg8(LPC23XX_TMR0_BASE+(o))
#define tmr_getreg16(o) getreg16(LPC23XX_TMR0_BASE+(o))
#define tmr_getreg32(o) getreg32(LPC23XX_TMR0_BASE+(o))
#define tmr_putreg8(v,o) putreg8((v), LPC23XX_TMR0_BASE+(o))
#define tmr_putreg16(v,o) putreg16((v), LPC23XX_TMR0_BASE+(o))
#define tmr_putreg32(v,o) putreg32((v), LPC23XX_TMR0_BASE+(o))
/* Timer registers are 8, 16-bit and 32-bits wide */
/* Timer Interrupt Register Bit Definitions (8-bit) */
#define TMR_IR_MR0I (1 << 0) /* Interrupt flag for match channel 0 */
#define TMR_IR_MR1I (1 << 1) /* Interrupt flag for match channel 1 */
#define TMR_IR_MR2I (1 << 2) /* Interrupt flag for match channel 2 */
#define TMR_IR_MR3I (1 << 3) /* Interrupt flag for match channel 3 */
#define TMR_IR_CR0I (1 << 4) /* Interrupt flag for capture channel 0 event */
#define TMR_IR_CR1I (1 << 5) /* Interrupt flag for capture channel 1 event */
#define TMR_IR_CR2I (1 << 6) /* Interrupt flag for capture channel 2 event */
#define TMR_IR_CR3I (1 << 7) /* Interrupt flag for capture channel 3 event */
#define TMR_IR_ALLI (0xff) /* All timer interrupts */
/* Timer Control Register Bit Definitions (8-bits) */
#define TMR_CR_ENABLE (1 << 0) /* Counter Enable */
#define TMR_CR_RESET (1 << 1) /* Countger Reset */
/* Timer Counter (32-bits, no bit fields) */
/* Timer Prescale Register Bit Definitions (32-bits, no bit fields) */
/* Timer Prescale Counter Register Bit Definitions */
/* Timer Match Control Register Bit Definitions (16-bit) */
#define TMR_MCR_MR0I (1 << 0) /* Enable Interrupt when MR0 matches TC */
#define TMR_MCR_MR0R (1 << 1) /* Enable Reset of TC upon MR0 match */
#define TMR_MCR_MR0S (1 << 2) /* Enable Stop of TC upon MR0 match */
#define TMR_MCR_MR1I (1 << 3) /* Enable Interrupt when MR1 matches TC */
#define TMR_MCR_MR1R (1 << 4) /* Enable Reset of TC upon MR1 match */
#define TMR_MCR_MR1S (1 << 5) /* Enable Stop of TC upon MR1 match */
#define TMR_MCR_MR2I (1 << 6) /* Enable Interrupt when MR2 matches TC */
#define TMR_MCR_MR2R (1 << 7) /* Enable Reset of TC upon MR2 match */
#define TMR_MCR_MR2S (1 << 8) /* Enable Stop of TC upon MR2 match */
#define TMR_MCR_MR3I (1 << 9) /* Enable Interrupt when MR3 matches TC */
#define TMR_MCR_MR3R (1 << 10) /* Enable Reset of TC upon MR3 match */
#define TMR_MCR_MR3S (1 << 11) /* Enable Stop of TC upon MR3 match */
/* Timer Match Register 0/1/2/3 (32-bits, no bit fields) */
/* Timer Capture Control Register Bit Definitions */
#define TMR_CCR_CAP0RE (1 << 0) /* Enable Rising edge on CAPn.0 will load TC to CR0 */
#define TMR_CCR_CAP0FE (1 << 1) /* Enable Falling edge on CAPn.0 will load TC to CR0 */
#define TMR_CCR_CAP0I (1 << 2) /* Enable Interrupt on load of CR0 */
#define TMR_CCR_CAP1RE (1 << 3) /* Enable Rising edge on CAPn.1 will load TC to CR1 */
#define TMR_CCR_CAP1FE (1 << 4) /* Enable Falling edge on CAPn.1 will load TC to CR1 */
#define TMR_CCR_CAP1I (1 << 5) /* Enable Interrupt on load of CR1 */
//~ #define TMR_CCR_CAP2RE (1 << 6) /* Enable Rising edge on CAPn.2 will load TC to CR2 */
//~ #define TMR_CCR_CAP2FE (1 << 7) /* Enable Falling edge on CAPn.2 will load TC to CR2 */
//~ #define TMR_CCR_CAP2I (1 << 8) /* Enable Interrupt on load of CR2 */
//~ #define TMR_CCR_CAP3RE (1 << 9) /* Enable Rising edge on CAPn.3 will load TC to CR3 */
//~ #define TMR_CCR_CAP3FE (1 << 10) /* Enable Falling edge on CAPn.3 will load TC to CR3 */
//~ #define TMR_CCR_CAP3I (1 << 11) /* Enable Interrupt on load of CR3 */
/* Timer Capture Register 0/1/2/3 (32-bits, no bit fields) */
/* Timer External Match Register Bit Definitions */
#define TMR_EMR_EM0 (1 << 0) /* External Match 0 */
#define TMR_EMR_EM1 (1 << 1) /* External Match 1 */
#define TMR_EMR_EM2 (1 << 2) /* External Match 2 */
#define TMR_EMR_EM3 (1 << 3) /* External Match 3 */
#define TMR_EMR_EMC0(b) ((b) << 4) /* External match control 0 (see below) */
#define TMR_EMR_EMC1(b) ((b) << 6) /* External match control 1 (see below) */
#define TMR_EMR_EMC2(b) ((b) << 8) /* External match control 2 (see below) */
#define TMR_EMR_EMC3(b) ((b) << 10) /* External match control 3 (see below) */
/* EMR External Match Control (EMCn) Field Falues */
#define TMR_EMR_MASK (3) /* Mask for all bits */
#define TMR_EMR_NOOP (0) /* Do nothing */
#define TMR_EMR_CLEAR (1) /* Clear corresponding EMn bit/output to 0 */
#define TMR_EMR_SET (2) /* Set corresponding EMn bit/output to 1 */
#define TMR_EMR_TOGGLE (3) /* Toggle corresponding EMn bit/output */
/* Timer Count Control Register Bit Definitions (8-bit) */
#define TMR_CTCR_MODE_MASK (3 << 0) /* Counter/Timer Mode */
#define TMR_CTCR_PCLK (0 << 0) /* Rising edge of PCLK */
#define TMR_CTCR_RISING (1 << 0) /* Rising edge of CAP input */
#define TMR_CTDR_FALLING (2 << 0) /* Failing edge of CAP input */
#define TMR_CTCR_BOTH (3 << 0) /* Both edges of CAP input */
#define TMR_CTCR_INPUT_MASK (3 << 2) /* Counter Input Select */
#define TMR_CTCR_CR0 (0 << 2) /* CAPn.0 */
#define TMR_CTCR_CR1 (1 << 2) /* CAPn.1 */
#define TMR_CTCR_CR2 (2 << 2) /* CAPn.2 */
#define TMR_CTCR_CR3 (3 << 2) /* CAPn.3 */
/************************************************************************************
* Public Types
************************************************************************************/
/************************************************************************************
* Inline Functions
************************************************************************************/
/************************************************************************************
* Public Function Prototypes
************************************************************************************/
#endif /* __ARCH_ARM_SRC_LPC2378_LPC23XX_TIMER_H */

View File

@ -0,0 +1,193 @@
/****************************************************************************
* arch/arm/src/lpc2378/lpc23xx_timerisr.c
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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 <debug.h>
#include <nuttx/arch.h>
#include <arch/board/board.h>
#include "clock_internal.h"
#include "internal.h"
#include "up_arch.h"
#include "lpc23xx_scb.h"
#include "lpc23xx_vic.h"
#include "lpc23xx_timer.h"
/****************************************************************************
* Definitions
****************************************************************************/
/* T0_PCLKDIV valid values are 1,2,4 */
#define T0_PCLK_DIV 1
/* PCKLSEL0 bits 3:2, 00=CCLK/4, 01=CCLK/1 , 10=CCLK/2 */
#ifdef T0_PCLK_DIV
# if T0_PCLK_DIV == 1
# define TIMER0_PCLKSEL (0x00000004)
# elif T0_PCLK_DIV == 2
# define TIMER0_PCLKSEL (0x00000008)
# elif T0_PCLK_DIV == 4
# define TIMER0_PCLKSEL (0x00000000)
# endif
#endif
#define T0_PCLKSEL_MASK (0x0000000C)
#define T0_TICKS_COUNT ( (CCLK / T0_PCLK_DIV ) / TICK_PER_SEC )
/****************************************************************************
* Private Types
****************************************************************************/
/****************************************************************************
* Private Function Prototypes
****************************************************************************/
/****************************************************************************
* Global Functions
****************************************************************************/
/****************************************************************************
* Function: up_timerisr
*
* Description:
* The timer ISR will perform a variety of services for
* various portions of the systems.
*
****************************************************************************/
#ifdef CONFIG_VECTORED_INTERRUPTS
int up_timerisr(uint32_t *regs)
#else
int up_timerisr(int irq, uint32_t *regs)
#endif
{
static uint32_t tick;
/* Process timer interrupt */
sched_process_timer();
/* Clear the MR0 match interrupt */
tmr_putreg8(TMR_IR_MR0I, TMR_IR_OFFSET);
/* Reset the VIC as well */
#ifdef CONFIG_VECTORED_INTERRUPTS
/* write any value to VICAddress to acknowledge the interrupt */
vic_putreg(0, VIC_ADDRESS_OFFSET);
#endif
if(tick++ > 100){
tick =0;
up_statledoff();
}else up_statledon();
return 0;
}
/****************************************************************************
* Function: up_timerinit
*
* Description:
* This function is called during start-up to initialize
* the system timer interrupt.
*
****************************************************************************/
void up_timerinit(void)
{
uint16_t mcr;
/* Power up Timer0 */
SCB_PCONP |= PCTIM0;
/* Timer0 clock input frequency = CCLK / TO_PCLKDIV */
SCB_PCLKSEL0 = (SCB_PCLKSEL0 & ~T0_PCLKSEL_MASK) | TIMER0_PCLKSEL;
/* Clear all match and capture event interrupts */
tmr_putreg8(TMR_IR_ALLI, TMR_IR_OFFSET);
/* Clear the timer counter */
tmr_putreg32(0, TMR_TC_OFFSET);
/* No pre-scaler */
tmr_putreg32(0, TMR_PR_OFFSET);
tmr_putreg32(0, TMR_PC_OFFSET);
/* Set timer match registger to get a TICK_PER_SEC rate
* See arch/board.h and sched/os_internal.h
*/
tmr_putreg32( T0_TICKS_COUNT, TMR_MR0_OFFSET ); /* 10ms Intterrupt */
/* Reset timer counter register and interrupt on match */
mcr = tmr_getreg16(TMR_MCR_OFFSET);
mcr &= ~TMR_MCR_MR1I;
mcr |= (TMR_MCR_MR0I | TMR_MCR_MR0R);
tmr_putreg16(mcr, TMR_MCR_OFFSET);//-- bit 0=1 -int on MR0, bit 1=1 - Reset on MR0
/* Enable counting */
//~ tmr_putreg32(1, TMR_TCR_OFFSET);
tmr_putreg8(TMR_CR_ENABLE, TMR_TCR_OFFSET);
/* Attach the timer interrupt vector */
#ifdef CONFIG_VECTORED_INTERRUPTS
up_attach_vector(IRQ_SYSTIMER, PRIORITY_HIGHEST, (vic_vector_t)up_timerisr);
#else
(void)irq_attach(IRQ_SYSTIMER, (xcpt_t)up_timerisr);
up_prioritize_irq(IRQ_SYSTIMER, PRIORITY_HIGHEST);
#endif
/* And enable the system timer interrupt */
up_enable_irq(IRQ_SYSTIMER);
}

View File

@ -0,0 +1,231 @@
/************************************************************************************
* arch/arm/src/lpc2378/lpc2378/uart.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
************************************************************************************/
#ifndef __ARCH_ARM_SRC_LPC2378_LPC23XX_UART_H
#define __ARCH_ARM_SRC_LPC2378_LPC23XX_UART_H
/************************************************************************************
* Included Files
************************************************************************************/
#include <arch/board/board.h> /* For clock settings */
/************************************************************************************
* Definitions
************************************************************************************/
/* Derive baud divisor setting from clock settings (see board.h) */
//--F_in = 57 600 000 Hz U0DLM=0, U0DLL=25, DIVADDVAL=3, MULVAL=12, baudrate=115200, err = 0.000000 %
//--F_in = 57 600 000 Hz U0DLM=1, U0DLL=119, DIVADDVAL=0, MULVAL=1, baudrate=9600, err = 0.000000 %
/* Used only if CONFIG_UART_MULVAL is not defined */
#define DIVADDVAL 0
#define MULVAL 1
#define DLMVAL 1
#define DLLVAL 119
/* UARTx PCLK divider valid values are 1,2,4 */
#define U0_PCLKDIV 1
//~ #define U1_PCLKDIV 1
#define U2_PCLKDIV 1
//~ #define U3_PCLKDIV 1
#define U0_PCLK (CCLK / U0_PCLKDIV)
//~ #define U1_PCLK (CCLK / U1_PCLKDIV)
#define U2_PCLK (CCLK / U2_PCLKDIV)
//~ #define U3_PCLK (CCLK / U3_PCLKDIV)
#define U0_PCLKSEL_MASK (0x000000C0)
#define U2_PCLKSEL_MASK (0x00030000)
/* PCKLSEL0 bits 7:6, 00=CCLK/4, 01=CCLK/1 , 10=CCLK/2 */
#ifdef U0_PCLKDIV
# if U0_PCLKDIV == 1
# define U0_PCLKSEL (0x00000040)
# elif U0_PCLKDIV == 2
# define U0_PCLKSEL (0x00000080)
# elif U0_PCLKDIV == 4
# define U0_PCLKSEL (0x00000000)
# endif
#else
# error "UART0 PCLK divider not set"
#endif
/* PCKLSEL1 bits 17:16, 00=CCLK/4, 01=CCLK/1 , 10=CCLK/2 */
#ifdef U2_PCLKDIV
# if U2_PCLKDIV == 1
# define U2_PCLKSEL (0x00010000)
# elif U2_PCLKDIV == 2
# define U2_PCLKSEL (0x00020000)
# elif U2_PCLKDIV == 4
# define U2_PCLKSEL (0x00000000)
# endif
#else
# error "UART2 PCLK divider not set"
#endif
/* Universal Asynchronous Receiver Transmitter Base Addresses */
#define UART0_BASE_ADDR 0xE000C000
#define UART1_BASE_ADDR 0xE0010000
#define UART2_BASE_ADDR 0xE0078000
#define UART3_BASE_ADDR 0xE007C000
/* UART 0/1/2/3 Register Offsets */
#define UART_RBR_OFFSET 0x00 /* R: Receive Buffer Register (DLAB=0) */
#define UART_THR_OFFSET 0x00 /* W: Transmit Holding Register (DLAB=0) */
#define UART_DLL_OFFSET 0x00 /* W: Divisor Latch Register (LSB, DLAB=1) */
#define UART_IER_OFFSET 0x04 /* W: Interrupt Enable Register (DLAB=0) */
#define UART_DLM_OFFSET 0x04 /* RW: Divisor Latch Register (MSB, DLAB=1) */
#define UART_IIR_OFFSET 0x08 /* R: Interrupt ID Register */
#define UART_FCR_OFFSET 0x08 /* W: FIFO Control Register */
#define UART_LCR_OFFSET 0x0c /* RW: Line Control Register */
#define UART_MCR_OFFSET 0x10 /* RW: Modem Control REgister (2146/6/8 UART1 Only) */
#define UART_LSR_OFFSET 0x14 /* R: Scratch Pad Register */
#define UART_MSR_OFFSET 0x18 /* RW: MODEM Status Register (2146/6/8 UART1 Only) */
#define UART_SCR_OFFSET 0x1c /* RW: Line Status Register */
#define UART_ACR_OFFSET 0x20 /* RW: Autobaud Control Register */
#define UART_FDR_OFFSET 0x28 /* RW: Fractional Divider Register */
#define UART_TER_OFFSET 0x30 /* RW: Transmit Enable Register */
/* PINSEL0 bit definitions for UART0/2 */
#define UART0_PINSEL 0x00000050 /* PINSEL0 value for UART0 */
#define UART0_PINMASK 0x000000F0 /* PINSEL0 mask for UART0 */
#define UART1_TX_PINSEL 0x40000000 /* PINSEL0 value for UART1 Tx */
#define UART1_TXPINMASK 0xC0000000 /* PINSEL0 mask for UART1 Tx */
#define UART1_RX_PINSEL 0x00000001 /* PINSEL1 value for UART1 Rx */
#define UART1_RX_PINMASK 0x00000003 /* PINSEL1 mask for UART1 Rx */
#define UART1_MODEM_PINSEL 0x00001555 /* PINSEL1 mask for UART1 Modem Interface */
#define UART1_CTS_PINMASK 0x00003FFF /* PINSEL1 mask for UART1 Modem Interface */
//~ #define UART1_CTS_PINSEL 0x00000004 /* PINSEL1 mask for UART1 CTS */
//~ #define UART1_CTS_PINMASK 0x0000000C /* PINSEL1 mask for UART1 CTS */
//~ #define UART1_CTS_PINSEL 0x00000010 /* PINSEL1 mask for UART1 Rx */
//~ #define UART1_CTS_PINMASK 0x00000030 /* PINSEL1 mask for UART1 Rx */
#define UART2_PINSEL 0x00500000 /* PINSEL0 value for UART2 */
#define UART2_PINMASK 0x00F00000 /* PINSEL0 mask for UART2 */
#define UART3_PINSEL 0x0F000000 /* PINSEL9 value for UART3 */
#define UART3_PINMASK 0x0F000000 /* PINSEL9 mask for UART3 */
/* Interrupt Enable Register (IER) bit definitions */
#define IER_ERBFI (1 << 0) /* Enable receive data available int */
#define IER_ETBEI (1 << 1) /* Enable THR empty Interrupt */
#define IER_ELSI (1 << 2) /* Enable receive line status int */
#define IER_EDSSI (1 << 3) /* Enable MODEM atatus interrupt (2146/6/8 UART1 Only) */
#define IER_ALLIE 0x0f /* All interrupts */
/* Interrupt ID Register(IIR) bit definitions */
#define IIR_NO_INT (1 << 0) /* No interrupts pending */
#define IIR_MS_INT (0 << 1) /* MODEM Status (UART1 only) */
#define IIR_THRE_INT (1 << 1) /* Transmit Holding Register Empty */
#define IIR_RDA_INT (2 << 1) /* Receive Data Available */
#define IIR_RLS_INT (3 << 1) /* Receive Line Status */
#define IIR_CTI_INT (6 << 1) /* Character Timeout Indicator */
#define IIR_MASK 0x0e
/* FIFO Control Register (FCR) bit definitions */
#define FCR_FIFO_ENABLE (1 << 0) /* FIFO enable */
#define FCR_RX_FIFO_RESET (1 << 1) /* Reset receive FIFO */
#define FCR_TX_FIFO_RESET (1 << 2) /* Reset transmit FIFO */
#define FCR_FIFO_TRIG1 (0 << 6) /* Trigger @1 character in FIFO */
#define FCR_FIFO_TRIG4 (1 << 6) /* Trigger @4 characters in FIFO */
#define FCR_FIFO_TRIG8 (2 << 6) /* Trigger @8 characters in FIFO */
#define FCR_FIFO_TRIG14 (3 << 6) /* Trigger @14 characters in FIFO */
/* Line Control Register (LCR) bit definitions */
#define LCR_CHAR_5 (0 << 0) /* 5-bit character length */
#define LCR_CHAR_6 (1 << 0) /* 6-bit character length */
#define LCR_CHAR_7 (2 << 0) /* 7-bit character length */
#define LCR_CHAR_8 (3 << 0) /* 8-bit character length */
#define LCR_STOP_1 (0 << 2) /* 1 stop bit */
#define LCR_STOP_2 (1 << 2) /* 2 stop bits */
#define LCR_PAR_NONE (0 << 3) /* No parity */
#define LCR_PAR_ODD (1 << 3) /* Odd parity */
#define LCR_PAR_EVEN (3 << 3) /* Even parity */
#define LCR_PAR_MARK (5 << 3) /* Mark "1" parity */
#define LCR_PAR_SPACE (7 << 3) /* Space "0" parity */
#define LCR_BREAK_ENABLE (1 << 6) /* Output BREAK */
#define LCR_DLAB_ENABLE (1 << 7) /* Enable divisor latch access */
/* Modem Control Register (MCR) bit definitions */
#define MCR_DTR (1 << 0) /* Data terminal ready */
#define MCR_RTS (1 << 1) /* Request to send */
#define MCR_LB (1 << 4) /* Loopback */
/* Line Status Register (LSR) bit definitions */
#define LSR_RDR (1 << 0) /* Receive data ready */
#define LSR_OE (1 << 1) /* Overrun error */
#define LSR_PE (1 << 2) /* Parity error */
#define LSR_FE (1 << 3) /* Framing error */
#define LSR_BI (1 << 4) /* Break interrupt */
#define LSR_THRE (1 << 5) /* THR empty */
#define LSR_TEMT (1 << 6) /* Transmitter empty */
#define LSR_RXFE (1 << 7) /* Error in receive FIFO */
#define LSR_ERR_MASK 0x1e
/* Modem Status Register (MSR) bit definitions */
#define MSR_DCTS (1 << 0) /* Delta clear to send */
#define MSR_DDSR (1 << 1) /* Delta data set ready */
#define MSR_TERI (1 << 2) /* Trailing edge ring indicator */
#define MSR_DDCD (1 << 3) /* Delta data carrier detect */
#define MSR_CTS (1 << 4) /* Clear to send */
#define MSR_DSR (1 << 5) /* Data set ready */
#define MSR_RI (1 << 6) /* Ring indicator */
#define MSR_DCD (1 << 7) /* Data carrier detect */
/************************************************************************************
* Inline Functions
************************************************************************************/
/************************************************************************************
* Global Function Prototypes
************************************************************************************/
#endif /* __ARCH_ARM_SRC_LPC2378_LPC23XX_UART_H */

View File

@ -0,0 +1,76 @@
/************************************************************************************
* arch/arm/src/lpc2378/lpc23xx_vic.h
*
* Copyright (C) 2010 Rommel Marcelo. All rights reserved.
* Author: Rommel Marcelo
*
* This file is part of the NuttX RTOS and based on the lpc2148 port:
*
* Copyright (C) 2010 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.
*
************************************************************************************/
#ifndef __ARCH_ARM_SRC_LPC2378_LPC23XX_VIC_H
#define __ARCH_ARM_SRC_LPC2378_LPC23XX_VIC_H
/************************************************************************************
* Included Files
************************************************************************************/
/************************************************************************************
* Definitions
************************************************************************************/
/* All VIC registers are 32-bits wide */
#define vic_getreg(o) getreg32(LPC23XX_VIC_BASE + (o))
#define vic_putreg(v,o) putreg32((v),LPC23XX_VIC_BASE + (o))
/* Vector Control Register bit definitions */
//~ #define LPC23XX_VECTPRIORITY_IRQMASK (0x0000001f)
//~ #define VECTPRIORITY_IRQMASK (0x0000FFFF)
//~ #define LPC23XX_VECTPRIORITY_IRQSHIFT (0)
//~ #define LPC23XX_VECTPRIORITY_ENABLE (1 << 5)
/************************************************************************************
* Public Types
************************************************************************************/
/************************************************************************************
* Inline Functions
************************************************************************************/
/************************************************************************************
* Public Function Prototypes
************************************************************************************/
#endif /* __ARCH_ARM_SRC_LPC2378_LPC23XX_VIC_H */