再談fpga開發(fpga開發的幾個差異)

【 聲明:版權所有,歡迎轉載,請勿用于商業用途。 聯系信箱:feixiaoxing @163.com】

? ? ? ? 學習嵌入式的同學都知道,嵌入式一般分成這幾種chip,有51,有stm32 mcu,有soc,有dsp,有gpu,有npu,最后一種就是fpga。有的最后是單獨賣,有的需要一個上位機。前面幾種一般就是軟件編程為主,應用也比較廣,只有最后一種fpga,它的使用和前面幾種差異很大,聽說過的人多,用的人少。今天正好來聊一聊。

1、fpga的基礎是時鐘、復位和信號

? ? ? ? 如果是軟件開發,大部分都是c語言開發,少部分是c++開發。既然是軟件開發,那就是我們寫好軟件之后,由編譯器和鏈接器生成二進制代碼之后,送到flash里面,等著被cpu執行。不管這個cpu屬于51、arm、還是dsp,它都是一條一條去執行的。所以軟件執行的基礎是匯編指令。

? ? ? ? 但是fpga不同,它的基礎是一個、一個的數字信號。從顆粒度來說,它要比純軟件細很多。基本上每一個外設,每一個接口都需要去詳細設計,當然這個過程中也可以使用廠家提供的ip,或者是sample code。每一個fpga工程都有一個top module,這個top module中除了clk、rst,剩下來就是各種外設,包括gpio、sdram、lcd、camera、spi、iic等等。這里說的是,相比較純軟件的芯片,fpga本身更接近硬件一點。

2、fpga的并發問題

? ? ? ? 和軟件一條一條去執行不同,fpga天生就是并發的。當然,我們也可以說,多核cpu也可以并發執行。不過這種并發和fpga比起來,還是小巫見大巫。因為fpga,本身設計的時候,就是讓所有的register在一個clock下面,并發運行,這是它的基因決定的。

? ? ? ? 至于是不是所有的register,真的每一個時刻都要去變更,這個真不一定。首先,我們會切分成不同的module,每一個module都是獨立的狀態機。module里面,如果復雜程度比較高,還會繼續切分成子模塊。另外,對于每一個module而言,如果register之間相互依賴,那么即使是并發的fpga,也會變成順序執行的形式,這個時候就和mcu開發是一樣的了。

3、fpga的demo居然和mcu demo一致

? ? ? ? fpga具有天生的并發特性,不過大家在學習和開發買板子的時候,卻發現這樣一個事實。那就是fpga的demo例子居然和mcu是一樣的,也是從點燈、串口、定時器、spi、iic、ddr、屏幕這些開始,最后以一個小的工程收尾。這個時候大家就會很疑惑,既然fpga學的內容和mcu一致,而且fpga是并發思維,調試也不好調試,價格上也沒有優勢,為啥自己還要學習fpga?

4、價格問題

? ? ? ? fpga本身是很壟斷的行業,之前都是國外壟斷,尤其是xilinx、altera和lattice三家公司,基本占據了全部的市場。現在慢慢的國產fpga起來了,尤其是中低端領域,國產fpga也開始展露頭腳。不過和mcu相比較,fpga的整體價格還是偏貴,資源密集度也少。一般的mcu或者是soc板子,最便宜的十幾塊、二十幾塊就可以,fpga雖然說現在便宜一點了,最便宜的也要上百塊,更不要說動則上千、幾千的fpga了。

5、實際落地場景問題

? ? ? ? 從實際應用來看,fpga的應用還是在兩個領域比較多。一個是希望用fpga做多接口的電路。比如一個mcu、soc,它的某種接口,例如spi、iic都是數量有限的,但是fpga幾乎是全能的,做成什么接口都可以,數量沒有限制。還有一種就是算法加速,特別是那種高帶寬、低復雜度的算法。這種情況,特別適合cpu采樣、fpga做預處理、接著cpu完成算法的場景,很多cpu+fpga的soc就是這么做的,以前可能只有zynq,現在很多國產的fpga廠商也開始支持這種模式了。圖像就是fpga應用最合適的場景之一。

