串口转host接口

简介

在很多FPGA应用场景中,我们需要对FPGA内的一些寄存器进行配置,直接采用高位宽的物理接口直接赋值会极大的浪费我们的管脚资源,因此我们经常采用串并转换的方式来达到实现功能且节约资源的目的。

模块介绍

实现本功能一共使用了5个模块,分别是串口数据接收、串口数据发送、串口接收数据转host协议数据、host协议数据转串口发送数据,顶层接口模块。
串口数据接收发送:我们使用115200的波特率(可调),使用16倍频采样。在FPGA中工作方式为全双工工作。
串口接收数据转host协议数据:串口接收数据格式为:帧头(2字节) 设备号(1字节) 读写控制(1字节) 寄存器地址(2字节) 写入值(2字节),我们将接到的数据对应上的数据格式进行存储,待上面数据全部接收完成时进行串并转换,由串口转换到host接口。同时为了防止传输过程中出现问题导致状态机卡住,我们在状态机中插入了看门狗来进行超时复位操作。
host协议数据转串口发送数据:将返回的数据进行缓存后由串口发送模块发出。

host接口介绍

input    wire                 h_w_rdy,
output   wire                 h_r_wb,
output   wire    [15:0]       h_addr,
output   wire    [15:0]       h_data_in

h_w_rdy信号为读写准备信号,为从设备反馈信号,从设备可接收命令时拉高。
h_r_wb信号为读写控制信号,由主设备控制,置高为读取数据,置低为写入数据。
h_addr信号为读写地址通道,存放控制的寄存器地址。
h_data_in信号为写入数据通道,输出寄存器写入的数据。
对于读取的数据,是由从机控制host协议数据转串口发送数据模块完成的,控制时序十分简单,直接在同一时刻将数据有效信号与数据放在对于通道上即可将返回数据通过串口发送出去。

具体实现可以看代码。
https://download.csdn.net/download/hpqztsc/12909757

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STM32F103C8 Serial(UART) to USB HID Keyboard Mouse 串口 USB键盘鼠标 (1) 使用Composite Device 组合(复合)设备 (1.1) 1个Device -> 1个 Configuation -> 2个Interfance (Keyboard & Mouse) (1.2) Keyboard Interfance -> HID (boot mode) -> 2个Endpoint(IN_0x81 & OUT_0x01) -> KeyboardReportDescriptor(不使用Report ID) (1.3) Mouse Interfance -> HID (boot mode) -> 1个Endpoint(IN_0x82) -> MouseReportDescriptor(不使用Report ID) (1.4) 使用HID boot模式, 不使用Report ID, 以便兼容在 计算器设定BIOS模式 中的操作 (2) 串口接收 命令 (2.1) UART协议: 115200, n, 8, 1 (2.2) 1帧发送字符串格式, 以 '{'开始; '}'结束; ','分隔. 共9个10进制数字 例如: {1,2,3,4,5,6,7,8,9} (2.3) 第9位 区分 Keyboard(64) 或是 Mouse(128) 命令 例如: {0,0,0,0,0,0,0,0,64} --- 发送Keyboard命令 {0,0,0,0,0,0,0,0,128} --- 发送Keyboard命令 (3) 发送Keyboard键盘命令时 : 第1~8位 分别如下 (3.1) 第1位 : Key_Release = 0x00, Left_Control = 0x01, Left_Shift = 0x02, Left_Alt = 0x04, Left_GUI = 0x08, Right_Control = 0x10, Right_Shift = 0x20, Right_Alt = 0x40, Right_GUI = 0x80, 例如: {8,0,0,0,0,0,0,0,64} --- 发送 Win_Key键 {128,0,0,0,0,0,0,0,64} --- 发送 WinApp_Key键 {32,0,0,0,0,0,0,0,64} --- 发送 右Shift键 (3.2) 第2位 : 保留,不使用,一律填0 (3.3) 第3~8位 : 可以同时发送6个Keyboard按键 例如: {0,0,4,5,6,7,8,9,64} --- 发送 'abcdef'键 {2,0,4,5,6,7,8,9,64} --- 按住 左Shift 发送 'abcdef'键 => 'ABCDEF' {0,0,0,5,0,7,0,9,64} --- 发送 'bdf'键 (0表示 无按键) 按键码 可参阅: (HID Usage ID) http://download.microsoft.com/download/1/6/1/161ba512-40e2-4cc9-843a-923143f3456c/translate.pdf https://www.hiemalis.org/~keiji/PC/scancode-translate.pdf https://gist.github.com/MightyPork/6da26e382a7ad91b5496ee55fdc73db2 http://www.usb.org/developers/hidpage/Hut1_12v2.pdf (4) 发送Mouse鼠标命令时 : 第1~8位 分别如下 (4.1) 第1位 : Button_Release = 0x00, Left_Button = 0x01, Right_Button = 0x02, Mid_Button = 0x04, 例如: {1,0,0,0,0,0,0,0,128} --- 点击 左键 {2,0,0,0,0,0,0,0,128} --- 点击 右键 {4,0,0,0,0,0,0,0,128} --- 点击 中键 (4.2) 第2~4位 : 移动(X,Y), 滚轮(Wheel) X: -127~127:左右移动鼠标 Y: -127~127:上下移动鼠标 Wheel: -127~127:上下动滚轮 例如: {0,20,-10,0,0,0,0,0,128} --- 鼠标 右移20,上移10 {0,0,0,-30,0,0,0,0,128} --- 滚轮-30 (4.2) 第5~8位 : 保留,不使用,一律填0

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值