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

相关推荐
赵谨言38 分钟前
基于单片机的防盗报警器设计与实现
经验分享·单片机·毕业设计
aloneboyooo42 分钟前
STM32H7时钟树
stm32·单片机·嵌入式硬件
技术流浪者42 分钟前
PCB设计(十九)PCB设计中NPN/PNP选型策略
单片机·嵌入式硬件·硬件工程·pcb工艺
长流小哥2 小时前
STM32实战指南:SG90舵机控制原理与代码详解
stm32·单片机·嵌入式硬件·keil5
xduryan5 小时前
16.1 - VDMA视频转发实验之TPG
嵌入式硬件
逼子格9 小时前
硬件工程师笔记——二极管Multisim电路仿真实验汇总
笔记·嵌入式硬件·硬件工程师·multisim·硬件工程师学习·电子器件·电路图
「QT(C++)开发工程师」9 小时前
STM32 | FreeRTOS 递归信号量
python·stm32·嵌入式硬件
芯眼9 小时前
ALIENTEK精英STM32F103开发板 实验0测试程序详解
开发语言·c++·stm32·单片机·嵌入式硬件·社交电子
百里东风10 小时前
STM32IIC协议基础及Cube配置
stm32·单片机·嵌入式硬件
2301_8003997211 小时前
stm32 DMA
stm32·单片机·嵌入式硬件