6、廠家的支持

? ? ? ? 大家使用fpga的時候,最好得到原廠的幫助,這樣會快很多。不光fpga可以用ide開發,做一些簡單的pll、fifo、ram、rom、乘法器、dma這些,還可以利用原廠的資源,獲取pcie軟核、mac軟核,以及數量不低的sample code,這些都可以改一改就可以用在自己的產品上的。我們學習的時候,是需要一行代碼一行代碼去寫,實際應用,最好還是建立在廠家的sample code基礎之上去開發、去應用。

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

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

相關文章

Kafka運維實戰 11 - kafka查看消息的具體內容【實戰】

目錄kafka 消息查看1. 直接查看日志文件內容步驟:2. 使用 Kafka 工具查看日志主要參數說明常用命令:輸出說明:3. 注意事項kafka 消息日志文件詳解我們有時候遇到這樣的需求,需要查看下kafka消息的內容。 kafka 消息查看 查看 Ka…

【自動化測試】JMeter+Jenkins自動化接口與性能測試環境部署指南

環境準備與基礎配置 軟硬件環境要求 工具鏈安裝部署 工具鏈安裝部署涉及JDK、JMeter、Jenkins等核心組件,其在Linux與Windows環境下的安裝流程存在顯著差異,企業級部署需重點關注靜默安裝、權限控制及數據備份配置。以下從組件安裝差異、企業級部署要點及備份配置三方面展開…

三步實現Android系統級集成:預裝Google TTS + 默認引擎設置 + 語音包預緩存方案

在定制Android系統時,預裝Google TTS引擎并實現開箱即用的語音服務能顯著提升用戶體驗。本文將詳解預裝APK→設為默認引擎→語音包預緩存的實現方案,適用于ROM開發者或系統定制場景。分步實現方案 預裝Google TTS APK 預裝APK這里可以采用很多種方式&…

Python基礎學習第三課:數據結構與文件操作

以下是Python基礎學習第三課的完整內容,重點講解數據結構(列表、字典、元組、集合)和文件操作,通過實例演示如何高效管理和操作數據:Python基礎學習第三課:數據結構與文件操作一、課程目標1. 掌握四種核心數…

【PHP 流程控制完全指南】

PHP 流程控制完全指南🧠 一、什么是流程控制? 在編程中,流程控制是指控制程序執行順序的語句。它決定了代碼是“從上往下執行”,還是“根據條件跳轉”,或者“循環執行某些代碼”。 PHP 中的流程控制語句主要包括&#…

Kafka運維實戰 05 - kafka 消費者組和重平衡(Rebalance)

目錄什么是消費者組?消費者組如何工作?位移(Offset)消費者組的核心機制:重平衡(Rebalance)觸發條件重平衡影響在消息隊列(如 Kafka)的世界里,消費者組是實現高…

Mysql-UDF提權

UDF(User Defined Function) 是用戶自定義函數,是 MySQL 支持的一種機制,可以通過 C語言寫動態鏈接庫(.so / .dll),然后讓 MySQL 調用這些函數,調用方式與一般系統自帶的函數相同&am…

車規級CANFD芯片在汽車車身控制方案中的應用解析

摘要:隨著汽車電子技術的不斷發展,汽車車身控制系統對信息傳輸的效率、可靠性及抗干擾能力等要求日益提高。車規級CANFD芯片作為一種先進的通信芯片,憑借其高速率、高可靠性以及強大的抗干擾能力,成為汽車車身控制系統中的關鍵組件…

docker desktop 訪問 https://registry-1.docker.io/v2/ 報錯問題解決

