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

ops/2024/11/19 6:36:57/

测试平台:

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.ppmy.cn/ops/134889.html

相关文章

llm 从0开始学习大语言模型, transformer架构学习

1. github&#xff1a; https://github.com/rasbt/LLMs-from-scratch 2. 这个是一本书&#xff0c;写在了github. 里面有代码&#xff0c;有讲解。从0开始写个llm 3. 如果看不懂&#xff0c;知乎有人写的中文版学习笔记&#xff1a; https://zhuanlan.zhihu.com/p/681401085

centos安装jenkins

本机使用虚拟机centos 7.9.2009 安装gitlab&#xff0c;本机的虚拟机ip地址是 192.168.60.151&#xff0c; 步骤记录如下 1、下载jenkins&#xff0c;安装jenkins之前需要安装jdk jdk和jenkins的版本对应关系参考&#xff1a;Redhat Jenkins Packages Index of /redhat-stable…

TDSQL 免密码登录

需求 os用户免密登录tdsql 解决方案 使用mysql自带的 mysql_config_editor 工具 提示&#xff1a;使用这个工具&#xff0c;登录密码不能包含#字符。 操作步骤 建os账号&#xff0c;切换到新账号 [roottdsql1 ~]# useradd jdbc_user [roottdsql1 ~]# su - jdbc_user [jd…

跨越网络边界:IPv6与零信任架构的深度融合

2024年&#xff0c;工信部发布了《关于开展“网络去NAT”专项工作 进一步深化IPv6部署应用的通知》&#xff0c;加速了国内网络由IPv4向IPv6的转型步伐。未来&#xff0c;各行各业将逐步去NAT&#xff0c;逐步向IPv6迁移。在此过程中&#xff0c;网络安全解决方案和产品能力将面…

深度学习:计算卷积神经网络中输出特征图尺寸的关键公式

计算卷积神经网络中输出特征图尺寸的关键公式 在设计卷积神经网络&#xff08;CNN&#xff09;时&#xff0c;准确计算每个卷积层的输出特征图尺寸是至关重要的。这不仅关系到网络的结构设计&#xff0c;也直接影响参数优化和整体性能。适当的计算可以确保网络层正确连接&…

Spring 与 Spring MVC 与 Spring Boot三者之间的区别与联系

一.什么是Spring&#xff1f;它解决了什么问题&#xff1f; 1.1什么是Spring&#xff1f; Spring&#xff0c;一般指代的是Spring Framework 它是一个开源的应用程序框架&#xff0c;提供了一个简易的开发方式&#xff0c;通过这种开发方式&#xff0c;将避免那些可能致使代码…

11.12.2024刷华为OD-集合的使用,递归回溯的使用

文章目录 HJ41 集合的使用HJ43 迷宫问题--递归回溯的使用语法知识记录 HJ41 集合的使用 HJ43 迷宫问题–递归回溯的使用 def dfs(x, y, path, grid):n len(grid)m len(grid[0])if x n-1 and y m-1:for cor in path:print("({},{})".format(cor[0],cor[1]))# 判断…

html兼容性问题处理

文章目录 HTML5兼容性问题及解决方法1. 标签支持问题2. 兼容性检测3. 属性值支持问题4. 媒体支持问题5. Web API支持问题6. CSS兼容性问题7. 特定浏览器问题的解决方法 HTML5兼容性问题及解决方法 HTML5作为一种新的标记语言&#xff0c;虽然带来了许多新特性和改进&#xff0…