aboutsummaryrefslogtreecommitdiffstats
path: root/firmware/source/periph/adc.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'firmware/source/periph/adc.hpp')
-rw-r--r--firmware/source/periph/adc.hpp31
1 files changed, 30 insertions, 1 deletions
diff --git a/firmware/source/periph/adc.hpp b/firmware/source/periph/adc.hpp
index 5f7fa08..ae2e881 100644
--- a/firmware/source/periph/adc.hpp
+++ b/firmware/source/periph/adc.hpp
@@ -2,7 +2,7 @@
* @file adc.hpp
* @brief Manages signal reading through the ADC.
*
- * Copyright (C) 2021 Clyne Sullivan
+ * Copyright (C) 2023 Clyne Sullivan
*
* Distributed under the GNU GPL v3 or later. You should have received a copy of
* the GNU General Public License along with this program.
@@ -22,18 +22,47 @@ class ADC
public:
using Operation = void (*)(adcsample_t *buffer, size_t count);
+ /**
+ * Initializes analog input pins and the microcontoller's ADC peripheral.
+ */
static void begin();
+ /**
+ * Begins continuous ADC sampling triggered by SClock at the set sampling
+ * rate.
+ * @param buffer Pointer to buffer for sample data.
+ * @param count Number of samples that the buffer can hold.
+ * @param operation Handler function to operate on filled half-buffers.
+ */
static void start(adcsample_t *buffer, size_t count, Operation operation);
+
+ /**
+ * Stops the continuous ADC sampling.
+ */
static void stop();
+ /**
+ * Runs a single conversion on the "alt" inputs (parameter knobs).
+ * @param id The ID of the desired "alt" input (zero or one).
+ * @return The sampled value for the given input.
+ */
static adcsample_t readAlt(unsigned int id);
+ /**
+ * Sets the desired sampling rate for the ADC to operate at.
+ */
static void setRate(SClock::Rate rate);
+
+ /**
+ * Used to override the handler function for the currently running
+ * conversion.
+ */
static void setOperation(Operation operation);
private:
+ // ADC driver for signal input.
static ADCDriver *m_driver;
+ // ADC driver for "alt" inputs.
static ADCDriver *m_driver2;
static const ADCConfig m_config;