#define AMBIENT_ADC N_PWMLEDS
-#define LAST_ADC (sizeof(adc_mux)/sizeof(char))
-volatile static unsigned char current_adc = LAST_ADC;
+#define LAST_ADC (sizeof(adc_mux)/sizeof(adc_mux[0]))
+volatile static unsigned char current_adc;
+static unsigned char adc_ignore;
static void start_next_adc()
{
found:
// ADCSRB |= _BV(GSEL); // gain 8 or 32
ADMUX = adc_mux[current_adc]; // set up mux, start one-shot conversion
+ adc_ignore = 1; // ignore first reading after mux change
ADCSRA |= _BV(ADSC);
}
void init_adc()
{
+ current_adc = LAST_ADC;
+ adc_ignore = 1;
+
ADCSRA = _BV(ADEN) // enable
| _BV(ADPS1) | _BV(ADPS0) // CLK/8 = 125 kHz
// | _BV(ADPS2) // CLK/16 = 62.5 kHz
ISR(ADC_vect) { // IRQ handler
uint16_t adcval = ADCW;
+#if 0
+ log_byte(0xF3);
+ log_byte(current_adc);
+ log_word(adcval);
+#endif
+
+ if (adc_ignore) {
+ ADCSRA |= _BV(ADSC);
+ adc_ignore = 0;
+ return;
+ }
+
if (current_adc < N_PWMLEDS)
pwmled_adc(current_adc, adcval);
if (current_adc == AMBIENT_ADC)