An interrupt is an internal or external event that requires quick attention from the controller. The PIC32MZ architecture provides a rich interrupt system that can manage up to 190 sources of interrupts. Each interrupt source can have a unique piece of code, called the Interrupt Service Routine (ISR) directly associated via a pointer, also called a "vector", to provide the required response action.

  At the moment, I use Timer1 interrupt as a example to show how to enable interrupt and how to write interrupt service routine for PIC32MZ. The implementation has three parts. The first is the Timer1 interfaces. The second is interrupts interfaces. And the third is the Timer1 interrupt service routine.

  The Timer1 interfaces include TMR1_Open() and TMR1_Write(). In the TMR1_Open(), will enable Timer1 and Timer1 interrupt. configure Timer1 to overflow and interrupt per millisecond. set Timer1 interrupt priority level and subpriority level. Below code show me how to do that.

/**
<p><b>Function: TMR1_Open</b></p> <p><b>Summary: Initialization of Timer </b></p> <p><b>Description: TMR1 on; 0.08 microsecond every tick, overflow and interrupt per ms </b></p> <p><b>Remarks: Pre-scale 1:8; PB 100MHz; PR1 0x30D3</b></p>
*/
// TODO Insert function definitions (right here) to leverage live documentation
void TMR1_Open(void)
{
T1CON = 0x8010;
PR1 = 0x30D3;
IPC1SET = 0x5;
IEC0SET = 0x10;
IFS0CLR = 0x10;
}
// Comment a function definition and leverage automatic documentation
/**
<p><b>Function: TMR1_Write</b></p> <p><b>Summary: Write TMR1</b></p> <p><b>Description: Write a value to TMR1</b></p> <p><b>Remarks: the value is range of 0~65535</b></p>
*/
// TODO Insert function definitions (right here) to leverage live documentation
void TMR1_Write(unsigned int value)
{
TMR1 = value & 0xFFFF;
}

  The interrupts interfaces include EnableINT(), DisableINT() and SelectMultiVector(). When we want to use any interrupt source, call EnableINT() to enable interrupt module first. PIC32 have two interrupt vector modes, the singlevector mode and multivector mode. SelectMultiVector() will help to set interrputs for multivector mode. I do that like below.

/**
@Function
EnableINT @Summary
Enable interrupts @Remarks
This function need to be called first before using any interrupt source
*/
void EnableINT(void)
{
asm volatile("ei");
} /**
@Function
DisableINT @Summary
Disable interrupts @Remarks */
void DisableINT(void)
{
asm volatile("di");
} /**
@Function
SelectMultiVector @Summary
Set system to use multivector mode for interrupts @Remarks */
void SelectMultiVector(void)
{
unsigned long MVEC_MASK = 0x1000;
INTCONSET = MVEC_MASK;
}

  At the end, I show the main function and the Timer1 interrupt service routine. There are styles of interrupt service routine, the interrupt attribute style, like

__attribute__((interrupt([IPLn[SRS|SOFT|AUTO]]))),

and the interrupt pragma style, like

# pragma interrupt function-name IPLn[AUTO|SOFT|SRS] [vector
       [@]vector-number [, vector-number-list]]
       # pragma interrupt function-name single [vector [@] 0

  It strongly recommend the first style. So there they are.

#include <xc.h>
#include "TMR.h"
#include "Interrupt.h"
#include "ConfigurationBits.h" //#define LED_IOCTL() TRISHbits.TRISH0 = 0
//#define LED_SETON() LATHbits.LATH0 = 1
//#define LED_SETOFF() LATHbits.LATH0 = 0
//#define LED_OPEN() ANSELHbits.ANSH0 = 0 //#define LED_IOCTL() TRISH &= 0xFFFFFFFE
//#define LED_SETON() LATH |= 0x00000001
//#define LED_SETOFF() LATH &= 0xFFFFFFFE
//#define LED_OPEN() ANSELH &= 0xFFFFFFFE #define LED_IOCTL() TRISHCLR = (1<<0)
#define LED_SETON() LATHSET = (1<<0)
#define LED_SETOFF() LATHCLR = (1<<0)
#define LED_ONOFF() LATHINV = (1<<0)
#define LED_OPEN() ANSELH &= 0xFFFFFFFE volatile unsigned int COUNTER; void __attribute__((vector(_TIMER_1_VECTOR), interrupt(ipl1AUTO), nomips16)) TMR1_ISR(void)
{
if (COUNTER++ >= )
{
COUNTER = ;
LED_ONOFF();
}
TMR1_Write();
IFS0CLR = 0x10; // Clear flag
} void main(void)
{
LED_OPEN();
LED_IOCTL();
TMR1_Open();
TMR1_Write();
SelectMultiVector();
EnableINT();
COUNTER = ;
while ()
{
; // do nothing
}
}

  This application run well on PIC32MZ EC starter kit. I see the LED blink perfectly as expectation.

最新文章

  1. c#接口容易被忽视的问题
  2. redis 配置 linux
  3. 弄清const与指针、引用之间的关系
  4. [Slimdx]顶点和索引缓冲,绘制了2个分离的三角形
  5. Android 使用动态加载框架DL进行插件化开发
  6. Android:密码显示隐藏
  7. MVC3缓存:使用页面缓存
  8. [HDU 1695] GCD
  9. 监控CPU和内存的使用
  10. 交叉编译环境以及开发板上-/bin/sh: ./hello: not found(使用arm-linux-gcc -static -o 来进行静态编译)
  11. 一颗 45nm CPU的制造过程
  12. DefaultHttpClient is deprecated 【Api 弃用]】
  13. 一颗简单的hibernate栗子
  14. 201521123048 《Java程序设计》第9周学习总结
  15. Neo4j使用
  16. bzoj 4260: Codechef REBXOR (01 Trie)
  17. CF数据结构练习(二)
  18. rn最新版测试
  19. 我们为什么要在Android中使用RxJava
  20. Docker Nginx 配置多个子域名

热门文章

  1. 为什么在保护模式下IA-32处理器最高可访问4GB的内存
  2. php大力力 [046节] 兄弟连高洛峰 PHP教程 2015年[最新最新最新最新最新]
  3. PKU 1002解题总结
  4. Libgdx 开发指南(1) 应用框架
  5. UE4 异步资源加载
  6. PHP Html5上传大文件
  7. java中时间类型的问题
  8. 如何成为一名优秀的前端工程师 (share)
  9. LintCode Search For a Range (Binary Search)
  10. jquery中ajax方法返回的三种数据类型:text、json、xml;