mod_regs_intc.h
来自「eCos操作系统源码」· C头文件 代码 · 共 162 行
H
162 行
//=============================================================================//// mod_regs_intc.h//// INTC (interrupt controller) Module register definitions////=============================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// eCos is free software; you can redistribute it and/or modify it under// the terms of the GNU General Public License as published by the Free// Software Foundation; either version 2 or (at your option) any later version.//// eCos is distributed in the hope that it will be useful, but WITHOUT ANY// WARRANTY; without even the implied warranty of MERCHANTABILITY or// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License// for more details.//// You should have received a copy of the GNU General Public License along// with eCos; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.//// As a special exception, if other files instantiate templates or use macros// or inline functions from this file, or you compile this file and link it// with other works to produce a work based on this file, this file does not// by itself cause the resulting work to be covered by the GNU General Public// License. However the source code for this file must still be made available// in accordance with section (3) of the GNU General Public License.//// This exception does not invalidate any other reasons why a work based on// this file might be covered by the GNU General Public License.//// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.// at http://sources.redhat.com/ecos/ecos-license/// -------------------------------------------//####ECOSGPLCOPYRIGHTEND####//=============================================================================//#####DESCRIPTIONBEGIN####//// Author(s): jskov// Contributors:jskov// Date: 2002-01-15// //####DESCRIPTIONEND####////=============================================================================// NOTE: This'll need restructuring as other variants are added. Type 1 should// be fewest common registers.//--------------------------------------------------------------------------// Interrupt registers, module type 1#define CYGARC_REG_ICR 0xfffffee0#define CYGARC_REG_IRQCSR 0xfffffee8#define CYGARC_REG_IPRA 0xfffffee2#define CYGARC_REG_IPRB 0xfffffe60#define CYGARC_REG_IPRC 0xfffffee6#define CYGARC_REG_IPRD 0xfffffe40#define CYGARC_REG_IPRE 0xfffffec0#define CYGARC_REG_VCRA 0xfffffe62#define CYGARC_REG_VCRB 0xfffffe64#define CYGARC_REG_VCRC 0xfffffe66#define CYGARC_REG_VCRD 0xfffffe68#define CYGARC_REG_VCRE 0xfffffe42#define CYGARC_REG_VCRF 0xfffffe44#define CYGARC_REG_VCRG 0xfffffe46#define CYGARC_REG_VCRH 0xfffffe48#define CYGARC_REG_VCRI 0xfffffe4a#define CYGARC_REG_VCRJ 0xfffffe4c#define CYGARC_REG_VCRK 0xfffffe4e#define CYGARC_REG_VCRL 0xfffffe50#define CYGARC_REG_VCRM 0xfffffe52#define CYGARC_REG_VCRN 0xfffffe54#define CYGARC_REG_VCRO 0xfffffe56#define CYGARC_REG_VCRP 0xfffffec2#define CYGARC_REG_VCRQ 0xfffffec4#define CYGARC_REG_VCRR 0xfffffec6#define CYGARC_REG_VCRS 0xfffffec8#define CYGARC_REG_VCRT 0xfffffeca#define CYGARC_REG_VCRU 0xfffffecc#define CYGARC_REG_VCRWDT 0xfffffee4#define CYGARC_REG_VCRDMA0 0xffffffa0 // 32 bit#define CYGARC_REG_VCRDMA1 0xffffffa8 // 32 bit#define CYGARC_REG_ICR_NMIL 0x8000#define CYGARC_REG_ICR_NMIE 0x0100#define CYGARC_REG_ICR_EXIMD 0x0002#define CYGARC_REG_ICR_VECMD 0x0001#define CYGARC_REG_IPRA_DMAC_MASK 0x0f00#define CYGARC_REG_IPRA_DMAC_PRI1 0x0100#define CYGARC_REG_IPRA_WDT_MASK 0x00f0#define CYGARC_REG_IPRA_WDT_PRI1 0x0010#define CYGARC_REG_IPRB_EDMAC_MASK 0xf000#define CYGARC_REG_IPRB_EDMAC_PRI1 0x1000#define CYGARC_REG_IPRB_FRT_MASK 0x0f00#define CYGARC_REG_IPRB_FRT_PRI1 0x0100#define CYGARC_REG_IPRC_IRQ3_MASK 0xf000#define CYGARC_REG_IPRC_IRQ3_PRI1 0x1000#define CYGARC_REG_IPRC_IRQ2_MASK 0x0f00#define CYGARC_REG_IPRC_IRQ2_PRI1 0x0100#define CYGARC_REG_IPRC_IRQ1_MASK 0x00f0#define CYGARC_REG_IPRC_IRQ1_PRI1 0x0010#define CYGARC_REG_IPRC_IRQ0_MASK 0x000f#define CYGARC_REG_IPRC_IRQ0_PRI1 0x0001#define CYGARC_REG_IPRD_TPU0_MASK 0xf000#define CYGARC_REG_IPRD_TPU0_PRI1 0x1000#define CYGARC_REG_IPRD_TPU1_MASK 0x0f00#define CYGARC_REG_IPRD_TPU1_PRI1 0x0100#define CYGARC_REG_IPRD_TPU2_MASK 0x00f0#define CYGARC_REG_IPRD_TPU2_PRI1 0x0010#define CYGARC_REG_IPRD_SCIF1_MASK 0x000f#define CYGARC_REG_IPRD_SCIF1_PRI1 0x0001#define CYGARC_REG_IPRE_SCIF2_MASK 0xf000#define CYGARC_REG_IPRE_SCIF2_PRI1 0x1000#define CYGARC_REG_IPRE_SIO0_MASK 0x0f00#define CYGARC_REG_IPRE_SIO0_PRI1 0x0100#define CYGARC_REG_IPRE_SIO1_MASK 0x00f0#define CYGARC_REG_IPRE_SIO1_PRI1 0x0010#define CYGARC_REG_IPRE_SIO2_MASK 0x000f#define CYGARC_REG_IPRE_SIO2_PRI1 0x0001// The (initial) IRQ mode is controlled by configuration.#ifdef CYGHWR_HAL_SH_IRQ_USE_IRQLVL# define CYGARC_REG_ICR_INIT (CYGARC_REG_ICR_EXIMD)#else# define CYGARC_REG_ICR_INIT 0x0000#endif#define CYGARC_REG_IRQCSR_IRQ_LOWLEVEL 0#define CYGARC_REG_IRQCSR_IRQ_RISING 1#define CYGARC_REG_IRQCSR_IRQ_FALLING 2#define CYGARC_REG_IRQCSR_IRQ_BOTHEDGES 3#define CYGARC_REG_IRQCSR_IRQ_mask 3#define CYGARC_REG_IRQCSR_IRQ3_mask 0xc000#define CYGARC_REG_IRQCSR_IRQ3_shift 14#define CYGARC_REG_IRQCSR_IRQ2_mask 0x3000#define CYGARC_REG_IRQCSR_IRQ2_shift 12#define CYGARC_REG_IRQCSR_IRQ1_mask 0x0c00#define CYGARC_REG_IRQCSR_IRQ1_shift 10#define CYGARC_REG_IRQCSR_IRQ0_mask 0x0300#define CYGARC_REG_IRQCSR_IRQ0_shift 8#define CYGARC_REG_IRQCSR_IRL3PS 0x0080#define CYGARC_REG_IRQCSR_IRL2PS 0x0040#define CYGARC_REG_IRQCSR_IRL1PS 0x0020#define CYGARC_REG_IRQCSR_IRL0PS 0x0010#define CYGARC_REG_IRQCSR_IRQ3F 0x0008#define CYGARC_REG_IRQCSR_IRQ2F 0x0004#define CYGARC_REG_IRQCSR_IRQ1F 0x0002#define CYGARC_REG_IRQCSR_IRQ0F 0x0001
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?