精密PCB製造、高頻PCB、高速PCB、標準PCB、多層PCB和PCB組裝。
PCB科技

PCB科技 - 為什麼嵌入式開發人員應該使用FPGA

PCB科技

PCB科技 - 為什麼嵌入式開發人員應該使用FPGA

為什麼嵌入式開發人員應該使用FPGA

2021-08-17
View:484
Author:IPCB

在裡面 一 領域, 如果 這個 只有 常數 是 改變, 然後 那裡 是 不 需要 到 回顧 這個 發展 和 變化 屬於 電子的 科技 和 設計 方法 到 目擊者 怎樣 變化 使可能 設計 工程師 到 創造 這個 下一個 一代 屬於 創新的 產品. 之後 這個 大規模的 應用 屬於 微處理器, 新 廉價的 和 高品質 科技 有 開的 這個 門 到 這個 設計 屬於 創新的 基於軟件 電子的 產品. 這 是 一 好的 實例. 在裡面 短的, 之後 正在傳輸 這個 主要的 要素 屬於 設計-在這裡 是 這個 控制 “智慧”-進入 這個 軟的 領域, 設計 工程師 可以 創造 較好的, 更聰明的, 和 更便宜的 產品 在裡面 一 更短的 時期 屬於 時間.


這一變化意味著嵌入式軟體發展人員是當今電子產品功能和特性定義的主要驅動因素,並最終將生產硬體。 這種方法的成功因素在於降低硬體複雜性,以及將設計的控制元件轉換為可程式設計現場所帶來的開放靈活性。


今天, 這個 到達 屬於 高容量, 低成本 可程式設計 設備 有 帶來 這個 相同的 希望 到 這個 發展 屬於 電子的 產品 <一 href="一_href_0" t一rget="_bl一nk" t它le="pcb 設計">設計, 因為 它 有 成為 可能的 到 def在裡面e 這個 系統 h一rdw是 它本身 在裡面 這個 s屬於t 領域. 大規模 設備 這樣的 像 大容量的 FPGAs 是 完美的 對於 會議 這 dem和. 這個se 時期 可以 通常地 是 習慣於 到 建築 大的 部分 屬於 這個 系統 周邊設備 思維方式 作用 阻礙, 包括…在內 公共汽車 介面, 我/O 阻礙, 和 即使 記憶力. 這個 介紹 屬於 一 大的 數量 屬於 思維方式 在裡面到 這個 FPGA 領域 有 一 pr屬於ound 影響 on 硬體 發展 和 打開s 這個 門 到 一 新 時代 屬於的屬於t' 設計, 哪一個 提供 前所未有的 靈活性 對於 設計 和 有 無限的 潜在的 到 减少 板 大小 和 複雜性 .


儘管它有可能徹底改變電子產品開發過程,但大多數嵌入式軟體發展人員仍然像以前一樣在設計過程開始時選擇離散硬體處理器,創建物理平臺,然後使用該平臺編寫軟件。 人們在嵌入式系統開發的“軟”和硬體領域缺乏探索,主要是因為缺乏C程式師在可程式設計硬體級別使用技能的工具。 事實上,當前大多數FPGA設計流程主要來自晶片設計領域,需要非常專業的技能。

將軟設計提升到新的水准


To 去 超過 FPGA 膠 思維方式 一pplic在ions 要求s 一 更廣泛的 v是ion, 包括…在內 製作 滿的 使用 屬於 可程式設計 設備 和 介紹 像 很 硬體 像 可能的 進入 這個 軟的 do主要的. 這 包括 這個 介紹 屬於 過程或 功能 這個mselves. 今天, s屬於t 處理器 在裡面 FPGAs 是 在裡面cre像在裡面gly 存在 tr一ns對於med 在裡面到 嵌入的 站臺s. 從根本上講 講話, 切換 到 一 s屬於t 過程或 具有 FPGA 將 帶…到某處 這個 優勢 屬於 結構的 靈活性, 更小 板 大小, 和 更簡單. 但是 更深的 一pplic在ions 將 帶…到某處 更多 有吸引力的 優勢.


當FPGA的可程式設計特性用於在處理器頂部獲得抽象層時,它為嵌入式開發人員提供了無限的可能性,不僅可以在軟件上實現抽象層設計,還可以在硬體上實現抽象層設計。 設想一個系統,其中處理器通過可配置硬體(本質上是一個硬體包)連接到其記憶體和周邊設備-這抽象了處理器的介面。 只需對FPGA重新程式設計即可更改硬體包,系統設計者可以輕鬆更改處理器覈心,甚至在硬處理器和軟處理器之間切換,而無需修改其他系統硬體。 從系統的角度來看,所有處理器都是相似的,這簡化了硬體設計過程。 當然,將其擴展到應用軟體領域還需要一個能够在處理器之間提供C級相容性的編譯器。


該系統的優點是無需“提前”選擇處理器。 該系統可以使用特定的處理器進行開發,但開發階段發現,需要更高的效能,並使用更快的設備。 由於包裝層的原因,處理器可以是軟的、硬的,甚至是FPGA內部的硬體處理器覈心,而不會影響周圍的硬體,因為轉換層只創建用於連接周邊設備的標準介面。 事實上,周邊設備本身的連接可以用同樣的管道抽象。 在該方案中,FPGA為嵌入式系統的所有組件提供了通用的連接,並有效地成為系統互連結構。 換句話說,它有效地成為標準介面的“主幹”,硬體和軟件都可以輕鬆地與處理器和周邊設備通信。


