93 lines
1.6 KiB
C
93 lines
1.6 KiB
C
//adc.c
|
|
|
|
#include "adc.h"
|
|
#include <avr/io.h>
|
|
#include <stdio.h>
|
|
|
|
uint8_t adc_state;
|
|
uint8_t adc_count;
|
|
uint16_t adc_values[ADC_CHAN_CNT];
|
|
uint16_t adc_sim_mask;
|
|
|
|
|
|
#ifdef ADC_CALLBACK
|
|
extern void ADC_CALLBACK(void);
|
|
#endif //ADC_CALLBACK
|
|
|
|
|
|
void adc_init(void)
|
|
{
|
|
printf(("adc_init\n"));
|
|
adc_sim_mask = 0x00;
|
|
ADCSRA |= (1 << ADPS2) | (1 << ADPS1) | (1 << ADPS0);
|
|
ADMUX |= (1 << REFS0);
|
|
ADCSRA |= (1 << ADEN);
|
|
// ADCSRA |= (1 << ADIF) | (1 << ADSC);
|
|
DIDR0 = (ADC_CHAN_MSK & 0xff);
|
|
DIDR2 = (ADC_CHAN_MSK >> 8);
|
|
adc_reset();
|
|
// adc_sim_mask = 0b0101;
|
|
// adc_sim_mask = 0b100101;
|
|
// adc_values[0] = 1023 * 16;
|
|
// adc_values[2] = 1023 * 16;
|
|
// adc_values[5] = 1002 * 16;
|
|
}
|
|
|
|
void adc_reset(void)
|
|
{
|
|
adc_state = 0;
|
|
adc_count = 0;
|
|
uint8_t i; for (i = 0; i < ADC_CHAN_CNT; i++)
|
|
if ((adc_sim_mask & (1 << i)) == 0)
|
|
adc_values[i] = 0;
|
|
}
|
|
|
|
void adc_setmux(uint8_t ch)
|
|
{
|
|
ch &= 0x0f;
|
|
if (ch & 0x08) ADCSRB |= (1 << MUX5);
|
|
else ADCSRB &= ~(1 << MUX5);
|
|
ADMUX = (ADMUX & ~(0x07)) | (ch & 0x07);
|
|
}
|
|
|
|
uint8_t adc_chan(uint8_t index)
|
|
{
|
|
uint8_t chan = 0;
|
|
uint16_t mask = 1;
|
|
while (mask)
|
|
{
|
|
if ((mask & ADC_CHAN_MSK) && (index-- == 0)) break;
|
|
mask <<= 1;
|
|
chan++;
|
|
}
|
|
return chan;
|
|
}
|
|
|
|
void adc_cycle(void)
|
|
{
|
|
if (adc_state & 0x80)
|
|
{
|
|
uint8_t index = adc_state & 0x0f;
|
|
if ((adc_sim_mask & (1 << index)) == 0)
|
|
adc_values[index] += ADC;
|
|
if (index++ >= ADC_CHAN_CNT)
|
|
{
|
|
index = 0;
|
|
adc_count++;
|
|
if (adc_count >= ADC_OVRSAMPL)
|
|
{
|
|
#ifdef ADC_CALLBACK
|
|
ADC_CALLBACK();
|
|
#endif //ADC_CALLBACK
|
|
adc_reset();
|
|
}
|
|
}
|
|
adc_setmux(adc_chan(index));
|
|
adc_state = index;
|
|
}
|
|
else
|
|
{
|
|
ADCSRA |= (1 << ADSC); //start conversion
|
|
adc_state |= 0x80;
|
|
}
|
|
}
|