找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4713|回复: 4
收起左侧

基于verilog语言的温度检测系统源程序

[复制链接]
ID:410231 发表于 2019-9-7 15:25 | 显示全部楼层 |阅读模式
当初开始做这个系统的时候苦于没有一个成熟的代码和时序图帮助理解,网上的代码往往被魔改过,在技术群里边问问题基本上不回应,有一哥们甚至想1000块卖我代码……后来洒家爆肝一周把写出代码又调试完毕。本人比较认同黑客精神,认为网上的学习资源应该是免费使用的。因此在这里将洒家的代码和仿真文件、仿真图一并奉上,以供参考。如有不足,希望大家多多包涵指正。
read.png write_0x44.png write0xcc.png

Verilog源程序如下:
  1. module ds18b20_top
  2. (
  3.                 clkin,//时钟
  4.                 resetin,//复位信号输入
  5.                 ds18b20_bus,//ds18b20控制信号
  6.                 wrong,//错误信号
  7.                 temperature,//温度输出
  8.                 read//读温度命令
  9. );
  10. input clkin,resetin,read;
  11. inout ds18b20_bus;
  12. output[15:0] temperature;
  13. output wrong;

  14. parameter  reset1 = 1, //初始化
  15.                                         data1_1 = reset1 + 1000,//1000  写0xcc
  16.                                         data1_2 = data1_1 + 600,//1600 写0x44
  17.                                         reset2 = data1_2 + 600,//2200 初始化
  18.                                         data2_1 = reset2 + 1000,//3200 写0xcc
  19.                                         data2_2 = data2_1 + 600,//3800 写0xbe
  20.                                         read1 = data2_2 + 600,//4400 读低字节
  21.                                         read2 = read1 + 600,//5000 读高字节
  22.                                         read_end = read2 + 600;//5600
  23.                                        
  24. assign temperature = {tempH, tempL};
  25. reg[7:0] tempH, tempL;//温度高字节 温度低字节
  26. wire[7:0] temp;//
  27. wire[1:0] command;
  28. reg[1:0] state;
  29. reg divider_reset, ds18b20_reset, wrong;
  30. wire ds18b20_ok;
  31. //分频时钟
  32. wire clk_1MHz;
  33. reg start, stop;
  34. reg[8:0] ds18b20_byte_write;
  35. reg[15:0] clk_count;

  36. Divider Divide_1MHz(.reset(divider_reset), .clkin(clkin), .clkout(clk_1MHz));
  37. ds18b20_byte ds18b20(.clkin(clkin),
  38.                                                                         .resetin(start),
  39.                                                                         .ds18b20_command(ds18b20_byte_write),
  40.                                                                         .ds18b20_bus(ds18b20_bus),
  41.                                                                         .ds18b20_read(temp),
  42.                                                                         .ds18b20_reset(ds18b20_reset),
  43.                                                                         .ds18b20_ok(ds18b20_ok),
  44.                                                                         );
  45.                                                                        
  46. always @ (negedge resetin or posedge clk_1MHz)
  47.         if (!resetin)
  48.                 begin
  49.                         divider_reset<=1'b1;
  50.                         start<=0;
  51.                         clk_count<=0;
  52.                         ds18b20_reset<=0;
  53.                         wrong<=0;
  54.                         tempL<=0;
  55.                         tempH<=0;
  56.                         stop<=0;
  57.                 end
  58.         else
  59.                 begin                       
  60.                         //send 0xcc 0x44
  61.                         case(clk_count)
  62.                         reset1 - 1: ds18b20_reset<=1;
  63.                         reset1:start<=1;
  64.                         data1_1 - 1://数据准备
  65.                                 begin
  66.                                         if(ds18b20_ok!=1'b1)
  67.                                                 begin
  68.                                                         wrong<=1;
  69.                                                         stop<=1;
  70.                                                 end
  71.                                         else
  72.                                                 begin
  73.                                                         start<=0;
  74.                                                         ds18b20_reset<=0;
  75.                                                         ds18b20_byte_write<={8'hcc, 1'b1};
  76.                                                 end
  77.                                 end
  78.                         data1_1:start<=1;//数据发送
  79.                         data1_2 - 2://数据准备
  80.                                 begin
  81.                                         ds18b20_byte_write<={8'h44, 1'b1};
  82.                                         start<=0;
  83.                                 end
  84.                         data1_2:start<=1;//数据发送
  85.                         //send 0xcc 0xbe
  86.                         reset2 - 2:
  87.                                 begin
  88.                                         ds18b20_reset<=1;
  89.                                         start<=0;
  90.                                         if(!read)
  91.                                                 stop<=1;
  92.                                 end
  93.                         reset2 - 1:
  94.                                 begin
  95.                                         if(read)
  96.                                                 stop<=0;
  97.                                 end
  98.                         reset2:start<=1;
  99.                         data2_1 - 2://等待读命令输入
  100.                                 begin
  101.                                         if(ds18b20_ok!=1'b1)
  102.                                                 begin
  103.                                                         wrong<=1;
  104.                                                         stop<=1;
  105.                                                 end
  106.                                         else
  107.                                                 begin
  108.                                                         start<=0;
  109.                                                         ds18b20_reset<=0;
  110.                                                         ds18b20_byte_write<={8'hcc, 1'b1};
  111.                                                 end
  112.                                 end
  113.                         data2_1:start<=1;//开始读温度
  114.                         data2_2 - 2:
  115.                                 begin
  116.                                         ds18b20_byte_write<={8'hbe, 1'b1};
  117.                                         start<=0;
  118.                                 end
  119.                         data2_2:start<=1;
  120.                         read1 - 2://低字节
  121.                                 begin
  122.                                         ds18b20_byte_write<={8'h00, 1'b0};
  123.                                         start<=0;
  124.                                 end
  125.                         read1:start<=1;
  126.                         read2 - 2:
  127.                                 begin
  128.                                         tempL<=temp;
  129.                                         start<=0;
  130.                                 end
  131.                         read2:start<=1;//prepare for read, get tempH
  132.                         read_end://高字节
  133.                                 begin
  134.                                         start<=0;
  135.                                         tempH<=temp;
  136.                                         stop<=1;
  137.                                 end
  138.                         endcase
  139.                 if(!stop)
  140.                         clk_count<=(clk_count+1)%8000;
  141.                 end
  142. endmodule
复制代码
0.png
所有资料51hei提供下载:
ds18b20.zip (8.75 KB, 下载次数: 61)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:163169 发表于 2019-10-5 14:03 | 显示全部楼层
精神强赞!
回复

使用道具 举报

ID:651992 发表于 2019-11-28 22:26 | 显示全部楼层
楼主能不能私发一下程序!1341409561@qq.com
回复

使用道具 举报

ID:651992 发表于 2019-11-29 00:10 | 显示全部楼层
老哥,留个联系方式,问您温度检测系统的问题
回复

使用道具 举报

ID:72951 发表于 2020-3-26 19:13 | 显示全部楼层
谢谢分享,赞
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表