这是本文档旧的修订版!
银杏科技有限公司旗下技术文档发布平台 | |||
技术支持电话 | 0379-69926675-801 | ||
技术支持邮件 | Gingko@vip.163.com | ||
技术论坛 | http://www.eeschool.org | ||
版本 | 日期 | 作者 | 修改内容 |
---|---|---|---|
V1.0 | 2020-03-09 | gingko | 初次建立 |
1.在主界面选择File–>New Project 或者直接点击ACCEE TO MCU SELECTOR
2.出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置
在搜索栏的下面,提供的各 种查找方式,可以选择芯片内核,型号,等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32H750IBKx。
3.配置RCC,使用外部时钟源
4.时基源选择SysTick
5.将PA10,PB7,PB8设置为GPIO_Output
6.引脚模式配置
7.配置DAC1
8.时钟源设置,选择外部高速时钟源,配置为最大主频
9.工程文件的设置, 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 IDE我们使用的是 MDK V5.27
10.点击Code Generator,进行进一步配置
DAC简介
图中VDDA和VSSA为DAC模块模拟部分的供电,而VREF+则是DAC模块的参考电压。DAC_OUT1/2就是DAC的两个输出通道了(对应PA4或者PA5引脚)。 从图中可以看出,DAC输出是受DORx(x=1/2,下同)寄存器直接控制的,但是我们不能直接往DORx寄存器写入数据,而是通过DHRx间接的传给DORx寄存器,实现对DAC输出的控制。前面我们提到,STM32H750的DAC支持8/12位模式,8位模式的时候是固定的右对齐的,而12位模式又可以设置左对齐/右对齐。单DAC通道x,总共有3种情况: ①8位数据右对齐:用户将数据写入DAC_DHR8Rx[7:0]位(实际存入DHRx[11:4]位)。 ②12位数据左对齐:用户将数据写入DAC_DHR12Lx[15:4]位(实际存入DHRx[11:0]位)。 ③12位数据右对齐:用户将数据写入DAC_DHR12Rx[11:0]位(实际存入DHRx[11:0]位)。 如果没有选中硬件触发(寄存器DAC_CR1的TENx位置‘0’),存入寄存器DAC_DHRx的数据会在1个APB1时钟周期后自动传至寄存器DAC_DORx。如果选中硬件触发(寄存器DAC_CR1的TENx位置’1’),数据传输在触发发生以后3个APB1时钟周期后完成。一旦数据从DAC_DHRx寄存器装入DAC_DORx寄存器,在经过时间tSETTLING之后,输出即有效,这段时间的长短依电源电压和模拟输出负载的不同会有所变化。
关闭触发 (TEN = 0) 时的转换时序图:
DAC输入/输出引脚:
DAC内部输入/输出信号:
DAC输出电压公式 经过线性转换后,数字输入会转换为 0 到 VREF+ 之间的输出电压。 各 DAC 通道引脚的模拟输出电压通过以下公式确定: DAC_output= V_REF × DOR/4096 DAC部分寄存器介绍 我们介绍一下要实现 DAC 的通道 1 输出,需要用到的一些寄存器。首先是 DAC控制寄存器 DAC_CR,该寄存器的各位描述如图所示:
DAC_CR 的低 16 位用于控制通道 1,而高 16 位用于控制通道 2,我们这里仅列出比较本章需要设置的一些位: EN1 位:用于 DAC 通道 1 的使能,我们需要用到 DAC 通道 1 的输出,该位必须设置为 1。 TEN1 位:用于 DAC 通道 1 的触发使能,我们设置该位为 0,不使用硬件触发。 写入 DHR1的值会在 1 个 APB1 周期后传送到 DOR1,然后输出到 PA4 口上。 TSEL[3:0]位,用于选择 DAC 通道 1 的触发方式,本章设置为 0,使用软件触发。 WAVE[1:0]位,用于控制 DAC 通道 1 的噪声/波形输出功能,默认设置为 0,不使能噪声/波形输出。 DMAEN1 位,用于控制 DAC 通道 1 的 DMA 使能,本章不使能,设置该位为 0 即可。CEN1 位,用于控制 DAC 通道 1 的输出缓冲校准使能,本章不使用校准功能(默认有一个出场校准值,我们使用默认的校准值即可),设置该位为 0 即可。 然后,我们介绍 DAC 模式控制寄存器( DAC1_MCR),该寄存器各位描述如图所示:
位 2:0 MODE1[2:0]: DAC 通道 1 模式 (DAC Channel 1 mode) 仅当 DAC 已禁止且不处于校准模式时( DACx_CR 寄存器中的位 EN1 = 0 且 位 CEN1 = 0),才可写入这些位。如果 EN1=1 或 CEN1 =1,则会忽略写操作。 这些位可由软件置 1 和清零,用于选择 DAC 通道 1 模式。 – DAC 通道 1 处于正常模式
本实验中iCore4T的参考电压为2.5V,我们使用DAC1通道一输出1.2V的电压。原理图如下:
int main(void) { HAL_Init(); SystemClock_Config(); i2c.initialize(); axp152.initialize(); axp152.set_dcdc1(3500);//[ARM & FPGA BK1/2/6 &OTHER] axp152.set_dcdc2(1200);//[FPGA INT & PLL D] axp152.set_aldo1(2500);//[FPGA PLL A] axp152.set_dcdc4(3300);//[POWER_OUTPUT] axp152.set_dcdc3(3300);//[FPGA BK4][Adjustable] axp152.set_aldo2(3300);//[FPGA BK3][Adjustable] axp152.set_dldo1(3300);//[FPGA BK7][Adjustable] axp152.set_dldo2(3300);//[FPGA BK5][Adjustable] MX_GPIO_Init(); MX_DAC1_Init(); LED_ON; dac1.set_voltage(1.2);//输出1.2V电压 while (1) { } }
void set_voltage(double voltage) { unsigned short int temp; temp = voltage * 4095 / 2.5; //求出所设电压对应DOR寄存器的值 HAL_DAC_SetValue(&hdac1, DAC_CHANNEL_1, DAC_ALIGN_12B_R, temp);//12 位右对齐数据格式设置 DAC 值 HAL_DAC_Start(&hdac1, DAC_CHANNEL_1); //输出要求电压 }
HAL_DAC_SetValue(DAC_HandleTypeDef *hdac, uint32_t Channel, uint32_t Alignment, uint32_t Data) //hdac:指向DAC_HandleTypeDef结构的指针 //Channel:选定DAC通道 //Alignment:数据对方方式 //Data:放入寄存器中的值
void MX_DAC1_Init(void) { DAC_ChannelConfTypeDef sConfig = {0}; hdac1.Instance = DAC1; if (HAL_DAC_Init(&hdac1) != HAL_OK) { Error_Handler(); } sConfig.DAC_SampleAndHold = DAC_SAMPLEANDHOLD_DISABLE;//关闭 sConfig.DAC_Trigger = DAC_TRIGGER_NONE;//关闭DAC触发 sConfig.DAC_OutputBuffer = DAC_OUTPUTBUFFER_ENABLE;//使用输出缓存,提高驱动力 sConfig.DAC_ConnectOnChipPeripheral = DAC_CHIPCONNECT_DISABLE;//关闭DAC芯片连接 sConfig.DAC_UserTrimming = DAC_TRIMMING_FACTORY;//缓冲器偏移校准采用出厂修整 if (HAL_DAC_ConfigChannel(&hdac1, &sConfig, DAC_CHANNEL_1) != HAL_OK) { Error_Handler(); } }