// TI File $Revision: /main/4 $
// Checkin $Date: March 28, 2007 15:51:10 $
//###########################################################################
//
// FILE: Example_281xSWPrioritizedDefaultIsr.c
//
// TITLE: DSP281x Device Default Software Prioritized Interrupt Service Routines.
//
// This file is based on the standard Example_28xSWPrioritizedDefaultIsr.c
//
// The ISR routines have been modified slightly to provide a trace
// mechanism used for this example
//
//###########################################################################
// $TI Release: $
// $Release Date: $
//###########################################################################
#include "DSP281x_Device.h" // DSP281x Headerfile Include File
#include "DSP281x_Examples.h" // DSP281x Examples Include File
// Defined in the Example_28xSWPrioritizedInterrupts.c file
// for this example only
extern Uint16 ISRTrace[50];
extern Uint16 ISRTraceIndex;
// Used for ISR delays
Uint16 i;
//---------------------------------------------------------------------------
// XINT13, TINT2, NMI, XINT1, XINT2 Default ISRs:
//---------------------------------------------------------------------------
//
// Connected to INT13 of CPU (use MINT13 mask):
#if (INT13PL != 0)
interrupt void INT13_ISR(void) // XINT13
{
IER |= MINT13; // Set "global" priority
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
#endif
// Connected to INT14 of CPU (use MINT14 mask):
#if (INT14PL != 0)
interrupt void INT14_ISR(void) // CPU-Timer2
{
IER |= MINT14; // Set "global" priority
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
#endif
// Connected to NMI of CPU (non-maskable):
interrupt void NMI_ISR(void) // Non-maskable interrupt
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
// Connected to PIEIER1_4 (use MINT1 and MG14 masks):
#if (G14PL != 0)
interrupt void XINT1_ISR(void)
{
// Set interrupt priority:
volatile Uint16 TempPIEIER = PieCtrlRegs.PIEIER1.all;
IER |= MINT1; // Set "global" priority
IER &= MINT1;
PieCtrlRegs.PIEIER1.all &= MG14; // Set "group" priority
PieCtrlRegs.PIEACK.all = 0xFFFF; // Enable PIE interrupts
EINT;
// Insert ISR Code here.......
asm(" NOP");
// Restore registers saved:
DINT;
PieCtrlRegs.PIEIER1.all = TempPIEIER;
// Add ISR to Trace
ISRTrace[ISRTraceIndex] = 0x0014;
ISRTraceIndex++;
}
#endif
// Connected to PIEIER1_5 (use MINT1 and MG15 masks):
#if (G15PL != 0)
interrupt void XINT2_ISR(void)
{
// Set interrupt priority:
volatile Uint16 TempPIEIER = PieCtrlRegs.PIEIER1.all;
IER |= MINT1; // Set "global" priority
IER &= MINT1;
PieCtrlRegs.PIEIER1.all &= MG15; // Set "group" priority
PieCtrlRegs.PIEACK.all = 0xFFFF; // Enable PIE interrupts
EINT;
// Insert ISR Code here.......
for(i = 1; i <= 10; i++) {}
// Restore registers saved:
DINT;
PieCtrlRegs.PIEIER1.all = TempPIEIER;
// Add ISR to Trace
ISRTrace[ISRTraceIndex] = 0x0015;
ISRTraceIndex++;
}
#endif
//---------------------------------------------------------------------------
// DATALOG, RTOSINT, EMUINT Default ISRs:
//---------------------------------------------------------------------------
//
// Connected to INT15 of CPU (use MINT15 mask):
#if (INT15PL != 0)
interrupt void DATALOG_ISR(void) // Datalogging interrupt
{
IER |= MINT15; // Set "global" priority
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
#endif
// Connected to INT16 of CPU (use MINT16 mask):
#if (INT16PL != 0)
interrupt void RTOSINT_ISR(void) // RTOS interrupt
{
IER |= MINT16; // Set "global" priority
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
#endif
// Connected to EMUINT of CPU (non-maskable):
interrupt void EMUINT_ISR(void) // Emulation interrupt
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
//---------------------------------------------------------------------------
// ILLEGAL Instruction Trap ISR:
//
interrupt void ILLEGAL_ISR(void) // Illegal operation TRAP
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
//---------------------------------------------------------------------------
// USER Traps Default ISRs:
//
interrupt void USER1_ISR(void) // User Defined trap 1
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER2_ISR(void) // User Defined trap 2
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER3_ISR(void) // User Defined trap 3
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER4_ISR(void) // User Defined trap 4
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER5_ISR(void) // User Defined trap 5
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER6_ISR(void) // User Defined trap 6
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER7_ISR(void) // User Defined trap 7
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER8_ISR(void) // User Defined trap 8
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER9_ISR(void) // User Defined trap 9
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER10_ISR(void) // User Defined trap 10
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER11_ISR(void) // User Defined trap 11
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
interrupt void USER12_ISR(void) // User Defined trap 12
{
EINT;
// Insert ISR Code here.......
// Next line for debug only (remove after inserting ISR Code):
ESTOP0;
}
//---------------------------------------------------------------------------
// ADC Default ISR:
//
// Connected to PIEIER1_6 (use MINT1 and MG16 masks):
#if (G16PL != 0)
interrupt void ADCINT_ISR(void) // ADC
{
// Set interrupt priority:
volatile Uint16 TempPIEIER = PieCtrlRegs.PIEIER1.all;
IER |= M_INT1;
IER &= MINT1; // Set "global" priority
PieCtrlRegs.PIEIER1.all &= MG16; // Set "group" priority
PieCtrlRegs.PIEACK.all = 0xFFFF; // Enable PIE interrupts
EINT;
// Insert ISR Code here.......
for(i = 1; i <= 10; i++) {}
// Restore registers saved:
DINT;
PieCtrlRegs.PIEIER1.all = TempPIEIER;
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
DSP281x_examples.rar (69个子文件)
www.pudn.com.txt 218B
DSP281x_examples
mcbsp_loopback_interrupts
Example_281xMcBSP_FFDLB_int.pjt 2KB
Example_281xMcBSP_FFDLB_int.gel 1KB
Example_281xMcBSP_FFDLB_int.c 7KB
mcbsp_spi_loopback
Example_281xMcBSP_SPI_FFDLB.gel 586B
Example_281xMcBSP_SPI_FFDLB.c 10KB
Example_281xMcBSP_SPI_FFDLB.pjt 2KB
adc_soc
Example_281xAdcSoc.pjt 2KB
Example_281xAdcSoc.gel 1KB
Example_281xAdcSoc.c 5KB
flash
Example_281xFlash.c 14KB
Example_281xFlash.gel 1KB
Example_281xFlash.pjt 2KB
ecan_back2back
Example_281xECanBack2Back.c 10KB
Example_281xECanBack2Back.pjt 2KB
Example_281xECanBack2Back.gel 1KB
spi_loopback_interrupts
Example_281xSpi_FFDLB_int.pjt 2KB
Example_281xSpi_FFDLB_int.c 6KB
Example_281xSpi_FFDLB_int.gel 1KB
sci_echoback
SCI_96.ht 23KB
Example_281xSci_Echoback.c 6KB
Example_281xSci_Echoback.gel 1019B
Example_281xSci_Echoback.pjt 2KB
cpu_timer
Example_281xCpuTimer.gel 1KB
Example_281xCpuTimer.c 4KB
Example_281xCpuTimer.pjt 2KB
sci_loopback
Example_281xSci_FFDLB.c 6KB
Example_281xSci_FFDLB.pjt 2KB
Example_281xSci_FFDLB.gel 1KB
ev_timer_period
Example_281xEvTimerPeriod.pjt 2KB
Example_281xEvTimerPeriod.gel 1KB
Example_281xEvTimerPeriod.c 10KB
mcbsp_loopback
Example_281xMcBSP_FFDLB.pjt 2KB
Example_281xMcBSP_FFDLB.c 8KB
Example_281xMcBSP_FFDLB.gel 1KB
sw_prioritized_interrupts
Example_281xSWPrioritizedDefaultIsr.c 37KB
Example_281xSWPrioritizedInterrupts.pjt 2KB
Example_281xSWPrioritizedInterrupts.c 18KB
Example_281xSWPrioritizedInterrupts.gel 1KB
sci_autobaud
Example_281xSci_Autobaud.gel 1KB
Example_281xSci_Autobaud.pjt 2KB
Example_281xSci_Autobaud.c 11KB
watchdog
Example_281xWatchdog.pjt 2KB
Example_281xWatchdog.c 5KB
Example_281xWatchdog.gel 996B
gpio_toggle
Example_281xGpioToggle.gel 940B
Example_281xGpioToggle.c 8KB
Example_281xGpioToggle.pjt 2KB
adc_seqmode_test
Example_281xAdcSeqModeTest.pjt 2KB
Example_281xAdcSeqModeTest.c 4KB
Example_281xAdcSeqModeTest.gel 987B
gpio_loopback
Example_281xGpioLoopback.c 17KB
Example_281xGpioLoopback.pjt 2KB
Example_281xGpioLoopback.gel 984B
ev_pwm
Example_281xEvPwm.gel 923B
Example_281xEvPwm.pjt 2KB
Example_281xEvPwm.c 6KB
spi_loopback
Example_281xSpi_FFDLB.pjt 2KB
Example_281xSpi_FFDLB.c 5KB
Example_281xSpi_FFDLB.gel 1000B
adc_seq_ovd_test
Example_281xAdcSeq_ovdTest.gel 987B
Example_281xAdcSeq_ovdTest.c 9KB
Example_281xAdcSeq_ovdTest.pjt 2KB
sci_loopback_interrupts
Example_281xSci_FFDLB_int.gel 1KB
Example_281xSci_FFDLB_int.pjt 2KB
Example_281xSci_FFDLB_int.c 9KB
run_from_xintf
Example_281xCodeRunFromXintf.pjt 2KB
Example_281xRunFromXintf.gel 3KB
Example_281xCodeRunFromXintf.c 8KB
共 69 条
- 1
资源评论
林当时
- 粉丝: 97
- 资源: 1万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 基于Python的在线学习与推荐系统设计与实现(论文+源码)-kaic
- 蓝桥杯2024年第十五届省赛真题-前缀总分
- com.qihoo.appstore_300101305-1.apk
- tensorflow-gpu-2.7.1-cp37-cp37m-manylinux2010-x86-64.whl
- tensorflow-2.7.2-cp37-cp37m-manylinux2010-x86-64.whl
- tensorflow-2.7.1-cp39-cp39-manylinux2010-x86-64.whl
- 蓝桥杯2024年第十五届省赛真题-传送阵
- com.qihoo.appstore_300101305.apk
- linux之线程同步一.doc
- keil5配色方案10种
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功