【RK3568+PG2L50H開發板實驗例程】Linux部分/FPGA dma_memcpy_demo 讀寫案例

本原創文章由深圳市小眼睛科技有限公司創作,版權歸本公司所有,如需轉載,需授權并注明出處(www.meyesemi.com)

1.案例簡介

案例功能描述:ARM端利用 PCIe總線對 FPGA的 DRAM執行讀寫操作。應用程序通過 ioctl函數觸發 DMA數據傳輸后,將等待驅動程序發出的 input事件作為響應。應用程序接收到該事件時,表示 DMA數據傳輸已經結束。

2.測試程序執行流程

(1)ARM端

1.將數據寫至 dma_memcpy驅動申請的連續內存空間(位于 DDR)。配置 DMA,如源地址、目標地址、傳輸的數據大小等;

2.寫操作:通過 ioctl函數啟動 DMA,通過 PCIe總線將數據搬運至 FPGA DRAM;程序接收驅動上報 input事件后,將通過 ioctl函數獲取 DMA搬運數據耗時,并計算DMA寫速率;

3.讀操作:通過 ioctl函數啟動 DMA,通過 PCIe總線將 FPGA DRAM中的數據搬運至 dma_memcpy驅動申請的連續內存空間(位于 DDR);程序接收驅動上報 input事件后,將數據從內核空間讀取至用戶空間,然后校驗數據,同時通過 ioctl函數獲取DMA搬運數據耗時,并計算 DMA讀速率。

(2) FPGA端

1.實現 PCIe Endpoint功能;

2.處理 PCIe RC端發起的 PCIe BAR0空間讀寫事務;

3.將 PCIe BAR0讀寫數據緩存至 FPGA DRAM中。

3.操作流程

?打開終端,將本案例 bin目錄下( 05-開發資料 \軟件開發資料\linux_demo\mes_fpga_dma_memcpy_demo\bin ) 的 可 執 行 程 序mes_dma_memcpy_demo拷貝至開發板文件系統(源碼可以在 src路徑下查看)。#修改 Linux內核日志的顯示級別,內核的日志級別被設置為只顯示緊急或更高級別的消息

echo 1 4 1 7 > /proc/sys/kernel/printk

在終端執行如下指令,切換到 mes_dma_memcpy_demo可執行程序所在目錄

#切換到 mes_fpga_fspi_demo可執行程序所在目錄

cd ‘可執行文件所在目錄’

#查看 mes_dma_memcpy_demo是否在該目錄下

ls

若可執行文件 mes_dma_memcpy_demo在當前目錄下,則修改可執行文件的權限#修改文件權限

chmod 777 mes_dma_memcpy_demo

#查詢是否修改成功

ls -ld mes_dma_memcpy_demo

查詢確認文件修改權限成功后,執行 ./mes_dma_memcpy_demo -h可以查看該程序的幫助信息

#查看幫助信息

./mes_dma_memcpy_demo -h #-a:設置 PCIe 地址; #-s:設置傳輸數據大小(單位:Byte); #-c:設置循環讀寫次數; #-d:設置輸入設備;#-v:顯示版本信息; #-h:顯示幫助內容。 執行結果如下圖:

?執行以下命令,查看 PCIe BAR 空間地址。從下圖可見,PCIe BAR 空間映射至 0xf0200000 地址,大小為 64KByte,并查看 PCIe 設備連接狀態。

lspci -s 0002:21:00.0 -vv

?執行以下命令,使能 PCIe設備。

echo 1 > /sys/class/pci_bus/0002\:21/device/0002\:21\:00.0/enable

應用程序通過 ioctl函數發送命令開啟 DMA傳輸數據后,等待驅動上報 input事件;當應用層接收到 input事件,說明 DMA傳輸數據完成。執行以下指令以查看 input輸入事件接口。如圖所示,input事件接口為/dev/input/event0。

evetest

?

?執行以下指令,將隨機生成的數據寫入 FPGA的 DRAM,隨后從 FPGA的 DRAM中讀取數據。測試結束后,通過/dev/input/event0接收事件通知,輸出測試結果,其中包括平均讀寫時間、平均傳輸速率以及讀寫錯誤數量等統計信息。執行結果如下圖。./dma_memcpy_demo -a 0xf0200000 -s 65536 -c 100 -d /dev/input/event6#這里的 event0根據 evetest查詢到的結果更改。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/912872.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/912872.shtml
英文地址,請注明出處:http://en.pswp.cn/news/912872.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

