adc.c 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. //adc.c
  2. #include "adc.h"
  3. #include <avr/io.h>
  4. uint8_t adc_state;
  5. uint8_t adc_count;
  6. uint16_t adc_values[ADC_CHAN_CNT];
  7. uint16_t adc_sim_mask;
  8. #ifdef ADC_CALLBACK
  9. extern void ADC_CALLBACK(void);
  10. #endif //ADC_CALLBACK
  11. void adc_init(void)
  12. {
  13. printf(("adc_init\n"));
  14. adc_sim_mask = 0x00;
  15. ADCSRA |= (1 << ADPS2) | (1 << ADPS1) | (1 << ADPS0);
  16. ADMUX |= (1 << REFS0);
  17. ADCSRA |= (1 << ADEN);
  18. // ADCSRA |= (1 << ADIF) | (1 << ADSC);
  19. DIDR0 = (ADC_CHAN_MSK & 0xff);
  20. DIDR2 = (ADC_CHAN_MSK >> 8);
  21. adc_reset();
  22. }
  23. void adc_reset(void)
  24. {
  25. adc_state = 0;
  26. adc_count = 0;
  27. uint8_t i; for (i = 0; i < ADC_CHAN_CNT; i++)
  28. if ((adc_sim_mask & (1 << i)) == 0)
  29. adc_values[i] = 0;
  30. }
  31. void adc_setmux(uint8_t ch)
  32. {
  33. ch &= 0x0f;
  34. if (ch & 0x08) ADCSRB |= (1 << MUX5);
  35. else ADCSRB &= ~(1 << MUX5);
  36. ADMUX = (ADMUX & ~(0x07)) | (ch & 0x07);
  37. }
  38. uint8_t adc_chan(uint8_t index)
  39. {
  40. uint8_t chan = 0;
  41. uint16_t mask = 1;
  42. while (mask)
  43. {
  44. if ((mask & ADC_CHAN_MSK) && (index-- == 0)) break;
  45. mask <<= 1;
  46. chan++;
  47. }
  48. return chan;
  49. }
  50. void adc_cycle(void)
  51. {
  52. if (adc_state & 0x80)
  53. {
  54. uint8_t index = adc_state & 0x0f;
  55. if ((adc_sim_mask & (1 << index)) == 0)
  56. adc_values[index] += ADC;
  57. if (index++ >= ADC_CHAN_CNT)
  58. {
  59. index = 0;
  60. adc_count++;
  61. if (adc_count >= ADC_OVRSAMPL)
  62. {
  63. #ifdef ADC_CALLBACK
  64. ADC_CALLBACK();
  65. #endif //ADC_CALLBACK
  66. adc_reset();
  67. }
  68. }
  69. adc_setmux(adc_chan(index));
  70. adc_state = index;
  71. }
  72. else
  73. {
  74. ADCSRA |= (1 << ADSC); //start conversion
  75. adc_state |= 0x80;
  76. }
  77. }