mirror of
https://github.com/infiniteCable2/panda.git
synced 2026-02-18 09:13:52 +08:00
* refactor panda side * fix misra? * use common ADC driver in jungle * fix misra fr now * fix oversampling * default channel macro * one more * this makes more sense --------- Co-authored-by: Comma Device <device@comma.ai>
32 lines
945 B
C
32 lines
945 B
C
#include "lladc_declarations.h"
|
|
|
|
void register_set(volatile uint32_t *addr, uint32_t val, uint32_t mask);
|
|
|
|
void adc_init(ADC_TypeDef *adc) {
|
|
register_set(&(ADC->CCR), ADC_CCR_TSVREFE | ADC_CCR_VBATE, 0xC30000U);
|
|
register_set(&(adc->CR2), ADC_CR2_ADON, 0xFF7F0F03U);
|
|
}
|
|
|
|
static uint16_t adc_get_raw(const adc_signal_t *signal) {
|
|
// sample time
|
|
if (signal->channel < 10U) {
|
|
signal->adc->SMPR2 = ((uint32_t) signal->sample_time << (signal->channel * 3U));
|
|
} else {
|
|
signal->adc->SMPR1 = ((uint32_t) signal->sample_time << ((signal->channel - 10U) * 3U));
|
|
}
|
|
|
|
// select channel
|
|
signal->adc->JSQR = ((uint32_t) signal->channel << 15U);
|
|
|
|
// start conversion
|
|
signal->adc->SR &= ~(ADC_SR_JEOC);
|
|
signal->adc->CR2 |= ADC_CR2_JSWSTART;
|
|
while (!(signal->adc->SR & ADC_SR_JEOC));
|
|
|
|
return signal->adc->JDR1;
|
|
}
|
|
|
|
uint16_t adc_get_mV(const adc_signal_t *signal) {
|
|
return (adc_get_raw(signal) * current_board->avdd_mV) / 4095U;
|
|
}
|