NUC970-AIC

====================================================================
start.s

Vector_Table:
[0x00]  B Reset_GO;
[0x04]  LDR PC, Undefined_Addr;
[0x08]  LDR PC, SWI_Addr;
[0x0C]  LDR PC, Prefetch_Addr;
[0x10]  LDR PC, Abort_Addr;
[0x14]  DCD 0x0;
[0x18]  LDR PC, IRQ_Addr;
[0x1C]  LDR PC, FIQ_Addr;
[0x20]  Reset_Addr DCD Reset_GO
[0x24]  Undefined_Addr DCD Undefined_Handler
[0x28]  SWI_Addr DCD SWI_Handler
[0x2C]  Prefetch_Addr DCD Prefetch_Handler
[0x30]  Abort_Addr DCD Abort_Handler
[0x34]  DCD 0
[0x38]  IRQ_Addr DCD IRQ_Handler
[0x3C]  FIQ_Addr DCD FIQ_Handler

.......
====================================================================

因此安装中断处理程序可以这样写:

__irq void sysIrqHandle(void) {
    u32 volatile _mIPER, _mISNR;
    _mIPER = (inpw(REG_AIC_IPER) >> 2) & 0x3F;
    _mISNR = inpw(REG_AIC_ISNR);
    if (_mISNR != 0) {
        if (_mIPER == _mISNR) {
            (*sysIrqHandlerTable[_mISNR])();
        }
    }
    outpw(REG_AIC_EOSCR, 1);
}

__irq void sysFiqHandle(void) {
    u32 volatile _mIPER, _mISNR;
    _mIPER = (inpw(REG_AIC_IPER) >> 2) & 0x3F;
    _mISNR = inpw(REG_AIC_ISNR);
    if (_mISNR != 0) {
        if (_mIPER == _mISNR) {
            (*sysFiqHandlerTable[_mISNR])();
        }
    }
    outpw(REG_AIC_EOSCR, 1);
}

void sysInitializeAIC(void) {
    *(unsigned int volatile *)0x38 = (unsigned int)sysIrqHandler;
    *(unsigned int volatile *)0x3C = (unsigned int)sysFiqHandler;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
├── BSP │   └── nuc970bsp.tar.gz ├── Board\ Reference │   ├── NuDesign\ Eth2UART │   │   ├── BOM │   │   │   ├── NuDesign\ EtherD\ BOM.xls │   │   │   └── NuDesign\ EtherU\ BOM.xls │   │   ├── GBR │   │   │   ├── NK-NUC972UTE-D_0527_gbr.rar │   │   │   └── NK-NUC972UTE-U_0527_gbr.rar │   │   ├── PCB │   │   │   ├── NK-NUC972UTE-D_0527.asc │   │   │   └── NK-NUC972UTE-U_0527.asc │   │   ├── SCH │   │   │   ├── NUDESIGN\ ETHERU\ 20160504.DSN │   │   │   ├── NuDesign\ EtherD\ 20160504.DSN │   │   │   ├── NuDesign\ EtherD\ 20160504.pdf │   │   │   ├── Thumbs.db │   │   │   └── nudesign\ etheru\ 20160504.pdf │   │   └── User\ Manual │   │   └── NuDesign\ UART2ETH\ User_Manual_EN_Rev\ 1\ 00.pdf │   └── NuMaker\ Tomato │   ├── NuMaker_Tomato_Schematic_1.0.zip │   ├── NuvotonCDC_V1.00.001_Setup.zip │   ├── Tomato_SD_1.0.zip │   └── UM_NuMaker_Tomato_Rev1.00_EN.pdf ├── Documents │   ├── Chinese │   │   ├── NUC970\ Linux\ BSP\ Revision\ History\ CHT.pdf │   │   ├── NUC970\ Linux\ BSP\ User\ Manual\ CHT.pdf │   │   ├── NUC970\ Linux\ Quick\ Start\ Guide\ CHT.pdf │   │   ├── NUC970\ NuWriter\ User\ Manual\ CHT.pdf │   │   └── NUC970\ Programming\ Guide\ CHT.pdf │   └── English │   ├── NUC970\ Linux\ BSP\ Revision\ History\ EN.pdf │   ├── NUC970\ Linux\ BSP\ User\ Manual\ EN.pdf │   ├── NUC970\ Linux\ Quick\ Start\ Guide\ EN.pdf │   ├── NUC970\ NuWriter\ User\ Manual\ EN.pdf │   ├── NUC970\ Programming\ Guide\ EN.pdf │   └── NUC970\ U-Boot\ v2016_11\ User\ Manual\ EN.pdf └── Tools ├── NuWriter │   ├── bin │   │   ├── NuWriter.exe │   │   ├── NuWriter.exe.intermediate.manifest │   │   ├── key_cfg │   │   │   └── key.dat │   │   ├── path.ini │   │   ├── sys_cfg │   │   │   ├── NUC972DF51Y.ini │   │   │   ├── NUC972DF61Y.ini │   │   │   ├── NUC972DF61YC.ini │   │   │   ├── NUC972DF62Y.ini │   │   │   ├── NUC972DF71Y.ini │   │   │   ├── NUC972DF71YC.ini │   │   │   ├── NUC973DF62Y.ini │   │   │   ├── NUC975DK51Y.ini │   │   │   ├── NUC975DK61Y.ini │   │   │   ├── NUC975DK62Y.ini │   │   │   ├── NUC976DK41Y.ini │   │   │   ├── NUC976DK51Y.ini │   │   │   ├── NUC976DK61Y.ini │   │   │   ├── NUC976DK62Y.ini │   │   │   ├── NUC977DK41Y.ini │   │   │   ├── NUC977DK51Y.ini │   │   │   ├── NUC977DK61Y.ini │   │   │   ├── NUC977DK62Y.ini │   │   │   └── NUC978DK61Y.ini │   │   ├── xusb.bin │   │   ├── xusb128.bin │   │   ├── xusb16.bin │   │   └── xusb64.bin │   └── source │   └── README.txt └── WinUSB4NuVCOM_NUC970.exe
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值