/********************************** (C) COPYRIGHT ******************************* * File Name : ch32v30x_dac.c * Author : WCH * Version : V1.0.0 * Date : 2021/06/06 * Description : This file provides all the DAC firmware functions. * Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd. * SPDX-License-Identifier: Apache-2.0 ****************************************************************************************/ #include "ch32v30x_dac.h" #include "ch32v30x_rcc.h" /* CTLR register Mask */ #define CTLR_CLEAR_MASK ((uint32_t)0x00000FFE) /* DAC Dual Channels SWTR masks */ #define DUAL_SWTR_SET ((uint32_t)0x00000003) #define DUAL_SWTR_RESET ((uint32_t)0xFFFFFFFC) /* DHR registers offsets */ #define DHR12R1_OFFSET ((uint32_t)0x00000008) #define DHR12R2_OFFSET ((uint32_t)0x00000014) #define DHR12RD_OFFSET ((uint32_t)0x00000020) /* DOR register offset */ #define DOR_OFFSET ((uint32_t)0x0000002C) /********************************************************************* * @fn DAC_DeInit * * @brief Deinitializes the DAC peripheral registers to their default reset values. * * @return none */ void DAC_DeInit(void) { RCC_APB1PeriphResetCmd(RCC_APB1Periph_DAC, ENABLE); RCC_APB1PeriphResetCmd(RCC_APB1Periph_DAC, DISABLE); } /********************************************************************* * @fn DAC_Init * * @brief Initializes the DAC peripheral according to the specified parameters in * the DAC_InitStruct. * * @param DAC_Channel - the selected DAC channel. * DAC_Channel_1 - DAC Channel1 selected * DAC_Channel_2 - DAC Channel2 selected * DAC_InitStruct - pointer to a DAC_InitTypeDef structure. * * @return none */ void DAC_Init(uint32_t DAC_Channel, DAC_InitTypeDef *DAC_InitStruct) { uint32_t tmpreg1 = 0, tmpreg2 = 0; tmpreg1 = DAC->CTLR; tmpreg1 &= ~(CTLR_CLEAR_MASK << DAC_Channel); tmpreg2 = (DAC_InitStruct->DAC_Trigger | DAC_InitStruct->DAC_WaveGeneration | DAC_InitStruct->DAC_LFSRUnmask_TriangleAmplitude | DAC_InitStruct->DAC_OutputBuffer); tmpreg1 |= tmpreg2 << DAC_Channel; DAC->CTLR = tmpreg1; } /********************************************************************* * @fn DAC_StructInit * * @brief Fills each DAC_InitStruct member with its default value. * * @param DAC_InitStruct - pointer to a DAC_InitTypeDef structure which will be initialized. * * @return none */ void DAC_StructInit(DAC_InitTypeDef *DAC_InitStruct) { DAC_InitStruct->DAC_Trigger = DAC_Trigger_None; DAC_InitStruct->DAC_WaveGeneration = DAC_WaveGeneration_None; DAC_InitStruct->DAC_LFSRUnmask_TriangleAmplitude = DAC_LFSRUnmask_Bit0; DAC_InitStruct->DAC_OutputBuffer = DAC_OutputBuffer_Enable; } /********************************************************************* * @fn DAC_Cmd * * @brief Enables or disables the specified DAC channel. * * @param DAC_Channel - the selected DAC channel. * DAC_Channel_1 - DAC Channel1 selected * DAC_Channel_2 - DAC Channel2 selected * NewState - new state of the DAC channel(ENABLE or DISABLE). * * @return none */ void DAC_Cmd(uint32_t DAC_Channel, FunctionalState NewState) { if(NewState != DISABLE) { DAC->CTLR |= (DAC_EN1 << DAC_Channel); } else { DAC->CTLR &= ~(DAC_EN1 << DAC_Channel); } } /********************************************************************* * @fn DAC_DMACmd * * @brief Enables or disables the specified DAC channel DMA request. * * @param DAC_Channel - the selected DAC channel. * DAC_Channel_1 - DAC Channel1 selected * DAC_Channel_2 - DAC Channel2 selected * NewState - new state of the DAC channel(ENABLE or DISABLE). * * @return none */ void DAC_DMACmd(uint32_t DAC_Channel, FunctionalState NewState) { if(NewState != DISABLE) { DAC->CTLR |= (DAC_DMAEN1 << DAC_Channel); } else { DAC->CTLR &= ~(DAC_DMAEN1 << DAC_Channel); } } /********************************************************************* * @fn DAC_SoftwareTriggerCmd * * @brief Enables or disables the selected DAC channel software trigger. * * @param DAC_Channel - the selected DAC channel. * DAC_Channel_1 - DAC Channel1 selected * DAC_Channel_2 - DAC Channel2 selected * NewState - new state of the DAC channel(ENABLE or DISABLE). * * @return none */ void DAC_SoftwareTriggerCmd(uint32_t DAC_Channel, FunctionalState NewState) { if(NewState != DISABLE) { DAC->SWTR |= (uint32_t)DAC_SWTRIG1 << (DAC_Channel >> 4); } else { DAC->SWTR &= ~((uint32_t)DAC_SWTRIG1 << (DAC_Channel >> 4)); } } /********************************************************************* * @fn DAC_DualSoftwareTriggerCmd * * @brief Enables or disables the two DAC channel software trigger. * * @param NewState - new state of the DAC channel(ENABLE or DISABLE). * * @return none */ void DAC_DualSoftwareTriggerCmd(FunctionalState NewState) { if(NewState != DISABLE) { DAC->SWTR |= DUAL_SWTR_SET; } else { DAC->SWTR &= DUAL_SWTR_RESET; } } /********************************************************************* * @fn DAC_WaveGenerationCmd * * @brief Enables or disables the selected DAC channel wave generation. * * @param DAC_Channel - the selected DAC channel. * DAC_Channel_1 - DAC Channel1 selected * DAC_Channel_2 - DAC Channel2 selected * DAC_Wave - Specifies the wave type to enable or disable. * DAC_Wave_Noise - noise wave generation * DAC_Wave_Triangle - triangle wave generation * NewState - new state of the DAC channel(ENABLE or DISABLE). * * @return none */ void DAC_WaveGenerationCmd(uint32_t DAC_Channel, uint32_t DAC_Wave, FunctionalState NewState) { if(NewState != DISABLE) { DAC->CTLR |= DAC_Wave << DAC_Channel; } else { DAC->CTLR &= ~(DAC_Wave << DAC_Channel); } } /********************************************************************* * @fn DAC_SetChannel1Data * * @brief Set the specified data holding register value for DAC channel1. * * @param DAC_Align - Specifies the data alignment for DAC channel1. * DAC_Align_8b_R - 8bit right data alignment selected * DAC_Align_12b_L - 12bit left data alignment selected * DAC_Align_12b_R - 12bit right data alignment selected * Data - Data to be loaded in the selected data holding register. * * @return none */ void DAC_SetChannel1Data(uint32_t DAC_Align, uint16_t Data) { __IO uint32_t tmp = 0; tmp = (uint32_t)DAC_BASE; tmp += DHR12R1_OFFSET + DAC_Align; *(__IO uint32_t *)tmp = Data; } /********************************************************************* * @fn DAC_SetChannel2Data * * @brief Set the specified data holding register value for DAC channel2. * * @param DAC_Align - Specifies the data alignment for DAC channel1. * DAC_Align_8b_R - 8bit right data alignment selected * DAC_Align_12b_L - 12bit left data alignment selected * DAC_Align_12b_R - 12bit right data alignment selected * Data - Data to be loaded in the selected data holding register. * * @return none */ void DAC_SetChannel2Data(uint32_t DAC_Align, uint16_t Data) { __IO uint32_t tmp = 0; tmp = (uint32_t)DAC_BASE; tmp += DHR12R2_OFFSET + DAC_Align; *(__IO uint32_t *)tmp = Data; } /********************************************************************* * @fn DAC_SetDualChannelData * * @brief Set the specified data holding register value for two DAC. * * @param DAC_Align - Specifies the data alignment for DAC channel1. * DAC_Align_8b_R - 8bit right data alignment selected * DAC_Align_12b_L - 12bit left data alignment selected * DAC_Align_12b_R - 12bit right data alignment selected * Data - Data to be loaded in the selected data holding register. * Data1 - Data for DAC Channel1. * Data2 - Data for DAC Channel2 * * @return none */ void DAC_SetDualChannelData(uint32_t DAC_Align, uint16_t Data2, uint16_t Data1) { uint32_t data = 0, tmp = 0; if(DAC_Align == DAC_Align_8b_R) { data = ((uint32_t)Data2 << 8) | Data1; } else { data = ((uint32_t)Data2 << 16) | Data1; } tmp = (uint32_t)DAC_BASE; tmp += DHR12RD_OFFSET + DAC_Align; *(__IO uint32_t *)tmp = data; } /********************************************************************* * @fn DAC_GetDataOutputValue * * @brief Returns the last data output value of the selected DAC channel. * * @param DAC_Channel - the selected DAC channel. * DAC_Channel_1 - DAC Channel1 selected * DAC_Channel_2 - DAC Channel2 selected * * @return none */ uint16_t DAC_GetDataOutputValue(uint32_t DAC_Channel) { __IO uint32_t tmp = 0; tmp = (uint32_t)DAC_BASE; tmp += DOR_OFFSET + ((uint32_t)DAC_Channel >> 2); return (uint16_t)(*(__IO uint32_t *)tmp); }