FPGA+DSP的相关设计

本文详细介绍了使用FPGA和DSP配合实现矩阵键盘扫描和LED控制的方法,包括键盘扫描原理、DSP与FPGA的通信以及FIFO在两者间的数据传输。通过FPGA实现键盘扫描减少DSP资源消耗,利用FIFO实现异步通信,确保读写互不干涉。
摘要由CSDN通过智能技术生成

1.键盘扫描的电路图以及基本原理

在这里插入图片描述
如上图所示是一个4*4键盘与单片机连接的基本电路图,行线P10-P13的管脚是输出脚,列线P14-P17是输入脚,开始的时候输出脚都输出低电平,此时读入列线数据,若列线全为高电平则没有键按下,当列线有出现低电平时调用延时程序以此来去除按键抖动。延时完成后再判断是否有低电平,如果此时读入列线数据还是有低电平,则说明确实有键按下。
最后一步确定键值。现在我们以第二行的S5键为例,若按下S5后我们应该怎么得到这个键值呢?当判断确实有键按下之后,行线轮流输出低电平,根据读入列线的数据可以确定键值。首先,单片机将P10输出为低电平,其它P11~P13输出高电平,此时读取列线的数据全为高电平,说明没有在第一行有键按下;其次,单片机将P11输出低电平,其它P10、P12、P13仍为高电平,此时再来读取列线数据,发现列线读到的数据有低电平,数值为1011(0x0B),如果我们的键盘布局已经确定,那么0x0B就代表S5的值了。转到S5键功能处理子程序就可以达到目的。

2.实现对LED灯和矩阵键盘的控制

LED是实现对DSP对外设写数据,而键盘有写也有读。

首先我们要对DSP的存储结构图有一个比较清晰的了解:
在这里插入图片描述

  1. 首先我们就需要对将外设与我们DSP上的地址给对应起来,在这里我们选择的是外部扩展存储空间CE3来进行外设的扩展,地址从C00000开始。我们可以如下来进行地址的设定:
    8个LED,对应地址:0xC00000
    4个行按键line(输出口),对应地址:0xC00001
    4个列按键col(输入口),对应地址:0xC00002
    当然这只是一种地址设定的方式,我们可以将每个灯都对应一个地址,但是有一个问题,就是我们的数据总线宽度是8位、16位、32位的。我们每个灯只用得到一个bit。我们可以8个LED等对应0xC00000的低8位,也可以每个LED对应一个地址的最低位。这都是可以通过你的数
  • 3
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值