当前位置:首页 > 单片机 > 单片机
[导读]  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 inte

  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.



/**

Function: TMR1_Open


Summary: Initialization of Timer


Description: TMR1 on; 0.08 microsecond every tick, overflow and interrupt per ms


Remarks: Pre-scale 1:8; PB 100MHz; PR1 0x30D3

*/

// 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

/**

Function: TMR1_Write


Summary: Write TMR1


Description: Write a value to TMR1


Remarks: the value is range of 0~65535

*/

// 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

#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++ >= 300)

{

COUNTER = 0;

LED_ONOFF();

}

TMR1_Write(0);

IFS0CLR = 0x10; // Clear flag

}


void main(void)

{

LED_OPEN();

LED_IOCTL();

TMR1_Open();

TMR1_Write(0);

SelectMultiVector();

EnableINT();

COUNTER = 0;

while (1)

{

; // do nothing

}

}


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


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

Microchip公司的PIC32MZ EF系列是高达250MHz的集成浮点单元(FPU),具有广泛的外设和包括局域网(CAN)的极好的连接选择,工作电压2.1V到 3.6V,DSP增强核具有四

关键字: Microchip pic32mz 处理器

使用的是STM32F407的板子,程序参考的是STM32F4xx固件库的DAC_SignalsGeneration文件夹下的程序。官方例程分别使用了DAC的禁止生成波(DAC_WaveGeneration_None)的E...

关键字: dac dma STM32 timer 输出正弦波

  In my last post I implement "Key Debounce" with port polling, port polling is not very efficient....

关键字: pic32mz tutorial change notification

  In my older blog "PIC32MZ tutorial -- Key Debounce", I shows how to acheive key debounce with port...

关键字: interrupt pic32mz tutorial external

8051 系列 MCU 的基本结构包括:32 个 I/O 口(4 组8 bit 端口);两个16 位定时计数器;全双工串行通信;6 个中断源(2 个外部中断、2 个定时/计数器中断、1 个串口输入/输出中断),两级中断优...

关键字: interrupt using 中断优先级 c51中断

所有的中断(外部中断,定时器中断……)运行的结果都是一样的:流水灯逐个点亮,当中断响应的时候,流水灯全部熄灭,当中断结束的时候,流水灯继续刚才的流动。proteus原理图:1.外部中断:代码:#include#incl...

关键字: interrupt 单片机中断

经过千辛万苦,今天终于完工PIC32MZ EC Starter Kit的ethernet bootloader项目。我将整个项目, 命名为PhnBootloader。它分为两个部分。第一个部分是PC 端的host程序Ph...

关键字: bootloader ethernet pic32mz udp协议

  At this moment, I accomplish the interface of UART communication for PIC32MZ EC Starter Kit. This interface...

关键字: communication pic32mz tutorial uart

  Core Timer is a very popular feature of PIC32 since it isa piece of the MIPS M4K core itself and is common t...

关键字: core pic32mz timer tutorial

8051 系列 MCU 的基本结构包括:32 个 I/O 口(4 组8 bit 端口);两个16 位定时计数器;全双工串行通信;6 个中断源(2 个外部中断、2 个定时/计数器中断、1 个串口输入/输出中断),两级中断优...

关键字: c51中断 interrupt using
关闭
关闭