当前位置: 首页 > article >正文

乘法器为例:概述MCU与FPGA通过APB总线实现交互(fpgaAPB的简单使用)

测试平台:

GW1N4器件内置 M1内核;并且可以设置 APB总线与fpga 逻辑进行交互;

框图:

+---------------------+
|                     |
|   M1 Microprocessor |  <-----------------+
|                     |                    |
|   +-----------------+--------------------+
|   |                                             |
|   |  APB Bus                                  |
|   |  (PCLK, PRESETn, PSEL, PENABLE, PWRITE,   |
|   |   PADDR, PWDATA, PRDATA, PREADY, PSLVERR) |
|   +-----------------+--------------------+
|                     |                    |
+---------------------+                    |
                                               |
                                               v
+---------------------+---------------------+
|                                          |
|   FPGA Multiplier Module                 |
|   +-------------------------------------+
|   |                                     |
|   |  +-----------------+                |
|   |  |  Multiplier     |                |
|   |  +-----------------+                |
|   |  |  8-bit register |                |
|   |  +-----------------+                |
|   |                                     |
|   |  +-----------------+                |
|   |  |  Multiplicand  |                |
|   |  +-----------------+                |
|   |  |  8-bit register |                |
|   |  +-----------------+                |
|   |                                     |
|   |  +-----------------+                |
|   |  |  Command       |                |
|   |  +-----------------+                |
|   |  |  2-bit register |                |
|   |  +-----------------+                |
|   |                                     |
|   |  +-----------------+                |
|   |  |  Result        |                |
|   |  +-----------------+                |
|   |  |  16-bit register|                |
|   |  +-----------------+                |
|   |                                     |
|   +-------------------------------------+
|                                          |
+---------------------+---------------------+

说明

    M1 微处理器


        APB Bus:M1 微处理器通过 APB 总线与 FPGA 乘法器模块进行通信。APB 总线包括以下信号:
            PCLK:总线时钟信号。
            PRESETn:复位信号,低电平有效。
            PSEL:选择信号,表示当前传输的目标是从设备。
            PENABLE:使能信号,表示传输的第二个时钟周期(即数据传输周期)。
            PWRITE:读/写控制信号,高电平表示写操作,低电平表示读操作。
            PADDR:地址总线,表示当前传输的目标地址。
            PWDATA:写数据总线,用于写操作的数据传输。
            PRDATA:读数据总线,用于读操作的数据传输。
            PREADY:准备就绪信号,表示从设备已经准备好响应当前传输。
            PSLVERR:错误信号,表示传输过程中发生错误。

    FPGA 乘法器模块


        Multiplier:8 位寄存器,用于存储乘数。
        Multiplicand:8 位寄存器,用于存储被乘数。
        Command:2 位寄存器,用于存储命令。
        Result:16 位寄存器,用于存储乘法结果。

交互过程:

    初始化
        M1 微处理器通过 APB 总线初始化 FPGA 乘法器模块。
        设置乘数寄存器和被乘数寄存器的初始值。

    写操作
        M1 微处理器通过 APB 总线写入乘数寄存器和被乘数寄存器。
        设置命令寄存器中的启动位(例如 CMD_START)。

    读操作
        M1 微处理器通过 APB 总线读取命令寄存器的状态位(例如 STATUS_FINISHED),以检查乘法操作是否完成。
        如果乘法操作完成,读取结果寄存器中的乘法结果。

    完成
        M1 微处理器通过 APB 总线清除命令寄存器中的启动位,完成一次乘法操作。
        可以重复上述步骤进行多次乘法操作。

框图总结

通过这个框图,我们可以清晰地看到 M1 微处理器和 FPGA 乘法器模块之间的连接性和交互过程。APB 总线作为通信桥梁,确保了两者之间的数据传输和控制信号的传递。

M1端的C代码:


                

http://www.kler.cn/a/399708.html

相关文章:

  • 初识Linux · 信号处理 · 续
  • 基于Spring Boot+Unipp的博物馆预约小程序(协同过滤算法、二维码识别)【原创】
  • gitlab 服务器集群配置及 存储扩展配置
  • FastGPT部署通义千问Qwen和智谱glm模型|OneAPI配置免费的第三方API
  • 【springboot】启动原理
  • 【3D Slicer】的小白入门使用指南九
  • opencv(c++)---访问图像像素、增加白噪点
  • MySQL的表的约束以及查询
  • 汽车资讯新动力:Spring Boot技术驱动
  • 统计从输入的两个整数a和b所确定的范围内(0 ~ 9)出现的次数(c基础)
  • SpringBoot源码解析(四):解析应用参数args
  • 马斯克诉OpenAI新进展:加入微软等被告
  • WPF的基础控件详解
  • 基于单片机的风能太阳能供电的路灯智能控制系统设计(论文+源码)
  • 2411rust,1.80
  • 【汇编语言】数据处理的两个基本问题(三) —— 汇编语言的艺术:从div,dd,dup到结构化数据的访问
  • 数据库灾难恢复:构建不可摧的数据防线
  • 【数据结构】栈和队列的定义与实现
  • Linux :进程间通信之管道
  • 详细解读Gson 、Jackson 、FastJson 三大json序列化工具
  • PyTorch实战-手写数字识别-单层感知机
  • uniapp 微信小程序地图标记点、聚合点/根据缩放重合点,根据缩放登记显示气泡marik标点
  • Docker 用法详解
  • k8s入门学习
  • 鸿蒙动画开发08——帧动画
  • MYSQL- 查看表的状态信息语句(二十四)