0

我正在尝试将我的 ATTiny 置于睡眠模式,然后将其唤醒。我使用此代码使其进入睡眠状态:

void go_to_sleep(){
is_sleeping = true;
RED_HIGH;
YELLOW_HIGH;
GREEN_HIGH;
sleep_enable();
sei();
sleep_cpu();
sleep_disable();

}

比我使用外部中断但没有任何反应。

ISR(INT0_vect)
{
    if(is_sleeping){
        awake();
    }
    if(BUTTON_LOW){ // przycisk wciśnięty?
        _delay_ms(80);
        if(BUTTON_LOW){ // nadal wciśnięty?
            do_thing();
        }
    }
}
void awake(){
    is_sleeping = false;
    RED_LOW;
    YELLOW_HIGH;
    GREEN_HIGH;
}

欢迎任何想法。

我添加 main 以表明中断工作正常,我已经在没有睡眠模式的情况下对其进行了测试:

int main(void)
{
MCUCR |= 1<<SE; // zezwolenie na sleep mode
GIMSK |= 1<<INT0; // int0 enable
MCUCR |= 0<<ISC00 | 1<<ISC01; //przerwanie zboczem opadającym
sei(); // zezwolenie na przerwania

//OUTPUTS
DDRB |= RED | YELLOW  | GREEN;
//INPUTS
DDRB &= ~BUTTON;
// Podciągnięcie przycisku do VCC
PORTB |= BUTTON;

set_sleep_mode(SLEEP_MODE_PWR_DOWN); // ustaw tryb sleep modu, ta linijka nie uruchamia go

//Stan początkowy
RED_LOW;
YELLOW_HIGH;
GREEN_HIGH;

timer0(TIMER_PRESCALER_1024,255);

while(1);
}
4

2 回答 2

0

我相信您交叉发布了从断电模式唤醒的问题。验证我对其他问题的回答是否适合您,即您无法使用 INT0 上的下降沿检测从掉电中唤醒,因为掉电时没有 I/O 时钟。

于 2017-11-28T07:07:58.747 回答
0

您必须在通用中断屏蔽寄存器中启用 INT0 中断...... 在此处输入图像描述

添加行...

GIMSK |= _BV( PCIE );

...在您进入睡眠状态并激活 INT0 引脚(默认为低电平)之前,应该将 MCU 从睡眠状态唤醒。

请注意,使用如图所示的代码,我不确定您是否能够判断 CPU 已唤醒。尝试在你睡觉前将一个引脚输出为高电平,然后在你醒来时让它变为低电平,这样你就会知道它发生了。

于 2017-11-13T17:44:53.890 回答