mirror of
https://github.com/jhbruhn/eurorack.git
synced 2025-03-14 18:55:48 +00:00
103 lines
3.5 KiB
C++
Executable file
103 lines
3.5 KiB
C++
Executable file
#include "stereo_mix/drivers/adc.h"
|
|
#include "peripherals.h"
|
|
#include <stm32f0xx_hal.h>
|
|
|
|
namespace stereo_mix {
|
|
|
|
Adc::Adc()
|
|
{
|
|
__HAL_RCC_DMA1_CLK_ENABLE();
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
__HAL_RCC_ADC1_CLK_ENABLE();
|
|
|
|
GPIO_InitTypeDef gpio_init;
|
|
|
|
gpio_init.Pin = GPIO_PIN_0 | GPIO_PIN_1;
|
|
gpio_init.Pin |= GPIO_PIN_2 | GPIO_PIN_3 | GPIO_PIN_4 | GPIO_PIN_5;
|
|
gpio_init.Pin |= GPIO_PIN_6 | GPIO_PIN_7;
|
|
gpio_init.Mode = GPIO_MODE_ANALOG;
|
|
HAL_GPIO_Init(GPIOA, &gpio_init);
|
|
|
|
gpio_init.Pin = GPIO_PIN_0;
|
|
gpio_init.Mode = GPIO_MODE_ANALOG;
|
|
HAL_GPIO_Init(GPIOB, &gpio_init);
|
|
|
|
// Configure the address lines for the MUX.
|
|
gpio_init.Pin = GPIO_PIN_12 | GPIO_PIN_13 | GPIO_PIN_14;
|
|
gpio_init.Mode = GPIO_MODE_OUTPUT_PP;
|
|
gpio_init.Speed = GPIO_SPEED_FREQ_LOW;
|
|
HAL_GPIO_Init(GPIOB, &gpio_init);
|
|
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_12 | GPIO_PIN_13 | GPIO_PIN_14, GPIO_PIN_RESET);
|
|
this->mux_index_ = 0;
|
|
|
|
hadc1.Init.Resolution = ADC_RESOLUTION_12B;
|
|
hadc1.Init.ContinuousConvMode = ENABLE;
|
|
hadc1.Init.DiscontinuousConvMode = DISABLE;
|
|
hadc1.Init.DataAlign = ADC_DATAALIGN_LEFT;
|
|
hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
|
|
hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
|
|
hadc1.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV2;
|
|
hadc1.Init.DMAContinuousRequests = DISABLE;
|
|
HAL_ADC_Init(&hadc1);
|
|
HAL_NVIC_SetPriority(ADC1_IRQn, 0, 0);
|
|
HAL_NVIC_EnableIRQ(ADC1_IRQn);
|
|
|
|
ADC_ChannelConfTypeDef sConfig;
|
|
sConfig.Channel = ADC_CHANNEL_0;
|
|
sConfig.Rank = ADC_RANK_CHANNEL_NUMBER;
|
|
sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_1;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_2;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_3;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_4;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_5;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_6;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_7;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
sConfig.Channel = ADC_CHANNEL_8;
|
|
HAL_ADC_ConfigChannel(&hadc1, &sConfig);
|
|
|
|
hdma1_channel1.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
hdma1_channel1.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
hdma1_channel1.Init.MemInc = DMA_MINC_ENABLE;
|
|
hdma1_channel1.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
|
|
hdma1_channel1.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
|
|
hdma1_channel1.Init.Mode = DMA_CIRCULAR;
|
|
hdma1_channel1.Init.Priority = DMA_PRIORITY_LOW;
|
|
HAL_DMA_Init(&hdma1_channel1);
|
|
__HAL_LINKDMA(&hadc1, DMA_Handle, hdma1_channel1);
|
|
|
|
HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
|
|
HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 0, 0);
|
|
|
|
HAL_ADC_Start_DMA(&hadc1, (uint32_t*)values_, ADC_CHANNEL_LAST);
|
|
}
|
|
|
|
Adc::~Adc()
|
|
{
|
|
HAL_ADC_DeInit(&hadc1);
|
|
}
|
|
|
|
void Adc::OnDMATransferComplete()
|
|
{
|
|
this->values_[ADC_GROUP_POT + this->mux_index_] = this->values_[ADC_CHANNEL_MUX];
|
|
|
|
this->mux_index_ = (this->mux_index_ + 1) % (ADC_CHANNEL_LAST - 1);
|
|
uint8_t address = this->mux_index_;
|
|
|
|
// Write the mux address.
|
|
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_12, static_cast<GPIO_PinState>(address & 1));
|
|
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_13, static_cast<GPIO_PinState>(address & 2));
|
|
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_14, static_cast<GPIO_PinState>(address & 4));
|
|
HAL_ADC_Start_DMA(&hadc1, (uint32_t*)values_, ADC_CHANNEL_LAST);
|
|
}
|
|
|
|
} // namespace rings
|