aboutsummaryrefslogtreecommitdiffstats
path: root/source/adc.hpp
blob: 456e697a948e9a7c09eecd9fc30f9e171d55ca9c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/**
 * @file adc.hpp
 * @brief Wrapper for ChibiOS's ADCDriver.
 *
 * Copyright (C) 2020 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.
 * If not, see <https://www.gnu.org/licenses/>.
 */

#ifndef STMDSP_ADC_HPP_
#define STMDSP_ADC_HPP_

#include "hal.h"

class ADCd;

struct ADCdConfig : public ADCConfig
{
    ADCd *adcdinst;
};

class ADCd
{
public:
    constexpr explicit ADCd(ADCDriver& adcd, GPTDriver& gptd) :
        m_adcd(&adcd), m_gptd(&gptd), m_adc_config{},
        m_adc_group_config(ADC_GROUP_CONFIG),
        m_is_adc_finished(false) {}

    void start();
    adcsample_t *getSamples(adcsample_t *buffer, size_t count);

private:
    static const GPTConfig m_gpt_config;

    ADCDriver *m_adcd;
    GPTDriver *m_gptd;
    ADCdConfig m_adc_config;
    ADCConversionGroup m_adc_group_config;

    bool m_is_adc_finished;

    void initPins();
    static void adcEndCallback(ADCDriver *adcd);

    constexpr static const ADCConversionGroup ADC_GROUP_CONFIG = {
        .circular = false,
        .num_channels = 1,
        .end_cb = ADCd::adcEndCallback,
        .error_cb = nullptr,
        .cfgr = ADC_CFGR_EXTEN_RISING |
                ADC_CFGR_EXTSEL_SRC(12),  /* TIM4_TRGO */
        .cfgr2 = 0,
        .tr1 = ADC_TR(0, 4095),
        .smpr = {
            ADC_SMPR1_SMP_AN5(ADC_SMPR_SMP_247P5), 0
        },
        .sqr = {
            ADC_SQR1_SQ1_N(ADC_CHANNEL_IN5),
            0, 0, 0
        }
    };
};

#endif // STMDSP_ADC_HPP_