一、硬件与架构设计
本项目中用到的设备有:PC、FPGA、温度传感器DS18B20、蜂鸣器(beep)、数码管(segment)。
对于本次的项目,我的任务是将之前的温度检测项目的架构再进行细分,以及将相应的代码写出来并且能够上板调试出来。
之前的温度检测项目的架构主要分了九个模块:分别是uart_rx模块、ascii_hex模块、opcode模块、control模块、byte模块、bit模块、seg_disp模块、hex_ascii模块、uart_tx模块,具体的架构图如图1所示:
在上面温度检测架构(图1)的基础上,我将架构再进行了细分,分成了11个模块:分别是uart_rx模块、ascii_hex模块、opcode模块、control模块、byte模块、温度比较模块、温度计算转换模块、bit模块、seg_disp模块、hex_ascii模块、符号补全模块、uart_tx模块,具体的架构图如图2所示:
该项目架构细分前后的主要区别主要是:将细分之前的control模块分解成了control模块、温度比较模块、温度计算比较转换模块、符号补全模块、以及将opcode模块的输出设置为地址指令和数据指令一起输出。
二、架构细分后的优点
我个人认为有以下几个优点:
1、 让每一个模块的功能更加清晰,看起来比较直观(让刚接触到该项目的新手,能够比较短时间内了解各个模块的功能);
2、 让思路更加清晰,方便写相应地代码,减少因代码过多而导致容易发生错误的问题(细分前的control模块代码多,功能多,使得看或者写代码时有一定的难度);
3、 方便对每一个模块进行相应地测试(方便写测试文件)。
三、产生问题及解决方案
在细分该项目的过程中,我所遇到的问题有以下三点:
1、 对各个细分模块的输入和输出信号定义不太清晰(不知道该设置多少个输入和输出信号);
2、 对模块之前的闲忙信号定义比较模糊(不太清楚哪些模块之间需要定义闲忙信号);
3、 上板调试时,数码管上能够正常显示读取到的温度值,而pc上却出现了乱码(没有显示读取到的温度值);
对于以上提到的三个问题,我分别做了如下的处理:对于第一个问题、我先将能够想到的输入或者输出信号先定义好(多除少补),再结合细分架构之前对应的输入和输出进行定义;对于第二个问题、我先考虑各个模块之间的信号处理时间,看看哪些模块之间需要用到闲忙信号,最后再结合细分架构之前各个模块之前的闲忙信号设置;对于第三个问题、我使用signaltap从uart_tx模块、符号补全模块、hex_ascii模块、温度计算比较转换模块依次进行查找问题,最后查找出是某一个输出信号的位宽定义的问题。
总的来说,通过对本次温度检测项目架构细分,让我对该项目更加的了解了,以及在一定程度上扩展我的设计思路,同时也让我对signaltap的使用更加熟悉了(用signaltap找bug确实是一种很好的方法),还有就是也让我体验到了一丝的成就感。
以上就是本人优化温度检测工程架构的心得笔记,感兴趣的朋友可以在留言中与我进行交流讨论!
审核编辑黄昊宇
-
FPGA
+关注
关注
1664文章
22545浏览量
640414 -
检测
+关注
关注
5文章
4965浏览量
94377
发布评论请先 登录
电流互感器在电流检测中的误差分析与优化设计
三相无刷风扇驱动板:硬件架构、设计要点与工程实现
温度补偿芯片衰减器P*V系列:助力高频放大器性能优化
探索RotaSense™ 2位置温度传感器连接器:优化系统性能的理想之选
iptables防火墙的核心架构与性能优化指南
在TR组件优化与存算一体架构中构建技术话语权
ADI建议电源开发优先考虑电源架构的优化
嵌入式工程师的进阶之路
电商API的微服务架构优化策略
安科瑞ARTM-4 温度巡检测--低压配电系统电气接点、绕组温度监测与控制
Redis集群部署与性能优化实战
知识分享 | 评估模型架构——如何实现?
优化温度检测工程架构的心得
评论