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、数据处理如下

相关推荐
Vizio<18 小时前
STM32HAL库开发笔记-串口通信(UART)
笔记·stm32·嵌入式硬件
小幽余生不加糖18 小时前
步进电机、有刷直流电机以及无刷直流电机对比
笔记·单片机·嵌入式硬件·学习·能源
加成BUFF18 小时前
树莓派5-TB6612电机驱动模块完整实战教程
嵌入式硬件·pwm·树莓派5·tb6612·pwm波控制电机
DuanPenghao18 小时前
RISCV实战:实现基于Verilator模拟蜂鸟E203的加法器和卷积神经网络仿真
人工智能·嵌入式硬件·神经网络·cnn·risc-v
x9766619 小时前
使用 HMAC-SHA256算法对MCU UID进行加密
单片机·嵌入式硬件·算法
小叶子来了啊19 小时前
4Arduino 第一个程序
单片机·嵌入式硬件
方案开发PCBA抄板芯片解密19 小时前
什么是FIB,芯片解密为什么需要做FIB
单片机·嵌入式硬件
双古19 小时前
单片机调试,Ozone的使用
单片机·嵌入式硬件
飞凌嵌入式19 小时前
AIoT出海背景下,嵌入式主控的国际认证之路与价值思考
大数据·人工智能·嵌入式硬件·区块链·嵌入式
进阶的猪20 小时前
stm32 GPIO输出-使用固件库点亮LED灯 Q&A
c语言·笔记·stm32·单片机