AC620FPGA学习笔记——DAC输出显示

DAC输出显示

工程地址:https://github.com/HaHaHaHaHaGe/Planof2019_half/tree/master/Course_Project/FPGA/class04_TLV5618A
基于ADC的项目增添DAC输出

硬件结构

开发板:AC620
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

整体框架

在这里插入图片描述

tlv5618a_device

在这里插入图片描述

tlv5618a_interface

在这里插入图片描述

代码部分

代码过多更多代码在github

顶层代码

module voltmeter(
	key1,
	key2,
	rst,
	clk,
	lock595,
	out595,
	clk595,
	adc_sclk,
	adc_saddr,
	adc_csn,
	adc_sdat,
	dac_sclk,
	dac_din,
	dac_csn
);
input clk,rst,key1,key2,adc_sdat;
wire [2:0]out;
output lock595,out595,clk595,adc_sclk,adc_csn,adc_saddr,dac_sclk,dac_din,dac_csn;
wire [11:0]data;
wire BUSY;
reg START;
wire oclk;
wire [11:0]DATA_A;
wire [11:0]DATA_B;
frequencydivider frequencydivider1(
	.clk(clk),
	.rst(rst),
	.fclk(oclk)
);
KEY_Selector KEY_Selector1(
	.key1(key1),
	.key2(key2),
	.clk(clk),
	.rst(rst),
	.out(out)
);
BCDDisplay BCDDisplay1(
	.clk(clk),
	.rst(rst),
	.data({1'b0,out,16'b0,data}),
	.lock595(lock595),
	.out595(out595),
	.clk595(clk595)
);
ADC128S022_interface ADC128S022_interface1(
	.ADDR(out),
	.DATA(data),
	.START(START),
	.BUSY(BUSY),
	.CLK(oclk),
	.RST(rst),
	.adc_sclk(adc_sclk),
	.adc_saddr(adc_saddr),
	.adc_csn(adc_csn),
	.adc_sdat(adc_sdat)
);
tlv5618a_device tlv5618a_device1(
	.DATA_A(DATA_A),
	.DATA_B(DATA_B),
	.clk(oclk),
	.rst(rst),
	.dac_sclk(dac_sclk),
	.dac_din(dac_din),
	.dac_csn(dac_csn)
);
always@(posedge oclk)
if(BUSY)
	START <= 1'b0;
else
	START <= 1'b1;	
assign DATA_A = 12'h0e4;
assign DATA_B = 12'hfff;

endmodule

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值