Я пытаюсь перевести свой 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);
}
sei()
разве это не код для отключения прерываний? в каком случае внешние прерывания будут замаскированы? - person Jean-François Fabre   schedule 13.11.2017sei
иcli
. Таким образом, на Atmelsei
означает разрешение прерываний, а на ядрах Motorola это означает блокировку всех прерываний. Они инвертировали значение битаI
в CCR. - person Lundin   schedule 13.11.2017