win11 docker desktop 配置國內鏡像加速器 1、win11管理員運行powershell notepad "$env:APPDATA\Docker\config.json"2、配置以下內容保存 {"registry-mirrors": ["https://hub-mirror.c.163.com","https://docker.mirrors.ustc.edu.cn&qu…

LLaMA-Factory微調教程1:LLaMA-Factory安裝及使用

文章目錄 環境搭建 LLaMA-Factory 安裝教程 模型大小選擇 環境搭建 Windows系統 RTX 4060 Ti(16G顯存) python 3.10 cuda=12.6 cudnn torch== 2.7.1+cu126 torchvision==0.22.1+cu126 torchaudio== 2.7.1+cu126 PS C:\Users\18098> nvidia-smi Tue Jul 22 01:52:19 2025 +…

Oracle數據庫索引性能機制深度解析:從數據結構到企業實踐的系統性知識體系

一、數據檢索的根本問題與索引產生的必然性 1.1、數據檢索的本質挑戰 在理解Oracle索引的性能優勢之前,必須回到數據檢索的根本問題。當面對海量數據時,傳統的線性搜索(Sequential Search)面臨著不可調和的性能瓶頸。這種瓶頸源于…

c#面向對象程序設計

一、面向對象與面向過程的核心區別(概念鋪墊)代碼背景開篇對比了兩種編程范式:面向過程(PP):按步驟分解問題(如 “輸入長→輸入寬→計算面積”);面向對象(OOP…

Kylin V10 4070安裝nvidia驅動+CUDA+docker安裝

目錄 1.系統版本信息 2.安裝nvidia驅動 3.CUDA安裝 4.docker離線安裝 1.系統版本信息 查看一下系統版本,命令為: cat /etc/kylin-release2.安裝nvidia驅動 編輯/usr/lib/modprobe.d/dist-blacklist.conf文件 blacklist nvidiafb加#號注釋掉 添加…

首家!數巔AskBI通過中國信通院數據分析智能體專項測試

近日,在中國信息通信研究院組織的數據分析智能體(Data Agent)專項測試中,數巔生成式分析智能體AskBI順利完成專項測試的全部內容。《數據智能體技術要求》標準及測試簡介中國信通院云計算與大數據研究所依托中國通信標準化協會大數…

一些Avalonia與WPF內容的對應關系和不同用法

UIElement、FrameworkElement和ControlWPFAvaloniaUIElementControlFrameworkElementControlControlTemplatedControl在 WPF 中,通過繼承 Control 類來創建新的模板控件,而在 Avalonia 中,從 TemplatedControl 繼承。在 WPF 中,通…

【REACT18.x】CRA+TS+ANTD5.X封裝自定義的hooks復用業務功能

模擬react中的hooks方法,實現自定義的hooks來封裝我們需要重復使用的組件,來優化代碼。這種hooks也是利用了react的原生hooks來實現我們需要的特定業務,可以返回任何我們需要的值,也可以不返回值,作為一個副作用方法使…

Vue CSR 到 Nuxt 3 SSR 遷移:技術實現與問題解決實錄

1. 遷移動機與技術選型1.1 CSR 架構的局限性 基于 Vue 3 和 Vite 構建的客戶端渲染 (CSR) 單頁應用 (SPA) 提供了良好的開發體驗和用戶交互流暢性。但是其核心局限在于:搜索引擎優化 (SEO):初始 HTML 響應僅包含一個根 div 元素,實際內容由 J…

FastGPT + Kymo:解鎖企業專屬知識庫與智能體開發新體驗

在信息爆炸的時代,企業如何讓知識“活起來”?傳統文檔庫和搜索框早已無法滿足需求。FastGPT——基于RAG技術的開源知識庫系統,正重新定義企業級知識管理! 一、FastGPT是什么? FastGPT是企業構建專屬知識庫的智能核心…

人形機器人_雙足行走動力學:Maxwell模型及在擬合肌腱特性中的應用

一、Maxwell模型及其在擬合肌腱特性中的應用Maxwell模型是經典的粘彈性力學模型之一,由彈簧(彈性元件)和阻尼器(粘性元件)串聯組成。其在生物力學領域的應用主要聚焦于材料的動態響應(如應力松弛和蠕變&…

「iOS」——KVC

源碼學習iOS底層學習:KVC 底層原理一、核心 API 與功能特性**常用方法**KVC 設值 底層原理KVC 取值 底層原理自定義KVC設值取值**特性:無隱私訪問****原理**四、多元應用場景1. **動態數據處理**(1)字典轉模型(2&#…