analog.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /* Copyright 2015 Jack Humbert
  2. *
  3. * This program is free software: you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License as published by
  5. * the Free Software Foundation, either version 2 of the License, or
  6. * (at your option) any later version.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License
  14. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. #include "analog.h"
  17. static uint8_t aref = ADC_REF_POWER;
  18. void analogReference(uint8_t mode) {
  19. aref = mode & (_BV(REFS1) | _BV(REFS0));
  20. }
  21. int16_t analogReadPin(pin_t pin) {
  22. return adc_read(pinToMux(pin));
  23. }
  24. uint8_t pinToMux(pin_t pin) {
  25. switch (pin) {
  26. // clang-format off
  27. #if defined(__AVR_AT90USB646__) || defined(__AVR_AT90USB647__) || defined(__AVR_AT90USB1286__) || defined(__AVR_AT90USB1287__)
  28. case F0: return 0; // ADC0
  29. case F1: return _BV(MUX0); // ADC1
  30. case F2: return _BV(MUX1); // ADC2
  31. case F3: return _BV(MUX1) | _BV(MUX0); // ADC3
  32. case F4: return _BV(MUX2); // ADC4
  33. case F5: return _BV(MUX2) | _BV(MUX0); // ADC5
  34. case F6: return _BV(MUX2) | _BV(MUX1); // ADC6
  35. case F7: return _BV(MUX2) | _BV(MUX1) | _BV(MUX0); // ADC7
  36. default: return _BV(MUX4) | _BV(MUX3) | _BV(MUX2) | _BV(MUX1) | _BV(MUX0); // 0V
  37. #elif defined(__AVR_ATmega16U4__) || defined(__AVR_ATmega32U4__)
  38. case F0: return 0; // ADC0
  39. case F1: return _BV(MUX0); // ADC1
  40. case F4: return _BV(MUX2); // ADC4
  41. case F5: return _BV(MUX2) | _BV(MUX0); // ADC5
  42. case F6: return _BV(MUX2) | _BV(MUX1); // ADC6
  43. case F7: return _BV(MUX2) | _BV(MUX1) | _BV(MUX0); // ADC7
  44. case D4: return _BV(MUX5); // ADC8
  45. case D6: return _BV(MUX5) | _BV(MUX0); // ADC9
  46. case D7: return _BV(MUX5) | _BV(MUX1); // ADC10
  47. case B4: return _BV(MUX5) | _BV(MUX1) | _BV(MUX0); // ADC11
  48. case B5: return _BV(MUX5) | _BV(MUX2); // ADC12
  49. case B6: return _BV(MUX5) | _BV(MUX2) | _BV(MUX0); // ADC13
  50. default: return _BV(MUX4) | _BV(MUX3) | _BV(MUX2) | _BV(MUX1) | _BV(MUX0); // 0V
  51. #elif defined(__AVR_ATmega32A__)
  52. case A0: return 0; // ADC0
  53. case A1: return _BV(MUX0); // ADC1
  54. case A2: return _BV(MUX1); // ADC2
  55. case A3: return _BV(MUX1) | _BV(MUX0); // ADC3
  56. case A4: return _BV(MUX2); // ADC4
  57. case A5: return _BV(MUX2) | _BV(MUX0); // ADC5
  58. case A6: return _BV(MUX2) | _BV(MUX1); // ADC6
  59. case A7: return _BV(MUX2) | _BV(MUX1) | _BV(MUX0); // ADC7
  60. default: return _BV(MUX4) | _BV(MUX3) | _BV(MUX2) | _BV(MUX1) | _BV(MUX0); // 0V
  61. #elif defined(__AVR_ATmega328P__) || defined(__AVR_ATmega328__)
  62. case C0: return 0; // ADC0
  63. case C1: return _BV(MUX0); // ADC1
  64. case C2: return _BV(MUX1); // ADC2
  65. case C3: return _BV(MUX1) | _BV(MUX0); // ADC3
  66. case C4: return _BV(MUX2); // ADC4
  67. case C5: return _BV(MUX2) | _BV(MUX0); // ADC5
  68. // ADC7:6 not present in DIP package and not shared by GPIO pins
  69. default: return _BV(MUX3) | _BV(MUX2) | _BV(MUX1) | _BV(MUX0); // 0V
  70. #endif
  71. // clang-format on
  72. }
  73. return 0;
  74. }
  75. int16_t adc_read(uint8_t mux) {
  76. uint16_t low;
  77. // Enable ADC and configure prescaler
  78. ADCSRA = _BV(ADEN) | ADC_PRESCALER;
  79. #if defined(__AVR_ATmega16U4__) || defined(__AVR_ATmega32U4__)
  80. // High speed mode and ADC8-13
  81. ADCSRB = _BV(ADHSM) | (mux & _BV(MUX5));
  82. #elif defined(__AVR_AT90USB646__) || defined(__AVR_AT90USB647__) || defined(__AVR_AT90USB1286__) || defined(__AVR_AT90USB1287__)
  83. // High speed mode only
  84. ADCSRB = _BV(ADHSM);
  85. #endif
  86. // Configure mux input
  87. #if defined(MUX4)
  88. ADMUX = aref | (mux & (_BV(MUX4) | _BV(MUX3) | _BV(MUX2) | _BV(MUX1) | _BV(MUX0)));
  89. #else
  90. ADMUX = aref | (mux & (_BV(MUX3) | _BV(MUX2) | _BV(MUX1) | _BV(MUX0)));
  91. #endif
  92. // Start the conversion
  93. ADCSRA |= _BV(ADSC);
  94. // Wait for result
  95. while (ADCSRA & _BV(ADSC))
  96. ;
  97. // Must read LSB first
  98. low = ADCL;
  99. // Must read MSB only once!
  100. low |= (ADCH << 8);
  101. // turn off the ADC
  102. ADCSRA &= ~(1 << ADEN);
  103. return low;
  104. }