8通道模数转换AD7091驱动代码SPI接口ADC,verilog

2023-10-29 00:52

本文主要是介绍8通道模数转换AD7091驱动代码SPI接口ADC,verilog,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

名称:8通道模数转换AD7091驱动代码

软件:QuartusII

语言:Verilog

代码功能:

    使用verilog代码设计AD7091R-8驱动代码

    控制接口为SPI接口,实现8通道模数转换,输出8通道数字信号。

FPGA代码Verilog/VHDL代码资源下载网:www.hdlcode.com

代码下载:

8通道模数转换AD7091驱动代码(代码在文末付费下载)软件:QuartusII语言:Verilog代码功能: 使用verilog代码设计AD7091R-8驱动代码 控制接口为SPI接口,实现8通道模数转换,输出8通道数字信号。FPGA代码Verilog/VHDL代码资源下载网:www.hdlcode.com部分代码展示//AD7091驱动module AD7091(input名称:8通道模数转换AD7091驱动代码(代码在文末付费下载)软件:QuartusII语言:Verilog代码功能: 使用verilog代码设计AD7091R-8驱动代码 控制接口为SPI接口,实现8通道模数转换,输出8通道数字信号。FPGA代码Verilog/VHDL代码资源下载网:www.hdlcode.com芯片手册:AD7091R-2_7091R-4_7091R-8.pdf部分icon-default.png?t=N7T8http://www.hdlcode.com/index.php?m=home&c=View&a=index&aid=218

ad7091-8.jpg

ad7091-8-2.jpg

芯片手册:

AD7091R-2_7091R-4_7091R-8.pdf

部分代码展示

//AD7091驱动
module AD7091(
input clk_50M,
//input reset_p,
output AD_CS,
output AD_convst,
output AD_sclk,//输出sclk
input AD_sdo,//输入sdo
output AD_sdi,//输出sdi
input AD_alert,
output reg [11:0] AD_0,
output reg [11:0] AD_1,
output reg [11:0] AD_2,
output reg [11:0] AD_3,
output reg [11:0] AD_4,
output reg [11:0] AD_5,
output reg [11:0] AD_6,
output reg [11:0] AD_7
);
wire reset_p;
assign reset_p=0;
reg [2:0] state=3'd0;
parameter s_idle=3'd0;
parameter s_initial=3'd1;
parameter s_write=3'd2;
parameter s_wait=3'd3;
reg [7:0] convst_cnt=8'd0;
reg [7:0] write_cnt=8'd0;
reg [7:0] wait_cnt=8'd0;
//状态机
always@(posedge clk_50M or posedge reset_p)
if(reset_p)
state<=s_idle;
else
case(state)
s_idle:
state<=s_initial;
s_initial://初始化状态
if(convst_cnt>=8'd66)
state<=s_wait;
else
state<=s_initial;
s_wait:
if(wait_cnt>=8'd200)
state<=s_write;
else
state<=s_wait;
s_write://读写状态
state<=s_write;
default:;
endcase
always@(posedge clk_50M or posedge reset_p)
if(reset_p)
wait_cnt<=8'd0;
else
if(state==s_wait)
wait_cnt<=wait_cnt+8'd1;
else
wait_cnt<=8'd0;
//初始化计数400输出66个convst周期
reg [9:0] clk_convst_cnt=10'd0;
always@(posedge clk_50M or posedge reset_p)
if(reset_p)
clk_convst_cnt<=10'd0;
else
if(state==s_initial)
if(clk_convst_cnt>=10'd400)
clk_convst_cnt<=10'd0;
else
clk_convst_cnt<=clk_convst_cnt+10'd1;
else
clk_convst_cnt<=10'd0;
reg convst_initial=1;
always@(posedge clk_50M or posedge reset_p)
if(reset_p)
convst_initial<=1;
else
if(state==s_initial)
if(clk_convst_cnt>10'd200)//400us低电平,400us高电平
convst_initial<=0;
else
convst_initial<=1;
else
convst_initial<=1;
always@(posedge clk_50M or posedge reset_p)
if(reset_p)
convst_cnt<=8'd0;
else
if(state==s_initial)
if(clk_convst_cnt>=10'd400)
convst_cnt<=convst_cnt+8'd1;//convst计数
else
convst_cnt<=convst_cnt;
else
convst_cnt<=8'd0;

这篇关于8通道模数转换AD7091驱动代码SPI接口ADC,verilog的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/297159

相关文章

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

Java 后端接口入参 - 联合前端VUE 使用AES完成入参出参加密解密

加密效果: 解密后的数据就是正常数据: 后端:使用的是spring-cloud框架,在gateway模块进行操作 <dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.0-jre</version></dependency> 编写一个AES加密