Matlab的SimuLink对FS32K144编程--SPI通讯控制12bitDAC输出

​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​

1、硬件介绍,DAC芯片:AD5328BRUZ

DAC_SPI_SCK----PTD0(SPI1)

DAC_SPI_DIN----PTE0(SPI1)单片机输出

DAC_SPI_CS-----PTB17(SPI1_CS3)

2、分析芯片数据手册时钟图,芯片为SPI的从机

可知

片选信号"SYNC":低电平有效

数据"DIN":第一位数据为最高位

时钟"SCLK":下降沿采集信号

SPI通讯的四种模式

时钟极性通常写为CKP或CPOL

时钟相位通常写为CKE或CPHA

  • Mode0:CKP=0,CKE =0:当空闲态时,SCK处于低电平,数据采样是在第1个边沿,也就是SCK由低电平到高电平的跳变,所以数据采样是在上升沿(准备数据),(发送数据)数据发送是在下降沿。
  • Mode1:CKP=0,CKE=1:当空闲态时,SCK处于低电平,数据发送是在第2个边沿,也就是SCK由低电平到高电平的跳变,所以数据采样是在下降沿,数据发送是在上升沿。
  • Mode2:CKP=1,CKE=0:当空闲态时,SCK处于高电平,数据采集是在第1个边沿,也就是SCK由高电平到低电平的跳变,所以数据采集是在下降沿,数据发送是在上升沿。
  • Mode3:CKP=1,CKE=1:当空闲态时,SCK处于高电平,数据发送是在第2个边沿,也就是SCK由高电平到低电平的跳变,所以数据采集是在上升沿,数据发送是在下降沿。

该芯片的时钟符合模式1:SPHA = 1,SPOL = 0;

3、查数据手册找数据位

该芯片一次通讯16bit

4、故该芯片SPI通讯格式如下

该芯片的时钟符合模式1:SPHA = 1,SPOL = 0;

一次通讯16bit

对接引脚

DAC_SPI_SCK----PTD0(SPI1)

DAC_SPI_DIN----PTE0(SPI1)单片机输出

DAC_SPI_CS-----PTB17(SPI1_CS3)

且Bit order = MSB first

5、配置SPI通讯模式,S32K144为主机,使用波特率为100000bps

6、SPI引脚分配

7、配置SPI通道

8、数据发送--查数据手册分析

最高位为0时数据输出模拟量信号,最高位为1时配置芯片寄存器,该芯片可以直接输出信号,故:最高位常为0。

A0,A1,A2可配置通道,AD5328有8个通道可独立控制

把A0,A1,A2进行二进制排列A0最低位A2最高位,即数值0-7各代表1个通道A-H

D的数值是D0~D11,D0为最低位D11为最高位,进行二进制组合排列,D的值在:0-4095之间

N是12,本电路中Vref为5V电压。

9、SPI输出,通道1,片选为通道3,片选低电平有效,没有反馈信息

10、由于一次输出只有8位,所以16bit由2个8位组成,第一个8位为低8为,第二个8位为高8位,输出信息无效,用display显示一下

11、数据处理如下

相关推荐
森利威尔电子-2 分钟前
森利威尔SL3150H替代MRDC88-1 10V-150V宽压输入、5V固定输出 SOP7封装
单片机·嵌入式硬件·物联网
xiebingsuccess11 分钟前
LC谐振电路分析
嵌入式硬件
恒森宇电子有限公司14 分钟前
南麟LN1173 低压差LDO线性稳压器芯片
单片机·嵌入式硬件
charlie11451419118 分钟前
嵌入式现代C++工程实践——第10篇:HAL_GPIO_Init —— 把引脚配置告诉芯片的仪式
开发语言·c++·stm32·单片机·c
LS_learner1 小时前
ESP-IDF 多版本共存安装方案
嵌入式硬件
AzusaFighting2 小时前
STM32F103R HAL CAN 通信实战 with Copilot
stm32·单片机·嵌入式硬件
拾-光2 小时前
【无标题】
单片机
himobrinehacken2 小时前
Windows调试技巧:从Hello到I Love C++
stm32·单片机·嵌入式硬件
2301_805962933 小时前
ESP32模组烧录失败排查解决方法
单片机·嵌入式硬件
时空自由民.5 小时前
RGB Image Sensor 和 RGB LCD Scren 的HSYNC和VSYNC的区别,以及ESP32 RGB LCD外设工作原理介绍
单片机