1

在我看来,我的定时器中断不能正常工作。问题是中断函数内的计数器只增加一次。这是我的主要和计时器设置代码。

#include <m8c.h>
#include "PSoCAPI.h"
#include <stdio.h>
#include <stdlib.h>

char theStr[] = "PSoC LCD";
static char tmp[3];
static int counter = 0;

void main(void){

    LCD_Start();
    LCD_Position(0,5);
    LCD_PrString(theStr);
    M8C_EnableGInt;
    Timer8_EnableInt();
    Timer8_Start();
    while (1);
}

#pragma interrupt_handler myTimerInt
void myTimerInt(void){
    counter ++;
    LCD_Position(1,0);
    itoa(tmp, counter, 10);
    LCD_PrString(tmp);
}
4

2 回答 2

1

大多数中断服务例程需要重新武装调用它的中断(有时称为“确认中断”)。否则,ISR 只会被调用一次。通常,这是在 ISR 的关键部分完成后完成的。

对于 503418,我认为重新启用是通过读取计数器寄存器来完成的。请参阅此底部的代码。

于 2014-04-02T00:29:58.123 回答
0

您可能遇到的一个可能问题是 Timer8INT.asm 中的中断服务程序配置错误。使用指令时,#pragma interrupt_handler您需要确保使用正确的指令来调用 Timer8INT.asm ISR 中的 C 中断服务例程。

如果定义了该reti指令,则将在该函数的末尾添加一条指令,如果您使用lcallTimer8INT.asm 调用该 C 函数,则该指令是不正确的。ljmp在这种情况下,您实际上需要对该 C 函数的简单指令。

使用指令#pragma interrupt_handlerTimer8INT.asm 时应该有

_Timer8_ISR:

    ljmp _myTimerInt

    reti

没有指令#pragma interrupt_handlerTimer8INT.asm 应该有

_Timer8_ISR:

    PRESERVE_CPU_CONTEXT
    lcall _myTimerInt
    RESTORE_CPU_CONTEXT

    reti
于 2014-04-02T21:48:00.820 回答