最後,在處理器上引入透明包裝器將創建一個基於FPGA的開發環境,提供真正的處理器獨立性。 軟件和硬體開發的速度提高了,處理器的選擇可以在設計過程的後期進行,有效的軟件/硬體協同設計成為可能。

在軟件和硬體之間轉換


在可配置硬體中創建處理器和週邊包裝層的想法的擴展是自動生成特定於應用程序的系統硬體,並在硬體中執行軟件算灋,這是一種“自己的”硬體輔助處理器。


從C程式碼直接生成硬體的想法並不新鮮。 已經實施了幾個系統。 現時的想法是通過類C語言創建一個完整的系統硬體。 本質上,這與使用HDL(如VHDL語言或V呃ilog)設計FPGA沒有什麼不同,這要求軟體發展人員學習並採用新的設計方法。 對於嵌入式開發人員來說,真正有效的是使流程透明。 設計工具必須能够處理標準ANSI標準 C程式碼的輸入,並將程式師選擇的功能轉換為硬體。 不僅如此,系統還必須能够生成使用生成的硬體所需的所有程式碼。 通過這種管道,嵌入式程式師將專用算灋從處理器轉移到專用硬體,而不知道底層硬體的任何設計細節。


充分發揮FPGA的潜力


顯然,從工具的角度來看,充分利用可程式設計器件(如FPGA)提供的機會需要一個提高開發過程抽象級別的系統,以便通過類似的設計科技和過程輕鬆更改設計的覈心元素。 這樣一個系統必須能够統一整個電子產品開發過程,並在單一、一致的環境中集成硬體、軟件和可程式設計硬體的開發。

圖形 1. T一k在裡面g 滿的 有利條件 屬於 FPGA's 潜在的 方法 br在裡面g在裡面g 全部的 元素 屬於 這個 <一 href="一_href_0" 目標="_bl一k" t它le="pcb 設計">設計 (在裡面clud在裡面g 硬體 和 軟件) 到 這個 re可程式設計 領域.


海拔高度 設計師 介紹 一 易於理解的, high-數量 加工機 到 實現 這 球門, 會議 軟件, FPGA 和 印刷電路板 要求, 和 an 綜合d 產品 發展 環境 那個 集成 全部的 必修的 過程es 在裡面 a 僅有一個的 應用 (圖形 1). Hardw是 和 軟件 發展 是 統一的 在 這個 站臺 數量, 製作 迅速的 s屬於tw是/硬體 co公司-設計 可能的. 具有 FPGA-基於 處理器 和 加工機-wrapped 果心s, 設計ers公司公司 可以 target 海拔高度 設計師 或 任何 s向上的p或ted 協力廠商 加工機, 雖然 保留 全部的 這個 特色s 屬於 這個 設計, 包括…在內 e像y 聯系 到 FPGA 周邊設備. 海拔高度 設計師的 Viper-b像ed 編譯器 擔保 C級 密碼 相容性 在…之間 全部的 加工機 架構(architecture) 支持 通過 這個 系統.


除了具有快速產品開發的潜力外,海拔高度 設計師的集成特性還為嵌入式開發人員帶來了新的設計和功能可能性。 海拔高度還開發了一種新的集成硬體/軟件編譯器科技,該科技不久將得到海拔高度 設計師的支持。 該科技同時從標準C程式碼生成高度優化的可執行程式碼和並行硬體FPGA實現,並生成運行時將兩者連結在一起所需的程式碼。 實際上,這意味著開發人員可以指定從處理器卸載到硬體的C程式碼功能,海拔高度 設計師的集成軟件/硬體環境使該過程快速透明(圖2)。

ATL

圖2:。 借助先進的軟體工具,嵌入式開發人員可以在成為硬體工程師後影響、修改和調試底層系統硬體。


此類系統為嵌入式開發人員提供了選擇系統核取方塊的選項,以便在將專用軟體功能轉移到硬體時獲得最終效能和成本改進的潜力。 這使開發人員能够在硬體和軟件之間有效地傳遞功能,並繼續在優化的應用程序解決方案上進行集成。 值得注意的一個有趣現象是,使用海拔高度 設計師的此功能和其他高級功能(如嵌入式包覈心和基於庫的預同步軟件組件)的軟體發展人員可以有效地使用FPGA機制內的硬體。 簡而言之,使用該系統的軟體工程師可以利用他們現有的技能輕鬆使用FPGA硬體,而不涉及目標設備的底層結構或RTL公司程式設計(圖3)。

ATL

圖形 3, 這個 integr在ion 屬於 這個 設計 流 包括…在內 硬體, 可程式設計 硬體, 和 軟的ware en能够的s FPGA 設備 到 是 已利用 和 創造 完成 嵌入的 系統s, 和 th是 要求 只有 常見的 tech不logies.


海拔高度 Designer的整合式開發環境和低成本大規模FPGA的結合,使嵌入式開發人員能够充分利用可程式設計設備的潜力。 在使用正確的開發環境後,當前FPGA帶來的巨大可重構設計空間使一種新的嵌入式設計方法成為可能,設計師可以像幾十年前一樣,為電子產品的開發帶來革命性的創新。 處理器的引入徹底改變了電子行業。