Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gemesa/stm32-dc-dc
STM32 based DC-DC converter
https://github.com/gemesa/stm32-dc-dc
boost boost-converter buck buck-boost buck-boost-converter buck-converter c dc-dc dc-dc-converter hal hardware-abstraction-layer stm32 stm32cubeide stm32f3 stm32f334 stm32f334c8t6 stm32hal
Last synced: about 2 months ago
JSON representation
STM32 based DC-DC converter
- Host: GitHub
- URL: https://github.com/gemesa/stm32-dc-dc
- Owner: gemesa
- License: mit
- Created: 2022-12-19T17:13:30.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-01-06T09:56:34.000Z (12 months ago)
- Last Synced: 2024-07-02T09:19:33.488Z (6 months ago)
- Topics: boost, boost-converter, buck, buck-boost, buck-boost-converter, buck-converter, c, dc-dc, dc-dc-converter, hal, hardware-abstraction-layer, stm32, stm32cubeide, stm32f3, stm32f334, stm32f334c8t6, stm32hal
- Language: C
- Homepage: https://gemesa.dev/
- Size: 959 KB
- Stars: 14
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# stm32-dc-dc
This project contains the source code of an [STM32F334C8T6](https://www.st.com/en/evaluation-tools/32f3348discovery.html) based DC-DC converter. The converter can operate in buck, boost and buck-boost (mixed) mode using high resolution timers (HRTIM) and is controlled by a PI controller. The input and output voltages are measured by ADC where the ADC trigger event is synchronized with the duty cycle: the voltages are measured before or after the PWM rising or falling edge (depending on the converter mode and duty cycle), this way the measurement noise can be minimalized.
The code has been implemented using [STM32CubeIDE](https://www.st.com/en/development-tools/stm32cubeide.html). For more information see the detailed documentation under the pull requests.
## Deployment
### Prerequisites
The following tools are necessary for building:
- `make`
- `arm-none-eabi-gcc`### How to build
Invoke the following commands:
```bash
$ cd Debug
$ make all
```which will build the _stm32f334c8t6.elf_ binary file (use your preferred method to download it, the SWD interface is configured so it can be used with an [ST-LINK](https://www.st.com/en/development-tools/st-link-v2.html) hardware).
Note: the SW can be built from STM32CubeIDE also (after importing the _.project_ and _.cproject_ files).
## Quickstart
The DC-DC control is currently disabled in _main.c_:
```c
void vDcDcTask(void const * argument)
{
/* USER CODE BEGIN vDcDcTask */uint32_t ulThreadNotification;
vSetDutyCycleBuck(5000u);
vSetAdcTriggerPoint(2500u);HAL_HRTIM_WaveformOutputStart(&hhrtim1, HRTIM_OUTPUT_TA1 | HRTIM_OUTPUT_TA2 | HRTIM_OUTPUT_TB1 | HRTIM_OUTPUT_TB2);
HAL_HRTIM_WaveformCountStart_IT(&hhrtim1, HRTIM_TIMERID_TIMER_A | HRTIM_TIMERID_TIMER_B);HAL_ADCEx_Calibration_Start(&hadc1, ADC_SINGLE_ENDED);
HAL_ADCEx_InjectedStart_IT(&hadc1);for (;;)
{
ulThreadNotification = ulTaskNotifyTake(pdTRUE, portMAX_DELAY);if (ulThreadNotification)
{
ulVinRaw = HAL_ADCEx_InjectedGetValue(&hadc1, ADC_INJECTED_RANK_1);
ulVoutRaw = HAL_ADCEx_InjectedGetValue(&hadc1, ADC_INJECTED_RANK_2);ulVinPhys = ulVinRawToPhys(ulVinRaw);
ulVoutPhys = ulVoutRawToPhys(ulVoutRaw);// vDcDcControl(ulVoutPhys, 5000u);
}
}/* USER CODE END vDcDcTask */
}
```Uncomment the control function and set the chosen output voltage in mV (for example 5000u = 5.00V), then the PI controller will set the desired value. The DC-DC task is activated every 5ms in the current configuration, so it can be made faster if necessary. The PI controller can be tuned further also by changing the P and I constants.
## Results
The following measurements illustrate the different working modes:
![buck](Measurements/buck.png)
![mixed](Measurements/mixed.png)
![boost](Measurements/boost.png)
## License
This project contains files from multiple sources with different licenses. The relevant license is added to every source file.