当前位置:首页 > 公众号精选 > FPGA之旅
[导读]这是FPGA之旅设计的第十例啦,在上一例中,已经成功驱动了OLED屏幕,本例将结合上一例,以及第四例多bytes串口通信做一个有趣的例程。

一. 简介

这是FPGA之旅设计的第十例啦,在上一例中,已经成功驱动了OLED屏幕,本例将结合上一例,以及第四例多bytes串口通信做一个有趣的例程。


简单来说,就是利用Qt编写上位机,通过串口与FPGA进行通信,然后FPGA将接收到的数据,通过IIC接口发送给OLED,就这么一个流程。


二. QT上位机

大家可能对QT部分不感兴趣,也不熟悉,这里就只对上位机的功能进行说明,实现过程就不叙述了,想了解的可以点个赞,人多的话,就专门介绍一下。


上位机目前一共只实现了两个功能,一个是添加文字,另外一个是添加圆。添加过后,会在OLED预览区域中进行显示。等编辑好之后,就可以点击执行,这时候,上位机会解析这部分的数据,然后通过串口发送给FPGA,接下来的就是FPGA里面的处理了。


上位机可以更加完善。例如字体的大小可调,字体可选,圆的线宽可调,像其他图形矩形,椭圆,线等等,都是可以的。也可以扩展功能,如添加图片等等。上位机的介绍就到这里。


三. FPGA部分实现

(一). 串口部分

在第四例,多byte串口接收模块中,默认为每次接收到三个byte就使能一次。刚好这里发送给OLED的数据也是三个byte,就对应上了,不需要修改任何程序,直接在top模块里面例化即可。

UART_MulRX UART_MulRXHP( .sys_clk        (sys_clk), /*系统时钟 50M*/ .rst_n        (rst_n), /*复位信号*/  .uart_rxs_done    (uart_rxs_done), /*串口接收完成*/ .odats        (uart_rxs_data), /*接收数据*/  .uartrx        (UART_RX) /*uart rx信号线*/);

OLED部分

在上一例中,程序对OLED进行初始化之后,就进入了空闲态,在空闲态的时候,是没有任何处理的。但在本例中,需要对串口接收到的数据进行处理,通过IIC发送给OLED,这部分也很简单,代码如下。

module OLED_SelData( input        sys_clk, input        rst_n, input        init_req, input[23:0]  init_data,  input        uart_req, input[23:0]  uart_data,  output       IICWriteReq, output[23:0] IICWriteData); reg       IICWriteReqReg;reg[23:0] IICWriteDataReg;  assign IICWriteReq  = init_req | uart_req;assign IICWriteData = (init_req == 1'b1) ? init_data : uart_data; endmodule

这个例程,就是将前面的串口多byte串口通信和这个结和起来了,设计难点在上位机的编写,对上位机感兴趣的可以多了解一下,不感兴趣的可以参考一下,例如说,将IIC模块上包一个串口模块,就可以将IIC接口变为串口了,就可以通过串口来配置OLED了。效果如下。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

当我们提到成本优化型FPGA,往往与简化逻辑资源、有限I/O和较低制造工艺联系在一起。诚然,在成本受限的系统设计中,对于价格、功耗和尺寸的要求更为敏感;但随着一系列创新应用的发展、随着边缘AI的深化,成本优化型FPGA也...

关键字: AMD FPGA Spartan 边缘计算

全球领先的高性能现场可编程门阵列(FPGA)和嵌入式FPGA(eFPGA)半导体知识产权(IP)提供商Achronix Semiconductor公司宣布,该公司参加了由私募股权和风险投资公司Baird Capital举...

关键字: FPGA 智能汽车 eFPGA

全新 FPGA 能为嵌入式视觉、医疗、工业互联、机器人与视频应用提供高数量 I/O、功率效率以及卓越的安全功能

关键字: FPGA 嵌入式视觉 机器人

Altera致力于为客户提供端到端的FPGA、易于使用的AI、软件和弹性供应链。

关键字: FPGA AI

在半导体领域,大部分对于AI的关注都集中在GPU或专用AI加速器芯片(如NPU和TPU)上。但事实证明,有相当多的组件可以直接影响甚至运行AI工作负载。FPGA就是其中之一。

关键字: FPGA AI 半导体

半导体产品老化是一个自然现象,在电子应用中,基于环境、自然等因素,半导体在经过一段时间连续工作之后,其功能会逐渐丧失,这被称为功能失效。半导体功能失效主要包括:腐蚀、载流子注入、电迁移等。其中,电迁移引发的失效机理最为突...

关键字: 半导体 电迁移 FPGA

2024 年 2 月 27日 - 中国 – 市场排名前列生物识别解决方案提供商创迈思(trinamiX)与主要合作伙伴维信诺和意法半导体合作开发出了智能手机隐形人脸认证系统。全球排名前列的先进显示整体解决方案制造商维信诺...

关键字: OLED屏 智能手机 人脸认证

这款较低成本的开发平台可帮助学生、初学者和经验丰富的设计人员采用新兴技术

关键字: RISC-V FPGA 嵌入式

进一步扩展旗下IEEE®-1588主时钟产品组合,可实现小于1纳秒的精确时间精度

关键字: 主时钟 数字合成器 FPGA

中国上海——2024年1月22日——莱迪思半导体(NASDAQ:LSCC),低功耗可编程器件的领先供应商,今日宣布莱迪思的中端FPGA系列莱迪思Avant-E™ FPGA荣获国际科技创新节(STIF)“年度产品创新奖”,...

关键字: 可编程器件 FPGA AI
关闭