7.3實驗部分

一、HDFS基礎操作 以root用戶登錄,創建如下HDFS目錄: /dw/yourname/input hadoop fs -mkdir -p /dw/zhanggengchen/input /dw/yourname/output hadoop fs -mkdir -p /dw/zhanggengchen/output 輸出結果: [rootmaster hadoop-mapreduce]# ha…

[nett5: AddressedEnvelope]-源碼解析

AddressedEnvelope AddressedEnvelope<M, A> 表示一個帶有發送者和接收者地址的消息封裝&#xff0c;常用于處理如 UDP 數據報這類含地址信息的通信場景。 public interface AddressedEnvelope<M, A extends SocketAddress> {// 實際的消息內容M content();// 消…

基于 Drone CI 實現前端自動化打包并集成 Spug 自動發布流程

前言&#xff1a;代碼自動化部署目前使用的是Spug開源運維平臺&#xff0c;通過docker直接部署該平臺后&#xff0c;在前端自動化打包&#xff08;npm run build&#xff09;會遇見Node的版本問題&#xff0c;因為Spug容器使用的是Centos7&#xff0c;所以Node版本只支持V16&am…

【基礎】Golang語言開發環境搭建(Linux主機)

目錄 1. 下載并安裝Go語言2. 配置環境變量3. 驗證安裝4. 配置Go模塊5. 安裝常用開發工具6. 配置IDE&#xff08;可選&#xff09;7. 第一個Go程序 在Linux主機上搭建Golang開發環境&#xff0c;你可以按照以下步驟進行操作&#xff1a; 1. 下載并安裝Go語言 首先從官網下載Go…

MySQL安全加固:使用mysql_secure_installation

在安裝MySQL后&#xff0c;為了確保服務器的安全性&#xff0c;建議使用mysql_secure_installation工具對MySQL進行安全加固。這個工具可以幫助我們完成一些關鍵的安全配置&#xff0c;包括設置強密碼、移除匿名用戶、限制root用戶的遠程登錄以及清理默認的測試數據庫等。以下是…

設計模式之中介者模式 (Mediator Pattern) -聊天室-控制室

中介者模式用于減少多個對象之間的直接通信&#xff0c;而是通過一個中介對象來協調它們之間的交互。下面我用一個聊天室的例子來演示這個模式。 舉個栗子&#xff1a;聊天室系統 在這個系統中&#xff0c;用戶不直接相互發送消息&#xff0c;而是通過聊天室&#xff08;中介者…

SpringSecurity01

目錄 一、權限控制 二、相關框架 1、shiro 2、springsecurity 三、springsecurity使用流程 1、搭建環境實現默認用戶名和密碼登錄 2、使用數據庫表中定義好的用戶名和密碼訪問實現等值密碼匹配 1&#xff09;sql文件 2)搭建jdbc或者mybatis或者mybatis-plus環境 3&am…

解決git clone報錯:fatal unable to access xxx. Could not resolve host github.com

作者&#xff1a;唐叔在學習 專欄&#xff1a;問題百寶箱 文章目錄 問題描述問題診斷網絡連通性測試 解決方案1. 獲取GitHub最新IP地址2. 修改系統hosts文件 驗證解決方案常見問題解答總結 問題描述 當使用git clone命令克隆GitHub倉庫時&#xff0c;可能會遇到如下錯誤&#…

魔術方法__call__

__call__ 是一個特殊方法&#xff08;也稱為魔術方法&#xff09;&#xff0c;用于使一個類的實例能夠像函數一樣被調用。當定義了這個方法后&#xff0c;實例對象可以后接括號&#xff08;即 ()&#xff09;來觸發調用&#xff0c;這會讓實例表現得像函數一樣。 ?使實例可調…

PHP中的異常處理與錯誤日志記錄

在PHP編程實踐中&#xff0c;異常處理是一項至關重要的技能&#xff0c;它能夠幫助開發者識別和響應程序執行過程中發生的非預期事件。與此同時&#xff0c;錯誤日志記錄是確保應用程序可靠性和穩定性的關鍵組成部分。本文將詳細介紹如何在PHP中實現這兩個方面的技術。 首先&a…

