0

我正在编写 AVR MCU。

它有一个可以读取模拟引脚的 POT。似乎不断调用中断,并且必须在 LCD_display 方法期间调用它,因为它弄乱了我的 LCD。

有没有办法在块运行之前停止中断?

int main(void)
{
/*Turn on ADC Interrupt */
ADCSRA |= (1 << ADIE); 

/*Turn On GLobal Interrupts*/
sei();


/* Intalise LCD */
lcd_init(LCD_DISP_ON);                /* initialize display, cursor off */
lcd_clrscr();
lcd_puts("READY");

DDRB &= ~(1 << PINB5);   //set input direction
ADC_Init(128, 0); //initalize ADC


while (1)                         
{

if (!bit_is_clear(PINB, 5))
{
_delay_ms(500);

if (!pressed)
{           
lcd_gotoxy(0,0);
lcd_clrscr();
lcd_puts("test");  //Doesnt work unless I dont comment out the last line of interrupt
pressed = 1;
}

}

/* INTERRUPTS */

//ADC INTERRUPT
ISR(ADC_vect) 
{ 

char adcResult[4];

uint8_t theLowADC = ADCL;
uint16_t theTenBitResults = ADCH<<8 | theLowADC;
itoa(theTenBitResults, adcResult, 10);
ADCSRA |= (1 << ADSC);  //next conversion  *if i comment out this line it works*


} 
4

3 回答 3

3

如果中断处理程序对您的代码表现不佳,原因可能是您在中断处理程序上花费了太多时间。您应该只在中断处理程序中做关键工作,并在应用程序代码中推迟不太关键的工作;使用volatile处理程序和应用程序代码之间共享的标志来让应用程序代码知道它是否有工作要做。在您的示例中,您应该推迟itoa应用程序代码中的调用。

于 2012-02-13T10:10:27.033 回答
0

使用 cli(); 禁用中断和 sei(); 完成显示例程后再次启用它们。你用的是哪个MCU?您应该适当地使用计时器而不是 500 毫秒的延迟。

于 2012-02-15T10:17:40.107 回答
0

我相信,我来晚了,但我仍然遇到同样的问题,我使用以下方法解决了它,

使用两个标志启用中断 1.A 全局中断标志 2.A 模块相关中断标志(在您的情况下为 ADC)

您可以控制与模块相关的标志,在您的情况下,ADCSRA 控制寄存器中有一个名为 ADIE-ADC 中断启用标志的标志,您可以使用它来控制中断。

例如,在 main 函数中,您可以启用该标志,而在 ISR 中禁用该标志。

main()
{
    //enable global flag and ADC flag
    while(1)
    {
        //your logic
        // enable ADC flag
    }
}

ISR()
{
   //disable the ADC flag
}

我希望这可以解决您遇到的问题。

于 2018-03-08T12:41:22.380 回答