Я намагаюся отримати ATTiny85, щоб розрядити акумулятор. У мене він працює із кришталю 16,384 МГц із встановленим запобіжником розділення на 8. Vcc - 3,3 вольта. На рисунку 22-7 в аркуші даних сказано, що в режимі очікування ( set_sleep_mode(SLEEP_MODE_IDLE); sleep_mode();
) він повинен складати близько 300 мкА. Насправді я бачу, що він виглядає як 850 мкА. Я не можу зрозуміти, чому споживається енергія вдвічі. Я вимкнув все в PRR, за винятком timer0, який я налаштовував переривати кожні 25 мс. Таким чином, вона повинна провести переважну більшість свого часу в режимі очікування, що найкраще, що я можу зробити, враховуючи, що я все ще хочу, щоб таймери рахували.
Запобіжники 0x7f, 0xdf, 0xff.
Ось код, який використовується для цього тесту:
#include <Arduino.h>
#include <EEPROM.h>
#include <avr/sleep.h>
#include <avr/power.h>
#define P0 0
#define P1 1
#define P_UNUSED 2
ISR(TIMER0_COMPA_vect) {
// do nothing - just wake up
}
void setup() {
power_adc_disable();
power_usi_disable();
power_timer1_disable();
//PRR = _BV(PRADC) | _BV(PRTIM1) | _BV(PRUSI); // everything off but timer 0.
TCCR0A = _BV(WGM01); // mode 2 - CTC
TCCR0B = _BV(CS02) | _BV(CS00); // prescale = 1024
// xtal freq = 16.384 MHz.
// CPU freq = 16.384 MHz / 8 = 2.048 MHz
// count freq = 2.048 MHz / 1024 = 2000 Hz
OCR0A = 50; // 25 msec per irq
TIMSK = _BV(OCIE0A); // OCR0A interrupt only.
set_sleep_mode(SLEEP_MODE_IDLE);
pinMode(P_UNUSED, INPUT_PULLUP);
pinMode(P0, OUTPUT);
pinMode(P1, OUTPUT);
digitalWrite(P0, LOW);
digitalWrite(P1, LOW);
while(1) { sleep_mode(); }
}
void loop() {}