Add z16f system exception handling logic.
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@564 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
30984a7eed
commit
fb4253bfb2
@ -49,42 +49,40 @@
|
|||||||
* Definitions
|
* Definitions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* Interrupt Vectors */
|
/* Interrupt Vectors (excluding reset and sysexec which are handled differently) */
|
||||||
|
|
||||||
#define Z16F_IRQ_SYSEXC ( 0) /* Vector: 0x08 System Exceptions */
|
#define Z16F_IRQ_IRQ0 ( 0) /* First of 8 IRQs controlled by IRQ0 registers */
|
||||||
|
#define Z16F_IRQ_ADC ( 0) /* Vector: 0x2C IRQ0.0 ADC */
|
||||||
|
#define Z16F_IRQ_SPI ( 1) /* Vector: 0x28 IRQ0.1 SPI */
|
||||||
|
#define Z16F_IRQ_I2C ( 2) /* Vector: 0x24 IRQ0.2 I2C */
|
||||||
|
#define Z16F_IRQ_UART0TX ( 3) /* Vector: 0x20 IRQ0.3 UART0 TX */
|
||||||
|
#define Z16F_IRQ_UART0RX ( 4) /* Vector: 0x1C IRQ0.4 UART0 RX */
|
||||||
|
#define Z16F_IRQ_TIMER0 ( 5) /* Vector: 0x18 IRQ0.5 Timer 0 */
|
||||||
|
#define Z16F_IRQ_TIMER1 ( 6) /* Vector: 0x14 IRQ0.6 Timer 1 */
|
||||||
|
#define Z16F_IRQ_TIMER2 ( 7) /* Vector: 0x10 IRQ0.7 Timer 2 */
|
||||||
|
|
||||||
#define Z16F_IRQ_IRQ0 ( 1) /* First of 8 IRQs controlled by IRQ0 registers */
|
#define Z16F_IRQ_IRQ1 ( 8) /* First of 8 IRQs controlled by IRQ1 registers */
|
||||||
#define Z16F_IRQ_ADC ( 1) /* Vector: 0x2C IRQ0.0 ADC */
|
#define Z16F_IRQ_P0AD ( 8) /* Vector: 0x4C IRQ1.0 Port A/D0, rising/falling edge */
|
||||||
#define Z16F_IRQ_SPI ( 2) /* Vector: 0x28 IRQ0.1 SPI */
|
#define Z16F_IRQ_P1AD ( 9) /* Vector: 0x48 IRQ1.1 Port A/D1, rising/falling edge */
|
||||||
#define Z16F_IRQ_I2C ( 3) /* Vector: 0x24 IRQ0.2 I2C */
|
#define Z16F_IRQ_P2AD (10) /* Vector: 0x44 IRQ1.2 Port A/D2, rising/falling edge */
|
||||||
#define Z16F_IRQ_UART0TX ( 4) /* Vector: 0x20 IRQ0.3 UART0 TX */
|
#define Z16F_IRQ_P3AD (11) /* Vector: 0x40 IRQ1.3 Port A/D3, rising/falling edge */
|
||||||
#define Z16F_IRQ_UART0RX ( 5) /* Vector: 0x1C IRQ0.4 UART0 RX */
|
#define Z16F_IRQ_P4AD (12) /* Vector: 0x3C IRQ1.4 Port A/D4, rising/falling edge */
|
||||||
#define Z16F_IRQ_TIMER0 ( 6) /* Vector: 0x18 IRQ0.5 Timer 0 */
|
#define Z16F_IRQ_P5AD (13) /* Vector: 0x38 IRQ1.5 Port A/D5, rising/falling edge */
|
||||||
#define Z16F_IRQ_TIMER1 ( 7) /* Vector: 0x14 IRQ0.6 Timer 1 */
|
#define Z16F_IRQ_P6AD (14) /* Vector: 0x34 IRQ1.6 Port A/D6, rising/falling edge */
|
||||||
#define Z16F_IRQ_TIMER2 ( 8) /* Vector: 0x10 IRQ0.7 Timer 2 */
|
#define Z16F_IRQ_P7AD (15) /* Vector: 0x30 IRQ1.7 Port A/D7, rising/falling edge */
|
||||||
|
|
||||||
#define Z16F_IRQ_IRQ1 ( 9) /* First of 8 IRQs controlled by IRQ1 registers */
|
#define Z16F_IRQ_IRQ2 (16) /* First of 8 IRQs controlled by IRQ2 registers */
|
||||||
#define Z16F_IRQ_P0AD ( 9) /* Vector: 0x4C IRQ1.0 Port A/D0, rising/falling edge */
|
#define Z16F_IRQ_C0 (16) /* Vector: IRQ2.0 0x6C Port C0, both edges DMA0 */
|
||||||
#define Z16F_IRQ_P1AD (10) /* Vector: 0x48 IRQ1.1 Port A/D1, rising/falling edge */
|
#define Z16F_IRQ_C1 (17) /* Vector: IRQ2.1 0x68 Port C1, both edges DMA1 */
|
||||||
#define Z16F_IRQ_P2AD (11) /* Vector: 0x44 IRQ1.2 Port A/D2, rising/falling edge */
|
#define Z16F_IRQ_C2 (18) /* Vector: IRQ2.2 0x64 Port C2, both edges DMA2 */
|
||||||
#define Z16F_IRQ_P3AD (12) /* Vector: 0x40 IRQ1.3 Port A/D3, rising/falling edge */
|
#define Z16F_IRQ_C3 (19) /* Vector: IRQ2.3 0x60 Port C3, both edges DMA3 */
|
||||||
#define Z16F_IRQ_P4AD (13) /* Vector: 0x3C IRQ1.4 Port A/D4, rising/falling edge */
|
#define Z16F_IRQ_PWMFAULT (20) /* Vector: IRQ2.4 0x5C PWM Fault */
|
||||||
#define Z16F_IRQ_P5AD (14) /* Vector: 0x38 IRQ1.5 Port A/D5, rising/falling edge */
|
#define Z16F_IRQ_UART1TX (21) /* Vector: IRQ2.5 0x58 UART1 TX */
|
||||||
#define Z16F_IRQ_P6AD (15) /* Vector: 0x34 IRQ1.6 Port A/D6, rising/falling edge */
|
#define Z16F_IRQ_UART1RX (22) /* Vector: IRQ2.6 0x54 UART1 RX */
|
||||||
#define Z16F_IRQ_P7AD (16) /* Vector: 0x30 IRQ1.7 Port A/D7, rising/falling edge */
|
#define Z16F_IRQ_PWMTIMER (23) /* Vector: IRQ2.7 0x50 PWM Timer */
|
||||||
|
|
||||||
#define Z16F_IRQ_IRQ2 (17) /* First of 8 IRQs controlled by IRQ2 registers */
|
|
||||||
#define Z16F_IRQ_C0 (17) /* Vector: IRQ2.0 0x6C Port C0, both edges DMA0 */
|
|
||||||
#define Z16F_IRQ_C1 (18) /* Vector: IRQ2.1 0x68 Port C1, both edges DMA1 */
|
|
||||||
#define Z16F_IRQ_C2 (19) /* Vector: IRQ2.2 0x64 Port C2, both edges DMA2 */
|
|
||||||
#define Z16F_IRQ_C3 (20) /* Vector: IRQ2.3 0x60 Port C3, both edges DMA3 */
|
|
||||||
#define Z16F_IRQ_PWMFAULT (21) /* Vector: IRQ2.4 0x5C PWM Fault */
|
|
||||||
#define Z16F_IRQ_UART1TX (22) /* Vector: IRQ2.5 0x58 UART1 TX */
|
|
||||||
#define Z16F_IRQ_UART1RX (23) /* Vector: IRQ2.6 0x54 UART1 RX */
|
|
||||||
#define Z16F_IRQ_PWMTIMER (24) /* Vector: IRQ2.7 0x50 PWM Timer */
|
|
||||||
|
|
||||||
#define Z16F_IRQ_SYSTIMER Z16F_IRQ_TIMER0
|
#define Z16F_IRQ_SYSTIMER Z16F_IRQ_TIMER0
|
||||||
#define NR_IRQS (25)
|
#define NR_IRQS (24)
|
||||||
|
|
||||||
/* These macros will map an IRQ to a register bit position */
|
/* These macros will map an IRQ to a register bit position */
|
||||||
|
|
||||||
|
@ -43,6 +43,7 @@
|
|||||||
#include <debug.h>
|
#include <debug.h>
|
||||||
#include <nuttx/arch.h>
|
#include <nuttx/arch.h>
|
||||||
#include <nuttx/mm.h>
|
#include <nuttx/mm.h>
|
||||||
|
#include <arch/board/board.h>
|
||||||
|
|
||||||
#include "chip/chip.h"
|
#include "chip/chip.h"
|
||||||
#include "up_internal.h"
|
#include "up_internal.h"
|
||||||
|
@ -46,6 +46,7 @@
|
|||||||
|
|
||||||
#include <nuttx/irq.h>
|
#include <nuttx/irq.h>
|
||||||
#include <nuttx/arch.h>
|
#include <nuttx/arch.h>
|
||||||
|
#include <arch/board/board.h>
|
||||||
|
|
||||||
#include "chip/chip.h"
|
#include "chip/chip.h"
|
||||||
#include "os_internal.h"
|
#include "os_internal.h"
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
|
|
||||||
#include <nuttx/kmalloc.h>
|
#include <nuttx/kmalloc.h>
|
||||||
#include <nuttx/arch.h>
|
#include <nuttx/arch.h>
|
||||||
|
#include <arch/board/board.h>
|
||||||
|
|
||||||
#include "chip/chip.h"
|
#include "chip/chip.h"
|
||||||
#include "up_internal.h"
|
#include "up_internal.h"
|
||||||
|
@ -40,9 +40,11 @@
|
|||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
#include <nuttx/irq.h>
|
#include <nuttx/irq.h>
|
||||||
#include <nuttx/arch.h>
|
#include <nuttx/arch.h>
|
||||||
#include <assert.h>
|
#include <arch/board/board.h>
|
||||||
|
|
||||||
#include "chip/chip.h"
|
#include "chip/chip.h"
|
||||||
#include "os_internal.h"
|
#include "os_internal.h"
|
||||||
@ -79,7 +81,7 @@
|
|||||||
|
|
||||||
FAR chipreg_t *up_doirq(int irq, FAR chipreg_t *regs)
|
FAR chipreg_t *up_doirq(int irq, FAR chipreg_t *regs)
|
||||||
{
|
{
|
||||||
chipreg_t *ret = regs;
|
FAR chipreg_t *ret = regs;
|
||||||
|
|
||||||
up_ledon(LED_INIRQ);
|
up_ledon(LED_INIRQ);
|
||||||
#ifdef CONFIG_SUPPRESS_INTERRUPTS
|
#ifdef CONFIG_SUPPRESS_INTERRUPTS
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
|
|
||||||
#include <nuttx/irq.h>
|
#include <nuttx/irq.h>
|
||||||
#include <nuttx/arch.h>
|
#include <nuttx/arch.h>
|
||||||
|
#include <arch/board/board.h>
|
||||||
|
|
||||||
#include "os_internal.h"
|
#include "os_internal.h"
|
||||||
#include "up_internal.h"
|
#include "up_internal.h"
|
||||||
|
@ -44,5 +44,5 @@ CMN_CSRCS = up_allocateheap.c up_initialize.c up_schedulesigaction.c \
|
|||||||
up_exit.c up_releasestack.c up_idle.c up_reprioritizertr.c
|
up_exit.c up_releasestack.c up_idle.c up_reprioritizertr.c
|
||||||
|
|
||||||
CHIP_SSRCS = z16f_lowuart.S z16f_saveusercontext.S z16f_restoreusercontext.S
|
CHIP_SSRCS = z16f_lowuart.S z16f_saveusercontext.S z16f_restoreusercontext.S
|
||||||
CHIP_CSRCS = z16f_clkinit.c z16f_irq.c z16f_timerisr.c z16f_serial.c
|
CHIP_CSRCS = z16f_clkinit.c z16f_sysexec.c z16f_irq.c z16f_timerisr.c z16f_serial.c
|
||||||
|
|
||||||
|
@ -42,6 +42,7 @@
|
|||||||
************************************************************************************/
|
************************************************************************************/
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
#include <arch/irq.h>
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* Definitions
|
* Definitions
|
||||||
@ -199,6 +200,28 @@
|
|||||||
#define Z16F_IRQ2_ENH _HX32(ffffe03a) /* 8-bit: IRQ2 Enable High Bit */
|
#define Z16F_IRQ2_ENH _HX32(ffffe03a) /* 8-bit: IRQ2 Enable High Bit */
|
||||||
#define Z16F_IRQ2_ENL _HX32(ffffe03c) /* 8-bit: IRQ2 Enable Low Bit */
|
#define Z16F_IRQ2_ENL _HX32(ffffe03c) /* 8-bit: IRQ2 Enable Low Bit */
|
||||||
|
|
||||||
|
/* System exception status register bit definitions *********************************/
|
||||||
|
|
||||||
|
#define Z16F_SYSEXCPH_SPOVF _HX8(80) /* Bit 7: Stack pointer overflow */
|
||||||
|
#define Z16F_SYSEXCPH_PCOVF _HX8(40) /* Bit 6: Program counter overflow */
|
||||||
|
#define Z16F_SYSEXCPH_DIV0 _HX8(20) /* Bit 5: Divide by zero */
|
||||||
|
#define Z16F_SYSEXCPH_DIVOVF _HX8(10) /* Bit 4: Divide overflow */
|
||||||
|
#define Z16F_SYSEXCPH_ILL _HX8(08) /* Bit 3: Illegal instruction */
|
||||||
|
/* Bits 0-2: Reserved */
|
||||||
|
/* Bits 3-7: Reserved */
|
||||||
|
#define Z16F_SYSEXCPL_WDTOSC _HX8(04) /* Bit 2: WDT oscillator failure */
|
||||||
|
#define Z16F_SYSEXCPL_PRIOSC _HX8(02) /* Bit 1: Primary oscillator failure */
|
||||||
|
#define Z16F_SYSEXCPL_WDT _HX8(01) /* Bit 0: Watchdog timer interrupt */
|
||||||
|
|
||||||
|
#define Z16F_SYSEXCP_SPOVF (Z16F_SYSEXCPH_SPOVF << 8)
|
||||||
|
#define Z16F_SYSEXCP_PCOVF (Z16F_SYSEXCPH_PCOVF << 8)
|
||||||
|
#define Z16F_SYSEXCP_DIV0 (Z16F_SYSEXCPH_DIV0 << 8)
|
||||||
|
#define Z16F_SYSEXCP_DIVOVF (Z16F_SYSEXCPH_DIVOVF << 8)
|
||||||
|
#define Z16F_SYSEXCP_ILL (Z16F_SYSEXCPH_ILL << 8)
|
||||||
|
#define Z16F_SYSEXCP_WDTOSC Z16F_SYSEXCPL_WDTOSC
|
||||||
|
#define Z16F_SYSEXCP_PRIOSC Z16F_SYSEXCPL_PRIOSC
|
||||||
|
#define Z16F_SYSEXCP_WDT Z16F_SYSEXCPL_WDT
|
||||||
|
|
||||||
/* Oscillator control registers *****************************************************/
|
/* Oscillator control registers *****************************************************/
|
||||||
|
|
||||||
#define Z16F_OSC_CTL _HX32(ffffe0A0) /* 8-bit: Oscillator Control */
|
#define Z16F_OSC_CTL _HX32(ffffe0A0) /* 8-bit: Oscillator Control */
|
||||||
@ -519,11 +542,19 @@ extern "C" {
|
|||||||
* debugging support for up_lowputc (or getc) is enabled.
|
* debugging support for up_lowputc (or getc) is enabled.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
extern void z16f_lowinit(void);
|
EXTERN void z16f_lowinit(void);
|
||||||
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
||||||
extern void z16f_lowuartinit(void);
|
EXTERN void z16f_lowuartinit(void);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* This function handles Z16F system execeptions */
|
||||||
|
|
||||||
|
EXTERN void z16f_sysexec(FAR chipreg_t *regs);
|
||||||
|
|
||||||
|
/* Entry point to reset the processor */
|
||||||
|
|
||||||
|
EXTERN void z16f_reset(void);
|
||||||
|
|
||||||
#undef EXTERN
|
#undef EXTERN
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
@ -1,441 +1,454 @@
|
|||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
* arch/z16/src/z16f/z16f_head.S
|
* arch/z16/src/z16f/z16f_head.S
|
||||||
* Z16F Reset Entry Point
|
* Z16F Reset Entry Point
|
||||||
*
|
*
|
||||||
* Copyright (C) 2008 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2008 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
* are met:
|
* are met:
|
||||||
*
|
*
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
* notice, this list of conditions and the following disclaimer.
|
* notice, this list of conditions and the following disclaimer.
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
* notice, this list of conditions and the following disclaimer in
|
* notice, this list of conditions and the following disclaimer in
|
||||||
* the documentation and/or other materials provided with the
|
* the documentation and/or other materials provided with the
|
||||||
* distribution.
|
* distribution.
|
||||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
* used to endorse or promote products derived from this software
|
* used to endorse or promote products derived from this software
|
||||||
* without specific prior written permission.
|
* without specific prior written permission.
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
* Included Files
|
* Included Files
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
#include <arch/irq.h>
|
#include <arch/irq.h>
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
* External References / External Definitions
|
* External References / External Definitions
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
|
||||||
xref _z16f_lowinit:EROM
|
xref _z16f_lowinit:EROM
|
||||||
#ifdef CONFIG_ARCH_LEDS
|
#ifdef CONFIG_ARCH_LEDS
|
||||||
xref _up_ledinit:EROM
|
xref _up_ledinit:EROM
|
||||||
#endif
|
#endif
|
||||||
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
||||||
xref _z16f_lowuartinit:EROM
|
xref _z16f_lowuartinit:EROM
|
||||||
#endif
|
#endif
|
||||||
xref _os_start:EROM
|
xref _os_start:EROM
|
||||||
xref _up_doirq:EROM
|
xref _up_doirq:EROM
|
||||||
xdef _reset
|
xref _z16f_sysexec:EROM
|
||||||
xdef _sysexc_isr
|
xdef _z16f_reset
|
||||||
xdef _timer2_isr
|
|
||||||
xdef _timer1_isr
|
xref _low_nearbss:RAM
|
||||||
xdef _timer0_isr
|
xref _len_nearbss
|
||||||
xdef _uart0rx_isr
|
xref _low_farbss:ERAM
|
||||||
xdef _uart0tx_isr
|
xref _len_farbss:ERAM
|
||||||
xdef _i2c_isr
|
xref _low_neardata:RAM
|
||||||
xdef _spi_isr
|
xref _len_neardata
|
||||||
xdef _adc_isr
|
xref _low_near_romdata:EROM
|
||||||
xdef _p7ad_isr
|
xref _low_fardata:ERAM
|
||||||
xdef _p6ad_isr
|
xref _len_fardata:ERAM
|
||||||
xdef _p5ad_isr
|
xref _low_far_romdata:EROM
|
||||||
xdef _p4ad_isr
|
xref far_heapbot:ERAM
|
||||||
xdef _p3ad_isr
|
xref _far_stack:ERAM
|
||||||
xdef _p2ad_isr
|
xref _near_stack:RAM
|
||||||
xdef _p1ad_isr
|
|
||||||
xdef _p0ad_isr
|
/**************************************************************************
|
||||||
xdef _pwmtimer_isr
|
* Flash Option Byte Setup
|
||||||
xdef _uart1rx_isr
|
**************************************************************************/
|
||||||
xdef _uart1tx_isr
|
|
||||||
xdef _pwmfault_isr
|
define FOPTIONSEG, SPACE=ROM, ORG=0
|
||||||
xdef _c3_isr
|
segment FOPTIONSEG
|
||||||
xdef _c2_isr
|
db %FF
|
||||||
xdef _c1_isr
|
db %FF
|
||||||
xdef _c0_isr
|
db %FF
|
||||||
xdef _common_isr
|
db %FF
|
||||||
|
|
||||||
xref _low_nearbss:RAM
|
/**************************************************************************
|
||||||
xref _len_nearbss
|
* vectors
|
||||||
xref _low_farbss:ERAM
|
**************************************************************************/
|
||||||
xref _len_farbss:ERAM
|
|
||||||
xref _low_neardata:RAM
|
vector RESET=_z16f_reset
|
||||||
xref _len_neardata
|
vector SYSEXC=_sysexc_isr
|
||||||
xref _low_near_romdata:EROM
|
vector TIMER2=_timer2_isr
|
||||||
xref _low_fardata:ERAM
|
vector TIMER1=_timer1_isr
|
||||||
xref _len_fardata:ERAM
|
vector TIMER0=_timer0_isr
|
||||||
xref _low_far_romdata:EROM
|
vector UART0_RX=_uart0rx_isr
|
||||||
xref far_heapbot:ERAM
|
vector UART0_TX=_uart0tx_isr
|
||||||
xref _far_stack:ERAM
|
vector I2C=_i2c_isr
|
||||||
xref _near_stack:RAM
|
vector SPI=_spi_isr
|
||||||
|
vector ADC=_adc_isr
|
||||||
/**************************************************************************
|
vector P7AD=_p7ad_isr
|
||||||
* Flash Option Byte Setup
|
vector P6AD=_p6ad_isr
|
||||||
**************************************************************************/
|
vector P5AD=_p5ad_isr
|
||||||
|
vector P4AD=_p4ad_isr
|
||||||
define FOPTIONSEG, SPACE=ROM, ORG=0
|
vector P3AD=_p3ad_isr
|
||||||
segment FOPTIONSEG
|
vector P2AD=_p2ad_isr
|
||||||
db %FF
|
vector P1AD=_p1ad_isr
|
||||||
db %FF
|
vector P0AD=_p0ad_isr
|
||||||
db %FF
|
vector PWM_TIMER=_pwmtimer_isr
|
||||||
db %FF
|
vector UART1_RX=_uart1rx_isr
|
||||||
|
vector UART1_TX=_uart1tx_isr
|
||||||
/**************************************************************************
|
vector PWM_FAULT=_pwmfault_isr
|
||||||
* vectors
|
vector C3=_c3_isr
|
||||||
**************************************************************************/
|
vector C2=_c3_isr
|
||||||
|
vector C1=_c2_isr
|
||||||
vector RESET=_reset
|
vector C0=_c0_isr
|
||||||
vector SYSEXC=_sysexc_isr
|
|
||||||
vector TIMER2=_timer2_isr
|
/**************************************************************************
|
||||||
vector TIMER1=_timer1_isr
|
* Equates
|
||||||
vector TIMER0=_timer0_isr
|
**************************************************************************/
|
||||||
vector UART0_RX=_uart0rx_isr
|
|
||||||
vector UART0_TX=_uart0tx_isr
|
/**************************************************************************
|
||||||
vector I2C=_i2c_isr
|
* Data Allocation
|
||||||
vector SPI=_spi_isr
|
**************************************************************************/
|
||||||
vector ADC=_adc_isr
|
|
||||||
vector P7AD=_p7ad_isr
|
/**************************************************************************
|
||||||
vector P6AD=_p6ad_isr
|
* Code
|
||||||
vector P5AD=_p5ad_isr
|
**************************************************************************/
|
||||||
vector P4AD=_p4ad_isr
|
|
||||||
vector P3AD=_p3ad_isr
|
define CODESEG, SPACE=EROM
|
||||||
vector P2AD=_p2ad_isr
|
segment CODESEG
|
||||||
vector P1AD=_p1ad_isr
|
|
||||||
vector P0AD=_p0ad_isr
|
/**************************************************************************
|
||||||
vector PWM_TIMER=_pwmtimer_isr
|
* Name: _z16f_reset
|
||||||
vector UART1_RX=_uart1rx_isr
|
*
|
||||||
vector UART1_TX=_uart1tx_isr
|
* Description:
|
||||||
vector PWM_FAULT=_pwmfault_isr
|
* Reset entry point
|
||||||
vector C3=_c3_isr
|
*
|
||||||
vector C2=_c3_isr
|
**************************************************************************/
|
||||||
vector C1=_c2_isr
|
|
||||||
vector C0=_c0_isr
|
_z16f_reset:
|
||||||
|
/* Initialize the init/idle task stack */
|
||||||
/**************************************************************************
|
|
||||||
* Equates
|
ld sp, #(_near_stack+1) /* Set Stack Pointer to the top of internal RAM */
|
||||||
**************************************************************************/
|
clr fp
|
||||||
|
|
||||||
/**************************************************************************
|
/* Initialize onboard LEDs */
|
||||||
* Data Allocation
|
|
||||||
**************************************************************************/
|
#ifdef CONFIG_ARCH_LEDS
|
||||||
|
call _up_ledinit
|
||||||
/**************************************************************************
|
#endif
|
||||||
* Code
|
/* Perform VERY early UART initialization so that we can use it here */
|
||||||
**************************************************************************/
|
|
||||||
|
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
||||||
define CODESEG, SPACE=EROM
|
call _z16f_lowuartinit /* Initialize the UART for debugging */
|
||||||
segment CODESEG
|
#endif
|
||||||
|
/* Initialize the hardware stack overflow register */
|
||||||
/**************************************************************************
|
|
||||||
* Name: _reset
|
#ifdef CONFIG_Z16F_INITSPOV
|
||||||
*
|
ld r0, #(_near_stack_bot+1)
|
||||||
* Description:
|
ld spov, r0
|
||||||
* Reset entry point
|
#endif
|
||||||
*
|
/* Clear BSS */
|
||||||
**************************************************************************/
|
|
||||||
|
lea r0, _low_nearbss
|
||||||
_reset:
|
ld r1, #_len_nearbss+1
|
||||||
/* Initialize the init/idle task stack */
|
jp _z16f_reset2
|
||||||
|
_z16f_reset1:
|
||||||
ld sp, #(_near_stack+1) /* Set Stack Pointer to the top of internal RAM */
|
ld.b (r0++), #0
|
||||||
clr fp
|
_z16f_reset2:
|
||||||
|
djnz r1, _z16f_reset1
|
||||||
/* Initialize onboard LEDs */
|
|
||||||
|
lea r0, _low_farbss
|
||||||
#ifdef CONFIG_ARCH_LEDS
|
ld r1, #_len_farbss+1
|
||||||
bl _up_ledinit
|
jp _z16f_reset4
|
||||||
#endif
|
_z16f_reset3:
|
||||||
/* Perform VERY early UART initialization so that we can use it here */
|
ld.b (r0++), #0
|
||||||
|
_z16f_reset4:
|
||||||
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
djnz r1, _z16f_reset3
|
||||||
call _z16f_lowuartinit /* Initialize the UART for debugging */
|
|
||||||
#endif
|
/* Copy ROM data into RAM */
|
||||||
/* Initialize the hardware stack overflow register */
|
|
||||||
|
lea r0, _low_near_romdata
|
||||||
#ifdef CONFIG_Z16F_INITSPOV
|
lea r1, _low_neardata
|
||||||
ld r0, #(_near_stack_bot+1)
|
ld r2, #_len_neardata+1
|
||||||
ld spov, r0
|
jp _z16f_reset6
|
||||||
#endif
|
_z16f_reset5:
|
||||||
/* Clear BSS */
|
ld.b r3, (r0++)
|
||||||
|
ld.b (r1++), r3
|
||||||
lea r0, _low_nearbss
|
_z16f_reset6:
|
||||||
ld r1, #_len_nearbss+1
|
djnz r2, _z16f_reset5
|
||||||
jp _reset2
|
|
||||||
_reset1:
|
lea r0, _low_far_romdata
|
||||||
ld.b (r0++), #0
|
lea r1, _low_fardata
|
||||||
_reset2:
|
ld r2, #_len_fardata+1
|
||||||
djnz r1, _reset1
|
jp _z16f_reset8
|
||||||
|
_z16f_reset7:
|
||||||
lea r0, _low_farbss
|
ld.b r3, (r0++)
|
||||||
ld r1, #_len_farbss+1
|
ld.b (r1++), r3
|
||||||
jp _reset4
|
_z16f_reset8:
|
||||||
_reset3:
|
djnz r2, _z16f_reset7
|
||||||
ld.b (r0++), #0
|
|
||||||
_reset4:
|
/* Perform low-level hardware initialization */
|
||||||
djnz r1, _reset3
|
|
||||||
|
call _z16f_lowinit /* Perform low-level hardware initialization */
|
||||||
/* Copy ROM data into RAM */
|
|
||||||
|
/* Start NuttX */
|
||||||
lea r0, _low_near_romdata
|
|
||||||
lea r1, _low_neardata
|
call _os_start /* Start the operating system */
|
||||||
ld r2, #_len_neardata+1
|
_halt1: /* _os_start() should not return */
|
||||||
jp _reset6
|
halt
|
||||||
_reset5:
|
jp _halt1
|
||||||
ld.b r3, (r0++)
|
|
||||||
ld.b (r1++), r3
|
/**************************************************************************
|
||||||
_reset6:
|
* Name: _sysexec_isr
|
||||||
djnz r2, _reset5
|
*
|
||||||
|
* Description:
|
||||||
lea r0, _low_far_romdata
|
* System exception interrupt handler. On entry, the stack looks like
|
||||||
lea r1, _low_fardata
|
* this:
|
||||||
ld r2, #_len_fardata+1
|
*
|
||||||
jp _reset8
|
* TOS[0] = PC[31:24]
|
||||||
_reset7:
|
* TOS[1] = PC[23:16]
|
||||||
ld.b r3, (r0++)
|
* TOS[2] = PC[15:8]
|
||||||
ld.b (r1++), r3
|
* TOS[3] = PC[7:0]
|
||||||
_reset8:
|
* TOS[4] = 0
|
||||||
djnz r2, _reset7
|
* TOS[5] = flags
|
||||||
|
*
|
||||||
/* Perform low-level hardware initialization */
|
**************************************************************************/
|
||||||
|
|
||||||
call _z16f_lowinit /* Perform low-level hardware initialization */
|
_sysexc_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
/* Start NuttX */
|
|
||||||
|
/* Calculate the value of the SP BEFORE the interrupt occurred and
|
||||||
call _os_start /* Start the operating system */
|
* push that as the saved value of r15=sp
|
||||||
_halted: /* _os_start() should not return */
|
*/
|
||||||
halt
|
|
||||||
jp _halted
|
ld r1, #-6 /* return(4) + flags(1) + padding(1) */
|
||||||
|
add r1, sp /* r1 = Value of the SP before the interrupt */
|
||||||
/**************************************************************************
|
push r1 /* Push r1 in the spot for the saved SP */
|
||||||
* Name: Interrupt handlers
|
|
||||||
*
|
/* Save all of the remaining registers */
|
||||||
* Description:
|
|
||||||
* All interrupts will be vectored to the following locations.
|
pushmhi <r8-r14>
|
||||||
* On entry, the stack contains the following:
|
|
||||||
*
|
/* SP now holds the address of the beginning of the save structure
|
||||||
* TOS[0] = PC[31:24]
|
* on the stack. Now handle the system exception with arg1(r1)=address
|
||||||
* TOS[1] = PC[23:16]
|
* of the register save structure.
|
||||||
* TOS[2] = PC[15:8]
|
*/
|
||||||
* TOS[3] = PC[7:0]
|
|
||||||
* TOS[4] = 0
|
ld r1, sp
|
||||||
* TOS[5] = flags
|
call _z16f_sysexec /* Handle in C logic */
|
||||||
*
|
|
||||||
**************************************************************************/
|
_halt2: /* _z16f_sysexec() should not return */
|
||||||
|
halt
|
||||||
_sysexc_isr:
|
jp _halt2
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
|
||||||
ld r1, #Z16F_IRQ_SYSEXC /* r1 = SYSEXEC IRQ number */
|
/**************************************************************************
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
* Name: Interrupt handlers
|
||||||
|
*
|
||||||
_timer2_isr:
|
* Description:
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
* All interrupts will be vectored to the following locations.
|
||||||
ld r1, #Z16F_IRQ_TIMER0 /* r1 = Timer 2 IRQ number */
|
* On entry, the stack contains the following:
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
*
|
||||||
|
* TOS[0] = PC[31:24]
|
||||||
_timer1_isr:
|
* TOS[1] = PC[23:16]
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
* TOS[2] = PC[15:8]
|
||||||
ld r1, #Z16F_IRQ_TIMER0 /* r1 = Timer 1 IRQ number */
|
* TOS[3] = PC[7:0]
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
* TOS[4] = 0
|
||||||
|
* TOS[5] = flags
|
||||||
_timer0_isr:
|
*
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
**************************************************************************/
|
||||||
ld r1, #Z16F_IRQ_TIMER0 /* r1 = Timer 0 IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_timer2_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_uart0rx_isr:
|
ld r1, #Z16F_IRQ_TIMER0 /* r1 = Timer 2 IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_UART0RX /* r1 = UART0 RX IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_timer1_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_uart0tx_isr:
|
ld r1, #Z16F_IRQ_TIMER0 /* r1 = Timer 1 IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_UART0TX /* r1 = UART0 TX IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_timer0_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_i2c_isr:
|
ld r1, #Z16F_IRQ_TIMER0 /* r1 = Timer 0 IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_I2C /* r1 = I2C IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_uart0rx_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_spi_isr:
|
ld r1, #Z16F_IRQ_UART0RX /* r1 = UART0 RX IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_SPI /* r1 = SPI IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_uart0tx_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_adc_isr:
|
ld r1, #Z16F_IRQ_UART0TX /* r1 = UART0 TX IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_ADC /* r1 = ADC IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_i2c_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p7ad_isr:
|
ld r1, #Z16F_IRQ_I2C /* r1 = I2C IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P7AD /* r1 = Port A/D7, rising/falling edge IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_spi_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p6ad_isr:
|
ld r1, #Z16F_IRQ_SPI /* r1 = SPI IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P6AD /* r1 = Port A/D6, rising/falling edge IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_adc_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p5ad_isr:
|
ld r1, #Z16F_IRQ_ADC /* r1 = ADC IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P5AD /* r1 = Port A/D5, rising/falling edge IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p7ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p4ad_isr:
|
ld r1, #Z16F_IRQ_P7AD /* r1 = Port A/D7, rising/falling edge IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P4AD /* r1 = Port A/D4, rising/falling edge IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p6ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p3ad_isr:
|
ld r1, #Z16F_IRQ_P6AD /* r1 = Port A/D6, rising/falling edge IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P3AD /* r1 = Port A/D3, rising/falling edgeEXEC IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p5ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p2ad_isr:
|
ld r1, #Z16F_IRQ_P5AD /* r1 = Port A/D5, rising/falling edge IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P2AD /* r1 = Port A/D2, rising/falling edge IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p4ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p1ad_isr:
|
ld r1, #Z16F_IRQ_P4AD /* r1 = Port A/D4, rising/falling edge IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P1AD /* r1 = Port A/D1, rising/falling edge IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p3ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_p0ad_isr:
|
ld r1, #Z16F_IRQ_P3AD /* r1 = Port A/D3, rising/falling edgeEXEC IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_P0AD /* r1 = Port A/D0, rising/falling edge IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p2ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_pwmtimer_isr:
|
ld r1, #Z16F_IRQ_P2AD /* r1 = Port A/D2, rising/falling edge IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_PWMTIMER /* r1 = PWM Timer IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p1ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_uart1rx_isr:
|
ld r1, #Z16F_IRQ_P1AD /* r1 = Port A/D1, rising/falling edge IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_UART1RX /* r1 = UART1 RX IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_p0ad_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_uart1tx_isr:
|
ld r1, #Z16F_IRQ_P0AD /* r1 = Port A/D0, rising/falling edge IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_UART1TX /* r1 = UART1 TX IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_pwmtimer_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_pwmfault_isr:
|
ld r1, #Z16F_IRQ_PWMTIMER /* r1 = PWM Timer IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_PWMFAULT /* r1 = PWM Fault IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_uart1rx_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_c3_isr:
|
ld r1, #Z16F_IRQ_UART1RX /* r1 = UART1 RX IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_C3 /* r1 = Port C3, both edges DMA3 IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_uart1tx_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_c2_isr:
|
ld r1, #Z16F_IRQ_UART1TX /* r1 = UART1 TX IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_C2 /* r1 = Port C2, both edges DMA2 IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_pwmfault_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_c1_isr:
|
ld r1, #Z16F_IRQ_PWMFAULT /* r1 = PWM Fault IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_C1 /* r1 = Port C1, both edges DMA1 IRQ number */
|
|
||||||
jp _common_isr /* Join common interrupt handling logic */
|
_c3_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
_c0_isr:
|
ld r1, #Z16F_IRQ_C3 /* r1 = Port C3, both edges DMA3 IRQ number */
|
||||||
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
ld r1, #Z16F_IRQ_C0 /* r1 = Port C0, both edges DMA0 IRQ number */
|
|
||||||
/* Join common interrupt handling logic */
|
_c2_isr:
|
||||||
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
|
ld r1, #Z16F_IRQ_C2 /* r1 = Port C2, both edges DMA2 IRQ number */
|
||||||
/**************************************************************************
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
* Name: _common_isr
|
|
||||||
*
|
_c1_isr:
|
||||||
* Description:
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
* Common interrupt handling logic.
|
ld r1, #Z16F_IRQ_C1 /* r1 = Port C1, both edges DMA1 IRQ number */
|
||||||
*
|
jp _common_isr /* Join common interrupt handling logic */
|
||||||
* On entry:
|
|
||||||
*
|
_c0_isr:
|
||||||
* r0 = IRQ number
|
pushmlo <r0-r7> /* Save r0-r7 on the stack */
|
||||||
*
|
ld r1, #Z16F_IRQ_C0 /* r1 = Port C0, both edges DMA0 IRQ number */
|
||||||
* And the stack contains the following:
|
/* Join common interrupt handling logic */
|
||||||
*
|
|
||||||
* TOS[ 0- 3] = r0
|
|
||||||
* TOS[ 4- 7] = r1
|
/**************************************************************************
|
||||||
* TOS[ 8-11] = r2
|
* Name: _common_isr
|
||||||
* TOS[12-15] = r3
|
*
|
||||||
* TOS[16-19] = r4
|
* Description:
|
||||||
* TOS[20-23] = r5
|
* Common interrupt handling logic.
|
||||||
* TOS[24-27] = r6
|
*
|
||||||
* TOS[28-31] = r7
|
* On entry:
|
||||||
* TOS[32-33] = return PC
|
*
|
||||||
* TOS[34-35] = flags (with padding)
|
* r0 = IRQ number
|
||||||
*
|
*
|
||||||
**************************************************************************/
|
* And the stack contains the following:
|
||||||
|
*
|
||||||
_common_isr:
|
* TOS[ 0- 3] = r0
|
||||||
/* Calculate the value of the SP BEFORE the interrupt occurred and
|
* TOS[ 4- 7] = r1
|
||||||
* push that as the saved value of r15=sp
|
* TOS[ 8-11] = r2
|
||||||
*/
|
* TOS[12-15] = r3
|
||||||
|
* TOS[16-19] = r4
|
||||||
ld r1, #-36 /* See stack accounting above */
|
* TOS[20-23] = r5
|
||||||
add r1, sp /* r1 = Value of the SP before the interrupt */
|
* TOS[24-27] = r6
|
||||||
push r1 /* Push r1 in the spot for the saved SP */
|
* TOS[28-31] = r7
|
||||||
|
* TOS[32-33] = return PC
|
||||||
/* Save all of the remaining registers */
|
* TOS[34-35] = flags (with padding)
|
||||||
|
*
|
||||||
pushmhi <r8-r14>
|
**************************************************************************/
|
||||||
|
|
||||||
/* SP now holds the address of the beginning of the save structure
|
_common_isr:
|
||||||
* on the stack. Now handle the interrupt with arg1(r1)=IRQ number and
|
/* Calculate the value of the SP BEFORE the interrupt occurred and
|
||||||
* arg2(r2)=address of the register save structure.
|
* push that as the saved value of r15=sp
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ld r2, sp
|
ld r1, #-36 /* See stack accounting above */
|
||||||
call _up_doirq
|
add r1, sp /* r1 = Value of the SP before the interrupt */
|
||||||
|
push r1 /* Push r1 in the spot for the saved SP */
|
||||||
/* Upon return, _up_doirq will provide that address of the save structure
|
|
||||||
* to use to return from the interrupt in r0. This may or may not be the
|
/* Save all of the remaining registers */
|
||||||
* same value as sp.
|
|
||||||
*/
|
pushmhi <r8-r14>
|
||||||
|
|
||||||
ld sp, 2*REG_SP(r0) /* sp=Value of SP on return from interrupt */
|
/* SP now holds the address of the beginning of the save structure
|
||||||
ld.w r1, 2*REG_FLAGS(r0) /* r1=padded flags value */
|
* on the stack. Now handle the interrupt with arg1(r1)=IRQ number and
|
||||||
push.w r1 /* Push padded flags value onto the stack */
|
* arg2(r2)=address of the register save structure.
|
||||||
ld r1, 2*REG_PC(r0) /* r1=return address */
|
*/
|
||||||
push r1 /* Push the return address onto the stack */
|
|
||||||
|
ld r2, sp
|
||||||
ld sp, r0 /* sp=Value of SP at call to _up_doirq */
|
call _up_doirq
|
||||||
popmhi <r8-r14> /* Restore r8-r14 */
|
|
||||||
popmlo <r0-r7> /* Restore r0-r7 */
|
/* Upon return, _up_doirq will provide that address of the save structure
|
||||||
iret /* Return from interrupt */
|
* to use to return from the interrupt in r0. This may or may not be the
|
||||||
|
* same value as sp.
|
||||||
end
|
*/
|
||||||
|
|
||||||
|
ld sp, 2*REG_SP(r0) /* sp=Value of SP on return from interrupt */
|
||||||
|
ld.w r1, 2*REG_FLAGS(r0) /* r1=padded flags value */
|
||||||
|
push.w r1 /* Push padded flags value onto the stack */
|
||||||
|
ld r1, 2*REG_PC(r0) /* r1=return address */
|
||||||
|
push r1 /* Push the return address onto the stack */
|
||||||
|
|
||||||
|
ld sp, r0 /* sp=Value of SP at call to _up_doirq */
|
||||||
|
popmhi <r8-r14> /* Restore r8-r14 */
|
||||||
|
popmlo <r0-r7> /* Restore r0-r7 */
|
||||||
|
iret /* Return from interrupt */
|
||||||
|
|
||||||
|
end
|
||||||
|
@ -1,234 +1,233 @@
|
|||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
* arch/z16/src/z16f/z16f_lowuart.asm
|
* arch/z16/src/z16f/z16f_lowuart.asm
|
||||||
* Z16F UART management
|
* Z16F UART management
|
||||||
*
|
*
|
||||||
* Copyright (C) 2008 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2008 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
* are met:
|
* are met:
|
||||||
*
|
*
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
* notice, this list of conditions and the following disclaimer.
|
* notice, this list of conditions and the following disclaimer.
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
* notice, this list of conditions and the following disclaimer in
|
* notice, this list of conditions and the following disclaimer in
|
||||||
* the documentation and/or other materials provided with the
|
* the documentation and/or other materials provided with the
|
||||||
* distribution.
|
* distribution.
|
||||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
* used to endorse or promote products derived from this software
|
* used to endorse or promote products derived from this software
|
||||||
* without specific prior written permission.
|
* without specific prior written permission.
|
||||||
*
|
*
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSeqUENTIAL DAMAGES (INCLUDING,
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSeqUENTIAL DAMAGES (INCLUDING,
|
||||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
|
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
* Included Files
|
* Included Files
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
#include "chip/chip.h"
|
#include "chip/chip.h"
|
||||||
|
|
||||||
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
#if defined(CONFIG_ARCH_LOWPUTC) || defined(CONFIG_ARCH_LOWGETC)
|
||||||
|
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
* External References / External Definitions
|
* External References / External Definitions
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
|
|
||||||
xdef _z16f_lowuartinit
|
xdef _z16f_lowuartinit
|
||||||
xref _SYS_CLK_FREQ:EROM
|
xref _SYS_CLK_FREQ:EROM
|
||||||
#ifdef CONFIG_ARCH_LOWPUTC
|
#ifdef CONFIG_ARCH_LOWPUTC
|
||||||
xdef _z16f_xmitc
|
xdef _up_lowputc
|
||||||
xdef _up_lowputc
|
#endif
|
||||||
#endif
|
#ifdef CONFIG_ARCH_LOWGETC
|
||||||
#ifdef CONFIG_ARCH_LOWGETC
|
xdef _up_lowgetc
|
||||||
xdef _up_lowgetc
|
#endif
|
||||||
#endif
|
|
||||||
|
/*************************************************************************
|
||||||
/*************************************************************************
|
* Data Allocation
|
||||||
* Data Allocation
|
*************************************************************************/
|
||||||
*************************************************************************/
|
|
||||||
|
define CODESEG, SPACE=EROM
|
||||||
define CODESEG, SPACE=EROM
|
segment CODESEG
|
||||||
segment CODESEG
|
|
||||||
|
/*************************************************************************
|
||||||
/*************************************************************************
|
* Code
|
||||||
* Code
|
*************************************************************************/
|
||||||
*************************************************************************/
|
|
||||||
|
/*************************************************************************
|
||||||
/*************************************************************************
|
* Name: z16f_lowuartinit
|
||||||
* Name: z16f_lowuartinit
|
*
|
||||||
*
|
* Description:
|
||||||
* Description:
|
* Initialize UART0 or UART1
|
||||||
* Initialize UART0 or UART1
|
*
|
||||||
*
|
* Parameters:
|
||||||
* Parameters:
|
* None
|
||||||
* None
|
*
|
||||||
*
|
*************************************************************************/
|
||||||
*************************************************************************/
|
|
||||||
|
_z16f_lowuartinit:
|
||||||
_z16f_lowuartinit:
|
pushmlo <r0, r3> /* Save registers */
|
||||||
pushmlo <r0, r3> /* Save registers */
|
|
||||||
|
/* Calculate and set the baud rate generation register */
|
||||||
/* Calculate and set the baud rate generation register */
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
||||||
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
ld r3, #CONFIG_UART0_BAUD /* r3 = baud */
|
||||||
ld r3, #CONFIG_UART0_BAUD /* r3 = baud */
|
#else
|
||||||
#else
|
ld r3, #CONFIG_UART1_BAUD /* r3 = baud */
|
||||||
ld r3, #CONFIG_UART1_BAUD /* r3 = baud */
|
#endif
|
||||||
#endif
|
ld r0, r3 /* r0 = baud */
|
||||||
ld r0, r3 /* r0 = baud */
|
sll r0, #3 /* r0 = baud * 8 */
|
||||||
sll r0, #3 /* r0 = baud * 8 */
|
add r0, #_SYS_CLK_FREQ /* r3 = freq + baud * 8*/
|
||||||
add r0, #_SYS_CLK_FREQ /* r3 = freq + baud * 8*/
|
sll r3, #4 /* r3 = baud * 16 */
|
||||||
sll r3, #4 /* r3 = baud * 16 */
|
udiv r0, r3 /* BRG = (freq + baud * 8)/(baud * 16) */
|
||||||
udiv r0, r3 /* BRG = (freq + baud * 8)/(baud * 16) */
|
|
||||||
|
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
||||||
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
ld.w Z16F_UART0_BR, r0 /* Z16F_UART0_BR = BRG */
|
||||||
ld.w Z16F_UART0_BR, r0 /* Z16F_UART0_BR = BRG */
|
|
||||||
|
/* Set the GPIO Alternate Function Register Lo (AFL) register */
|
||||||
/* Set the GPIO Alternate Function Register Lo (AFL) register */
|
|
||||||
|
ld r0, #%30
|
||||||
ld r0, #%30
|
or.b Z16F_GPIOA_AFL, r0 /* Z16F_GPIOA_AFL |= %30 */
|
||||||
or.b Z16F_GPIOA_AFL, r0 /* Z16F_GPIOA_AFL |= %30 */
|
|
||||||
|
/* Enable UART receive (REN) and transmit (TEN) */
|
||||||
/* Enable UART receive (REN) and transmit (TEN) */
|
|
||||||
|
clr.b Z16F_UART0_CTL1 /* Z16F_UART0_CTL1 = 0 */
|
||||||
clr.b Z16F_UART0_CTL1 /* Z16F_UART0_CTL1 = 0 */
|
ld r0, #(Z16F_UARTCTL0_TEN|Z16F_UARTCTL0_REN)
|
||||||
ld r0, #(Z16F_UARTCTL0_TEN|Z16F_UARTCTL0_REN)
|
ld.b Z16F_UART0_CTL0, r0 /* Z16F_UART0_CTL0 = %c0 */
|
||||||
ld.b Z16F_UART0_CTL0, r0 /* Z16F_UART0_CTL0 = %c0 */
|
#else
|
||||||
#else
|
ld.w Z16F_UART1_BR, r0 /* Z16F_UART1_BR = BRG */
|
||||||
ld.w Z16F_UART1_BR, r0 /* Z16F_UART1_BR = BRG */
|
|
||||||
|
/* Set the GPIO Alternate Function Register Lo (AFL) register */
|
||||||
/* Set the GPIO Alternate Function Register Lo (AFL) register */
|
|
||||||
|
ld r0, #%30
|
||||||
ld r0, #%30
|
or.b Z16F_GPIOD_AFL, r0 /* Z16F_GPIOD_AFL |= %30 */
|
||||||
or.b Z16F_GPIOD_AFL, r0 /* Z16F_GPIOD_AFL |= %30 */
|
|
||||||
|
/* Enable UART receive (REN) and transmit (TEN) */
|
||||||
/* Enable UART receive (REN) and transmit (TEN) */
|
|
||||||
|
clr.b Z16F_UART1_CTL1 /* Z16F_UART1_CTL1 = 0 */
|
||||||
clr.b Z16F_UART1_CTL1 /* Z16F_UART1_CTL1 = 0 */
|
ld r0, #(Z16F_UARTCTL0_TEN|Z16F_UARTCTL0_REN)
|
||||||
ld r0, #(Z16F_UARTCTL0_TEN|Z16F_UARTCTL0_REN)
|
ld.b Z16F_UART1_CTL0, r0 /* Z16F_UART1_CTL0 = %c0 */
|
||||||
ld.b Z16F_UART1_CTL0, r0 /* Z16F_UART1_CTL0 = %c0 */
|
#endif
|
||||||
#endif
|
popmlo <r0, r3> /* Restore registers */
|
||||||
popmlo <r0, r3> /* Restore registers */
|
ret /* Return */
|
||||||
ret /* Return */
|
|
||||||
|
|
||||||
|
/*************************************************************************
|
||||||
/*************************************************************************
|
* Name: _z16f_xmitc
|
||||||
* Name: _z16f_xmitc
|
*
|
||||||
*
|
* Description:
|
||||||
* Description:
|
* Send one character on the selected port
|
||||||
* Send one character on the selected port
|
*
|
||||||
*
|
* Parmeters:
|
||||||
* Parmeters:
|
* r1 = character
|
||||||
* r1 = character
|
*
|
||||||
*
|
*************************************************************************/
|
||||||
*************************************************************************/
|
|
||||||
|
#ifdef CONFIG_ARCH_LOWPUTC
|
||||||
#ifdef CONFIG_ARCH_LOWPUTC
|
_z16f_xmitc:
|
||||||
_z16f_xmitc:
|
pushmlo <r0> /* Save registers */
|
||||||
pushmlo <r0> /* Save registers */
|
|
||||||
|
_z16f_xmitc1:
|
||||||
_z16f_xmitc1:
|
ld r0, Z16F_UARTSTAT0_TDRE /* TDRE=Transmitter Data Register Empty */
|
||||||
ld r0, Z16F_UARTSTAT0_TDRE /* TDRE=Transmitter Data Register Empty */
|
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
||||||
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
tm.b Z16F_UART0_STAT0, r0 /* r0 = Z16F_UART0_STAT0 */
|
||||||
tm.b Z16F_UART0_STAT0, r0 /* r0 = Z16F_UART0_STAT0 */
|
jp eq, _z16f_xmitc1 /* While (!(Z16F_UART0_STAT0 & TDRE)) */
|
||||||
jp eq, _z16f_xmitc1 /* While (!(Z16F_UART0_STAT0 & TDRE)) */
|
ld.b Z16F_UART0_TXD, r1 /* Z16F_UART0_TXD = r1 (character) */
|
||||||
ld.b Z16F_UART0_TXD, r1 /* Z16F_UART0_TXD = r1 (character) */
|
#else
|
||||||
#else
|
tm.b Z16F_UART1_STAT0, r0 /* r0 = Z16F_UART0_STAT1 */
|
||||||
tm.b Z16F_UART1_STAT0, r0 /* r0 = Z16F_UART0_STAT1 */
|
jp eq, _z16f_xmitc1 /* While (!(Z16F_UART1_STAT0 & TDRE)) */
|
||||||
jp eq, _z16f_xmitc1 /* While (!(Z16F_UART1_STAT0 & TDRE)) */
|
ld.b Z16F_UART1_TXD, r1 /* Z16F_UART1_TXD = r1 (character) */
|
||||||
ld.b Z16F_UART1_TXD, r1 /* Z16F_UART1_TXD = r1 (character) */
|
#endif
|
||||||
#endif
|
popmlo <r0> /* Restore registers */
|
||||||
popmlo <r0> /* Restore registers */
|
ret /* Return */
|
||||||
ret /* Return */
|
#endif
|
||||||
#endif
|
|
||||||
|
/*************************************************************************
|
||||||
/*************************************************************************
|
* Name: _up_lowputc
|
||||||
* Name: _up_lowputc
|
*
|
||||||
*
|
* Description:
|
||||||
* Description:
|
* Send one character to the selected serial console
|
||||||
* Send one character to the selected serial console
|
*
|
||||||
*
|
* Parmeters:
|
||||||
* Parmeters:
|
* r1 = character
|
||||||
* r1 = character
|
*
|
||||||
*
|
* Return
|
||||||
* Return
|
* R0 = 0
|
||||||
* R0 = 0
|
*
|
||||||
*
|
*************************************************************************/
|
||||||
*************************************************************************/
|
|
||||||
|
#ifdef CONFIG_ARCH_LOWPUTC
|
||||||
#ifdef CONFIG_ARCH_LOWPUTC
|
_up_lowputc:
|
||||||
_up_lowputc:
|
pushmlo <r1,r5> /* Save registers */
|
||||||
pushmlo <r1,r5> /* Save registers */
|
ld r0, r1
|
||||||
ld r0, r1
|
ext.ub r5, r0
|
||||||
ext.ub r5, r0
|
cp r5, #10
|
||||||
cp r5, #10
|
jp ne, _up_lowputc1 /* If (character == \n) */
|
||||||
jp ne, _up_lowputc1 /* If (character == \n) */
|
|
||||||
|
ld r1,#13
|
||||||
ld r1,#13
|
call _z16f_xmitc /* Call _z16f_xmitc with \r */
|
||||||
call _z16f_xmitc /* Call _z16f_xmitc with \r */
|
|
||||||
|
_up_lowputc1:
|
||||||
_up_lowputc1:
|
ld r1, r0
|
||||||
ld r1, r0
|
call _z16f_xmitc /* Xall _z16f_xmitc with character */
|
||||||
call _z16f_xmitc /* Xall _z16f_xmitc with character */
|
|
||||||
|
ld r0, #0 /* return r0 = 0 */
|
||||||
ld r0, #0 /* return r0 = 0 */
|
popmlo <r1,r5> /* Restore registers */
|
||||||
popmlo <r1,r5> /* Restore registers */
|
ret /* Return */
|
||||||
ret /* Return */
|
#endif
|
||||||
#endif
|
|
||||||
|
/*************************************************************************
|
||||||
/*************************************************************************
|
* Name: _up_lowgetc
|
||||||
* Name: _up_lowgetc
|
*
|
||||||
*
|
* Description:
|
||||||
* Description:
|
* Get a character from the serial port
|
||||||
* Get a character from the serial port
|
*
|
||||||
*
|
* Parmeters:
|
||||||
* Parmeters:
|
* None
|
||||||
* None
|
*
|
||||||
*
|
* Return
|
||||||
* Return
|
* R0 = Character read
|
||||||
* R0 = Character read
|
*
|
||||||
*
|
*************************************************************************/
|
||||||
*************************************************************************/
|
|
||||||
|
#ifdef CONFIG_ARCH_LOWGETC
|
||||||
#ifdef CONFIG_ARCH_LOWGETC
|
_up_lowgetc:
|
||||||
_up_lowgetc:
|
up_lowgetc1:
|
||||||
up_lowgetc1:
|
ld r0, #Z16F_UARTSTAT0_RDA /* RDA=Receive data available */
|
||||||
ld r0, #Z16F_UARTSTAT0_RDA /* RDA=Receive data available */
|
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
||||||
#ifdef CONFIG_UART0_SERIAL_CONSOLE
|
tm.b Z16F_UART0_STAT0, r0
|
||||||
tm.b Z16F_UART0_STAT0, r0
|
jp eq, _up_lowgetc1 /* While (!Z16F_UART0_STAT0 & RDA)) */
|
||||||
jp eq, _up_lowgetc1 /* While (!Z16F_UART0_STAT0 & RDA)) */
|
ld.ub r0, Z16F_UART0_RXD /* r0 = Z16F_UART0_RXD */
|
||||||
ld.ub r0, Z16F_UART0_RXD /* r0 = Z16F_UART0_RXD */
|
#else
|
||||||
#else
|
tm.b Z16F_UART1_STAT0,r0 /* While (!Z16F_UART1_STAT0 & RDA) */
|
||||||
tm.b Z16F_UART1_STAT0,r0 /* While (!Z16F_UART1_STAT0 & RDA) */
|
jp eq, _up_lowgetc1
|
||||||
jp eq, _up_lowgetc1
|
ld.ub r0, Z16F_UART1_RXD /* r0 = Z16F_UART1_RXD */
|
||||||
ld.ub r0, Z16F_UART1_RXD /* r0 = Z16F_UART1_RXD */
|
#endif
|
||||||
#endif
|
cp r0, #%0d /* Test for '\r' */
|
||||||
cp r0, #%0d /* Test for '\r' */
|
jp eq, _up_lowgetc2
|
||||||
jp eq, _up_lowgetc2
|
|
||||||
|
cp r0, #%0d /* Test \r + high bit */
|
||||||
cp r0, #%0d /* Test \r + high bit */
|
jp ne, _up_lowgetc3
|
||||||
jp ne, _up_lowgetc3
|
_up_lowgetc2:
|
||||||
_up_lowgetc2:
|
ld r0, #%0a /* Convert '\r' to '\n' */
|
||||||
ld r0, #%0a /* Convert '\r' to '\n' */
|
_up_lowgetc3: /* Return value in r0 */
|
||||||
_up_lowgetc3: /* Return value in r0 */
|
ret /* Return */
|
||||||
ret /* Return */
|
#endif
|
||||||
#endif
|
|
||||||
|
#endif /* CONFIG_ARCH_LOWPUTC || CONFIG_ARCH_LOWGETC */
|
||||||
#endif /* CONFIG_ARCH_LOWPUTC || CONFIG_ARCH_LOWGETC */
|
|
||||||
|
end
|
||||||
end
|
|
||||||
|
126
arch/z16/src/z16f/z16f_sysexec.c
Normal file
126
arch/z16/src/z16f/z16f_sysexec.c
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* z16f/z16f_sysexec.c
|
||||||
|
*
|
||||||
|
* Copyright (C) 2008 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 "chip/chip.h"
|
||||||
|
#include "os_internal.h"
|
||||||
|
#include "up_internal.h"
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Definitions
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_LOWPUTC
|
||||||
|
# define SYSDBG lib_lowprintf
|
||||||
|
#else
|
||||||
|
# define SYSDBG lib_rawprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Private Types
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Private Functions
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Global Functions
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
/***************************************************************************
|
||||||
|
* Function: z16f_sysexec
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Handle a Z16F system execption
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
void z16f_sysexec(FAR chipreg_t *regs)
|
||||||
|
{
|
||||||
|
int errcode = OSERR_ERREXCEPTION;
|
||||||
|
uint16 excp;
|
||||||
|
|
||||||
|
/* The cause of the the system exception is indicated in the SYSEXCPH&L
|
||||||
|
* registers
|
||||||
|
*/
|
||||||
|
|
||||||
|
excp = getreg16(Z16F_SYSEXCP);
|
||||||
|
if ((excp & Z16F_SYSEXCP_SPOVF) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("SP OVERFLOW\n");
|
||||||
|
}
|
||||||
|
if ((excp & Z16F_SYSEXCP_PCOVF) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("PC OVERFLOW\n");
|
||||||
|
}
|
||||||
|
if ((excp & Z16F_SYSEXCP_DIV0) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("Divide by zero\n");
|
||||||
|
}
|
||||||
|
if ((excp & Z16F_SYSEXCP_DIVOVF) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("Divide overflow\n");
|
||||||
|
}
|
||||||
|
if ((excp & Z16F_SYSEXCP_ILL) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("Illegal instruction\n");
|
||||||
|
errcode = OSERR_UNDEFINEDINSN;
|
||||||
|
}
|
||||||
|
if ((excp & Z16F_SYSEXCP_WDTOSC) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("WDT oscillator failure\n");
|
||||||
|
}
|
||||||
|
if ((excp & Z16F_SYSEXCP_PRIOSC) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("Primary Oscillator Failure\n");
|
||||||
|
}
|
||||||
|
if ((excp & Z16F_SYSEXCP_WDT) != 0)
|
||||||
|
{
|
||||||
|
SYSDBG("Watchdog timeout\n");
|
||||||
|
z16f_reset();
|
||||||
|
}
|
||||||
|
PANIC(errcode);
|
||||||
|
}
|
@ -57,10 +57,11 @@
|
|||||||
#define LED_STARTED 0
|
#define LED_STARTED 0
|
||||||
#define LED_HEAPALLOCATE 1
|
#define LED_HEAPALLOCATE 1
|
||||||
#define LED_IRQSENABLED 2
|
#define LED_IRQSENABLED 2
|
||||||
#define LED_IDLE 3
|
#define LED_STACKCREATED 3
|
||||||
#define LED_INIRQ 4
|
#define LED_IDLE 4
|
||||||
#define LED_ASSERTION 5
|
#define LED_INIRQ 5
|
||||||
#define LED_PANIC 6
|
#define LED_ASSERTION 6
|
||||||
|
#define LED_PANIC 7
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
|
@ -47,7 +47,9 @@
|
|||||||
# CONFIG_ARCH_BOARD - identifies the configs subdirectory and, hence,
|
# CONFIG_ARCH_BOARD - identifies the configs subdirectory and, hence,
|
||||||
# the board that supports the particular chip or SoC.
|
# the board that supports the particular chip or SoC.
|
||||||
# CONFIG_ARCH_BOARD_name - for use in C code
|
# CONFIG_ARCH_BOARD_name - for use in C code
|
||||||
|
# CONFIG_BOARD_LOOPSPERMSEC - for delay loops
|
||||||
# CONFIG_DRAM_SIZE - Describes the installed DRAM.
|
# CONFIG_DRAM_SIZE - Describes the installed DRAM.
|
||||||
|
# CONFIG_ARCH_LEDS - Use LEDs to show state. Unique to z16f.
|
||||||
#
|
#
|
||||||
CONFIG_ARCH=z16
|
CONFIG_ARCH=z16
|
||||||
CONFIG_ARCH_Z16=y
|
CONFIG_ARCH_Z16=y
|
||||||
@ -59,8 +61,9 @@ CONFIG_ARCH_CHIP_Z16F3211=n
|
|||||||
CONFIG_ARCH_CHIP_Z16F6411=n
|
CONFIG_ARCH_CHIP_Z16F6411=n
|
||||||
CONFIG_ARCH_BOARD=z16f2800100zcog
|
CONFIG_ARCH_BOARD=z16f2800100zcog
|
||||||
CONFIG_ARCH_BOARD_Z16F2800100ZCOG=y
|
CONFIG_ARCH_BOARD_Z16F2800100ZCOG=y
|
||||||
|
CONFIG_BOARD_LOOPSPERMSEC=1250
|
||||||
CONFIG_DRAM_SIZE=65536
|
CONFIG_DRAM_SIZE=65536
|
||||||
|
CONFIG_ARCH_LEDS=y
|
||||||
#
|
#
|
||||||
# Z16F specific device driver settings
|
# Z16F specific device driver settings
|
||||||
#
|
#
|
||||||
|
@ -47,6 +47,7 @@
|
|||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <arch/board/board.h>
|
||||||
#include "up_internal.h"
|
#include "up_internal.h"
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -84,38 +85,10 @@ void up_ledinit(void)
|
|||||||
|
|
||||||
void up_ledon(int led)
|
void up_ledon(int led)
|
||||||
{
|
{
|
||||||
ubyte paout = getreg8(Z16F_GPIOA_OUT) & 0xf8;
|
if ((unsigned)led <= 7)
|
||||||
switch (led)
|
|
||||||
{
|
{
|
||||||
case LED_STARTED:
|
putreg8(((getreg8(Z16F_GPIOA_OUT) & 0xf8) | led), Z16F_GPIOA_OUT);
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_HEAPALLOCATE:
|
|
||||||
paout |= 1;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_IRQSENABLED:
|
|
||||||
paout |= 2;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_IDLE:
|
|
||||||
paout |= 3;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_INIRQ:
|
|
||||||
paout |= 4;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_ASSERTION :
|
|
||||||
paout |= 5;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_PANIC:
|
|
||||||
default:
|
|
||||||
paout |= 6;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
putreg8(paout, Z16F_GPIOA_OUT);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -124,32 +97,9 @@ void up_ledon(int led)
|
|||||||
|
|
||||||
void up_ledoff(int led)
|
void up_ledoff(int led)
|
||||||
{
|
{
|
||||||
switch (led)
|
if (led >= 1)
|
||||||
{
|
{
|
||||||
case LED_STARTED:
|
up_ledon(led-1);
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_HEAPALLOCATE:
|
|
||||||
up_ledoff(LED_STARTED);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_IRQSENABLED:
|
|
||||||
up_ledoff(LED_IRQSENABLED);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_IDLE:
|
|
||||||
up_ledoff(LED_IRQSENABLED);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_INIRQ:
|
|
||||||
case LED_ASSERTION :
|
|
||||||
up_ledoff(LED_IDLE);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case LED_PANIC:
|
|
||||||
default:
|
|
||||||
up_ledoff(LED_ASSERTION);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_ARCH_LEDS */
|
#endif /* CONFIG_ARCH_LEDS */
|
||||||
|
Loading…
Reference in New Issue
Block a user