資料介紹
描述
動機
FPGA 非常適合低延遲、高吞吐量的成像應用。最好使用直接與 FPGA 接口的相機(而不是 USB/網絡相機)來實現這一點。然而,對于業余愛好者、修補匠和小型初創企業來說,可用的相機模塊選項數量有限,而且并非所有可用選項都便宜(相對而言)。最重要的是,許多都有自己的物理接口,所以通常你只能將相機與它的開發套件一起使用。沒有相當大的努力,就是這樣。
然而,由于具有 15 針 FFC 攝像頭接口 (MIPI-CSI) 的 Raspberry Pi 等低成本單板計算機的普及,情況正在好轉。隨著時間的推移,RPi 相機接口變得非常流行,如今許多單板計算機都可以使用相同的相機連接器(Jetson 套件、RPi 替代板等)。甚至一些 FPGA 板現在也配備了相同的 15 針連接器(Zybo-Z7、Kria 等)。由于受歡迎程度,現在可以從各種供應商(RPi 基金會、Arducam、VEYE 等)處獲得許多低成本圖像傳感器。
不幸的是,一旦我們開始將這些圖像傳感器之一與我們的 FPGA 一起使用,我們就會遇到一個大問題:大多數圖像傳感器的數據表都是不公開的!
您會看到,在使用任何現代圖像傳感器之前,您需要根據您的用例對其進行配置。雖然高吞吐量數據通過 MIPI-CSI 等協議傳輸,但配置通常通過 I2C 進行。然而,要知道通過 I2C 接口發送什么命令需要知道傳感器的寄存器映射,以及這些寄存器的每一位的功能。但如果沒有公開的數據表,這是一個大問題。在某些情況下,如果您足夠幸運,您將能夠在互聯網上找到您的特定圖像傳感器的泄露數據表,但情況并非總是如此。例如,在撰寫本文時(2021 年 9 月),RPi“高質量”相機沒有公開的數據表。
有時即使有數據表,事情也不會太樂觀。現代圖像傳感器是復雜的硅片,配置大多數圖像傳感器需要正確設置數百個寄存器,然后才能開始以正確格式輸出正確的圖像數據。有時鐘/PLL 配置、分辨率、binning、曝光、增益、白平衡、輸出接口格式等設置。至少獲得參考或起點不是很好嗎?
所以,我們能做些什么?
“嗅探”或“竊聽”是軟件/硬件黑客中常用的一種技術。這個想法是監聽兩個設備之間的通信,而不干擾原始對話,并保持細致的記錄以備后用。我們可能不明白對話的每個部分的含義是什么,但有時我們可以重播相同的序列,并設法欺騙目標設備給我們需要的東西。
我的設置
在這種特殊情況下,我有一個我之前購買的Zybo-z7-20板,以及PCAM-5C板相機。使用Digilent 提供的運行“baremetal”的演示項目,我能夠非常快速地讓兩者一起工作。但是,對于未來的項目,我希望有更多的相機選項,而不僅僅是 PCAM-5C。許多與 RPi 接口兼容的傳感器都帶有自己的 Linux 驅動程序。我希望能夠在運行裸機時使用相同的傳感器。
我的計劃如下:
- 選擇具有匹配物理/電氣接口的相機
- 使用我需要的設置(分辨率、幀率等)讓它在它的本機平臺(RPi、Jetson 等)上工作
- 使用邏輯分析儀設置 I2C 嗅探器并記錄從處理器到相機的所有命令。
- 使用我自己的 FPGA 板進行清理、適當格式化和重播命令。
對于這個特定的實驗,我將使用我已經擁有的:- Raspberry Pi v2.1 相機- RaspberryPi 4B 作為“本機”平臺- Saleae Logic 16 pro 作為我的邏輯分析儀- Zybo-Zy-20 作為我的“目標” FPGA板。
讓我們開始吧……!
第 1 步:驗證接口兼容性
N. 從電路板的示意圖中檢查引腳配置和電壓電平。
我們可以看到連接器將為連接的相機提供 3.3V 電壓,并且 I2C 也在 3.3V 下工作。
接下來,我們看一下攝像頭模塊。從 RPi v2.1 攝像頭模塊的示意圖中,我們可以驗證引腳配置和電壓確實匹配。
您可能會注意到上拉電壓為 1.8V 而不是 3.3V,但這沒關系,因為組件 Q1 正在執行電壓電平轉換。Ctrl+C退出。注意上面使用 gstreamer 管道,這是上述命令正常工作的先決條件。
第 3 步:嗅探 I2C 通信
現在我們有了一個工作系統,下一步是嗅探 RPi 和圖像傳感器之間的 I2C 通信。首先,我使用烙鐵將三根細跳線連接到 FFC 上的接地、SDA、SCL 引腳,然后用 Kapton 膠帶覆蓋以作為連接線的機械釋放。我這樣做是因為與在焊接過程中弄亂 RPi 或攝像頭板相比,FFC 電纜便宜且易于更換。此外,這給了我一根“間諜電纜”,我也可以將其重新用于其他相機/平臺。
在此之后,我將這些電線與我的邏輯分析儀連接起來。在這一步中,我使用 USB“邏輯分析儀”來嗅探 I2C 通道上的通信。我使用的是 Saleae Logic 16 pro,因為這是我所擁有的,但任何便宜的邏輯分析儀都可以解決這個問題(I2C 的數據速率相當慢)。最后,我為 I2C 解碼配置了邏輯分析儀并點擊了開始按鈕。
現在我們有一些捕獲的數據。
第 4 步:清理和準備 I2C 數據
現在我們有了一些捕獲的數據,我們需要清理和準備數據,然后才能將其與 FPGA 板一起使用。由于我遵循的確切過程非常具體到我所擁有的設置,因此我將詳細說明每個步驟的意圖以供讀者理解。
我注意到的第一件事是有一個初始的命令突發(左),然后是另一個密集的命令突發(中),然后經過一段時間的延遲后,每隔約 15 毫秒就會有一個 I2C 命令(右)。
每 ~15ms 的命令對應于 60fps 幀之間的時間。此外,這些命令被發送到相同的 I2C 地址,并且都是寫命令。
因此,經過一些實驗后,我得出結論,這些必須是從 ISP 到相機的命令,以便在處理每一幀后根據不斷變化的照明條件(自動增益/曝光控制,可能還有自動白平衡)進行調整。這也意味著,就目前而言,我可以刪除在這些命令的第一個實例之后發送的任何數據數據,因為發送一次曝光命令就足以開始了。另外,請注意這些重復的命令被發送到 I2C 地址 0x10。因此我們可以推斷出我們相機的 I2C 地址是 0x10 。
接下來,我查看了修剪后的數據,注意到開頭有一些讀命令,還有一些寫到 I2C 地址 0x71 的命令。
由于我們不知道如何處理從讀取命令返回的數據,因此保留它們沒有意義,因此我刪除了它們。
尋址到 0x71 的命令很可能用于位于 Rpi V2.1 cam 上的 EEPROM,Raspberry pi 固件使用它來查看是否連接了正版相機,因此我們也不需要保留它們。因此我也刪除了它們。
對于轉儲的數據,我將僅提及一些細分。讓我們隨機選擇一行轉儲數據:
write to 0x10 ack data: 0x01 0x62 0x0D 0xE8
在這一行中,0x10 是相機的 I2C 地址,0x0162 是寄存器地址,0x0D、0xE8 是數據字節。通常一個寄存器是一個字節長,因此由于大多數傳感器中的 I2C 地址自動遞增功能,第二個字節實際上會轉到下一個寄存器地址 (0x1063)。
無論如何,在此之后,我將剩余的修剪數據復制到 Excel 表中,刪除除 I2C 數據之外的所有文本并對其進行格式化(通過一些手動操作),以便稍后在 Xilinx 內部將其用作 C 中的數組開發工具包。其中一部分包括在每行中添加一個包含 I2C 字節數的列,因為轉儲數據中的不同行發送的 I2C 字節數不同。
第 5 步:使用 FPGA 重放命令
現在,要使用我們的 FPGA 板測試我們的數據,我需要一個 Vivado &SDK 項目。幸運的是,我已經從 Adam Taylor 的優秀帖子中下載了一個 Vivado 項目,它為我提供了一個工作系統,以 720p60 分辨率從 PCAM-5C 相機獲取數據并通過 HDMI 輸出顯示。
接下來,我為此訪問了 SDK 項目,并添加了一個包含先前步驟中轉儲和格式化的 I2C 數據的數組,并將其設置為在啟動后發送到 v2 相機 I2C 地址 (0x10)。其余什么都不需要更改,事實上我什至將以前的 PCAM-5C 代碼留在了文件中,因為當該地址上沒有設備響應時,該地址的命令會被簡單地忽略。我還將 Adam 的 vivado 項目配置為使用 CSI 輸入(而不是 HDMI IN)作為源。包含所有修改的完整項目鏈接在帖子末尾。
完成軟件修改后,剩下要做的就是將 RPi v2.1 攝像頭連接到 Zybo-Z7 上的 MIPI 連接器,將 HDMI 電纜從 HDMI TX 端口連接到顯示器,然后上傳代碼。
。
?
我愿意稱之為成功。這證明這里采用的概念也適用于其他可用的傳感器(盡管有一些警告),并且應該為我們提供更多 MIPI 圖像傳感器選項以用于 FPGA 項目。這意味著,如果其中一個傳感器是與 FPGA 一起使用,那么我們將需要在 FPGA 中自己處理這些功能。通過在受控的光照條件變化下查看每幀后發送到相機的數據,應該可以找到相關的寄存器。另一方面,一些攝像頭模塊還帶有板載 ISP,在這種情況下,這不是問題。(看看一些來自 Arducam、VEYE 的傳感器)
- 并非所有圖像傳感器本身都支持 720p 或 1080p 等格式。因此,在某些情況下,驅動程序會將傳感器設置為在高度/寬度(或兩者)上大于用戶通過命令行請求的模式。在這種情況下,Raspberry Pi/Jetson 等內部的 ISP(圖像信號處理器)預計會將圖像裁剪為用戶請求的分辨率。這意味著如果我們使用 FPGA 來接收這個流,那么我們需要在 FPGA 內部進行裁剪。通過在水平和垂直方向上為圖像開始位置、活動像素和步幅設置適當的值,Xilinx VDMA 可輕松用于執行此裁剪,而無需任何處理開銷。
?
希望你喜歡閱讀和跟隨。下次我們可能會嘗試不同的 MIPI 傳感器(RPi HQ 相機?),看看效果如何。
如果您發現這有用(或沒有),請在下面的評論部分分享您的評論/想法!
- 用于嵌入式攝像頭模塊的PMU TPS65705x數據表
- 用于嵌入式攝像頭模塊的電源管理單元 (PMU)TPS657095數據表
- 用于嵌入式攝像頭模塊的PMU TPS65708數據表
- 嵌入式Linux的攝像頭驅動程序設計與實現
- 基于FPGA的RPi攝像頭設計 0次下載
- ESP32 AUDIO OV2640攝像頭 音頻調試日記
- 基于ARM的FPGA嵌入式系統實現
- FPGA實現嵌入式系統
- 如何使用CMOS攝像頭與FPGA實現位置檢測系統的設計 13次下載
- 手機攝像頭的MIPI接口如何通過FPGA采集 59次下載
- 如何使用DSP芯片進行嵌入式USB攝像頭圖像采集與顯示的方案說明 1次下載
- 如何使用ARM進行嵌入式監控系統的設計 7次下載
- 在嵌入式工控板上接一個攝像頭進行視頻監控 0次下載
- 基于Quick Capture 技術的攝像頭驅動方案
- CSI(攝像頭)模組資料電路圖及說明書
- 嵌入式fpga是什么意思 997次閱讀
- fpga是嵌入式嗎 1769次閱讀
- fpga與嵌入式的區別 嵌入式和fpga開發有什么關系 6053次閱讀
- 使用Zynq平臺進行嵌入式軟件和FPGA設計時有哪些挑戰 476次閱讀
- 攝像頭應用領域及應用產品型號 1358次閱讀
- 如何使用ZYNQ進行嵌入式系統設計 761次閱讀
- 使用ZYNQ進行嵌入式系統設計 833次閱讀
- 飛凌嵌入式攝像頭模塊簡介 1516次閱讀
- 飛凌嵌入式500W攝像頭介紹 2303次閱讀
- 飛凌嵌入式模擬攝像頭采集模塊介紹 2118次閱讀
- 微雪電子 樹莓派原裝攝像頭V2兼容模組介紹 2021次閱讀
- 微雪電子樹莓派原裝攝像頭V2簡介 2540次閱讀
- 銳爾威視科技夜視攝像頭簡介 2797次閱讀
- 了解基于Zynq的嵌入式系統的研究 1366次閱讀
- 基于Xilinx reVISION Stack Demo雙攝像頭采集圖像 3309次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數據手冊
- 1.06 MB | 532次下載 | 免費
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費
- 3TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費
- 5元宇宙深度解析—未來的未來-風口還是泡沫
- 6.40 MB | 227次下載 | 免費
- 6迪文DGUS開發指南
- 31.67 MB | 194次下載 | 免費
- 7元宇宙底層硬件系列報告
- 13.42 MB | 182次下載 | 免費
- 8FP5207XR-G1中文應用手冊
- 1.09 MB | 178次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33566次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21549次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6656次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537798次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191187次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183279次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多