JS去除空格(數組內字符串)

1.JS中去除空格 去除這個數組中每個對象內部參數&#xff08;也就是屬性值&#xff09;的空格&#xff0c;可以通過遍歷數組&#xff0c;再遍歷每個對象的屬性&#xff0c;使用 trim() 方法來去除字符串首尾的空格。以下是具體實現代碼&#xff1a; let data [{ designHours:…

【Spring篇01】:Bean的線程安全問題總結

文章目錄 1. 核心問題&#xff1a;Spring 框架中的 Bean 是線程安全的嗎&#xff1f;2. 最佳實踐與解決方案禁止方案&#xff1a;濫用prototype作用域推薦方案&#xff08;按優先級排序&#xff09; 3. 生產環境中的典型案例Case 1&#xff1a;訂單服務統計Case 2&#xff1a;用…

本地項目上傳git

將您本地的項目代碼上傳到一個私有的、別人看不見的 GitHub 倉庫&#xff0c;是進行云端協作&#xff08;如使用 Google Colab&#xff09;、版本控制和代碼備份的最佳實踐。這是一個非常重要的技能。 整個過程可以分為三個部分&#xff1a; 準備工作&#xff1a;在您的電腦上…

【.NET Framework 窗體應用程序項目結構介紹】

在使用 Visual Studio (VS) 開發 .NET Framework 窗體應用程序&#xff08;Windows Forms App&#xff09; 時&#xff0c;項目結構通常包含以下核心文件夾和文件。以下是詳細介紹&#xff1a; 1. 項目根目錄下的主要文件 (1) .csproj 文件 作用&#xff1a;C# 項目文件&…

【SpringAI】4.多模態提問

SpringAI多模態提問 概述 SpringAI支持多模態輸入&#xff0c;允許AI模型同時處理文本和圖像內容。這對于需要視覺理解的AI應用場景非常有用&#xff0c;如圖像描述、視覺問答、圖像分析等。 核心概念 1. Media類 SpringAI使用Media類來表示多模態內容&#xff0c;支持圖…

自動化提示工程:未來AI優化的關鍵突破

自動化提示工程:未來AI優化的關鍵突破 自動化提示工程能夠自動化或半自動化地生成或優化提示詞,以探索大規模的提示詞組合,并通過 自動優化技術提升提示詞生成的穩定性? 依據自動化提示工程實現形式在邏輯推理和效能導向 兩個維度的取舍上,將其分為基于思維鏈的自動化提示工…

多模態大語言模型arxiv論文略讀(148)

A Comprehensive Survey and Guide to Multimodal Large Language Models in Vision-Language Tasks ?? 論文標題&#xff1a;A Comprehensive Survey and Guide to Multimodal Large Language Models in Vision-Language Tasks ?? 論文作者&#xff1a;Chia Xin Liang, P…

關于.net core開發的實體所有注解詳解

以下是對 .NET Core 開發中實體類&#xff08;用于數據模型&#xff09;和 Web API 控制器/方法&#xff08;用于定義接口&#xff09;常用注解屬性&#xff08;Attributes&#xff09;的詳細說明與示例&#xff0c;涵蓋數據驗證、API 行為控制、序列化、Swagger/OpenAPI 文檔生…

【安全工具】SQLMap 使用詳解:從基礎到高級技巧

目錄 簡介 一、安裝與基礎配置 1. 安裝方法 2. 基本語法 二、基礎掃描技術 1. 簡單檢測 2. 指定參數掃描 3. 批量掃描 三、信息收集 1. 獲取數據庫信息 2. 獲取當前數據庫 3. 獲取數據庫用戶 4. 獲取數據庫版本 四、數據提取技術 1. 列出所有表 2. 提取表數據 …

Redis大Key拆分實戰指南:從問題定位到落地優化

引言 最近在項目里遇到一個棘手問題&#xff1a;生產環境的Redis突然變“卡”了&#xff01;查詢延遲從幾毫秒飆升到幾百毫秒&#xff0c;監控面板顯示某個節點CPU使用率飆到90%。排查半天才發現&#xff0c;原來是某個用戶訂單的Hash Key太大了——單Key存了100多萬個訂單字段…