新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > BB-Black之PRU-ICSS簡析

        BB-Black之PRU-ICSS簡析

        作者: 時間:2017-10-21 來源:網絡 收藏

          什么是

        本文引用地址:http://www.104case.com/article/201710/366971.htm

          Beaglebone Black所使用的TI芯片(XAM3359AZCZ revision 2)包含了一個主處理器和許多其他的模塊,如下圖:

          盡管ARM Cortex-A8內核的性能十分強大,但是Linux的本質決定了對于高速外部硬件的控制可能會不太容易實現。而TI的這款芯片添加了兩個額外的CPU(稱為或PRUSSv2,即可編程實時單元和工業用通信子系統,以后簡稱PRU),從而使這個問題得到了改善。這意味著這兩個CPU可以分別運行不同的軟件,以便減輕底層協議在硬件接口和處理上的工作量。

          這款芯片就好像具有Arduino類似功能的處理器,只不過其額外的兩個CPU工作頻率要高出許多,達到200MHz,也就是說在許多情況下可以不再需要外部邏輯器件、CPLD或者FPGA。

          通常來說,針對一個以上的處理器進行編程是一件麻煩事,而且處理器之前還需要有通信協議。而TI的這款芯片則極大的簡化了這種麻煩,原因有兩點,一是用于PRU的代碼可以從主處理器下載,二是為了方便處理器之間通信,芯片集成了共享存儲器。

          PRU的作用體現在哪兒?

          對于低速通信來說,傳統的I2C或者常用的協議就已經足夠應付了,因此PRU在這些地方并沒有用武之地。而對于高速通信PRU可能會非常受歡迎,這是因為PRU能夠消除由于Linux環境切換所造成的中斷,從而連續對硬件提供服務,也不會對ARM主處理器造成負擔。這里有一些常見的并且可行例子;

          • 連接到高速ADC(例如模擬信號捕捉)

          • CCD 或者CMOS攝像機

          • LED或者LCD顯示器

          • 生成模擬視頻信號(視頻編碼器)

          • 自定義PWM或者其他自定義協議或非標準協議

          • 帶反饋的電機控制

          據我所知,PRU甚至能夠用某個外部時鐘來作為并行數據的時鐘。

          如何使用PRU?

          當前來說使用PRU即不簡單也不算困難。主要的難度在于在網上找到完整的實例。這里提供的內容就是從網上收集而來的。

          主要步驟如下:

          1. 在上使能PRU系統

          2. 將PRU匯編程序安裝到BBB上(當前用于PRU的代碼是都是用匯編寫的,還沒有人開發出這對PRU的C編譯器)

          3. 編寫代碼。PRU應用程序分為兩部分,而且相互之間能夠通過存儲器尋址來進行通信,即

          (a) 匯編代碼,編譯為.bin機器指令文件,以便在PRU上運行

          (b) C語言代碼,運行于主處理器上,也就是Linux系統上。這些代碼負責將匯編代碼下載到RPU

          4. 配置Linux設置樹,啟用所有引腳用于輸入輸出

          5. 運行程序

          PRU使用什么樣的匯編代碼?

          還好寄存器數量很給力(都是32位),而且指令都是正交的,另外用于操作的位和字節參考都相當令人滿意,所以相對而言,比起某些常見的匯編語言,例如針對PIC或其他8位處理器的匯編來說,PRU使用的匯編代碼算是比較容易上手的了。匯編命令數量并不多,目前為止我只使用了大約45條命令中的一小部分,結果還不錯。(通常本人不愿意為了某個不太好用的處理器花太多時間學習匯編 – 但RPU完全不同,其指令集貌似很好用的樣子)

          PRU是否物有所值?

          我覺得答案是肯定的,應為有了PRU就能夠在高速狀態下控制硬件(比如50MHz)。每條指令在PRU上只需要5納秒的執行時間(200MHz頻率,每條指令占用一個周期),并且不存在由于Linux內核造成的不規則延遲。

          難點在哪兒?

          難點主要在于和設備樹相關的東西。希望在未來能夠有所變化或者變得更簡單。在一個典型的微控制器上,輸入輸出的設定是用特定的寄存器完成的,這些寄存器存在于某個設備的某一部分存儲映射中。據我所知,當前運行在上的軟件不允許用戶通過傳統的C代碼對這些硬件寄存器進行直接的修改操作。當前采用的方法叫做“設備樹”。它是一個文本文件,并且被壓縮成為二進制文件,在系統啟動時需要對其進行讀操作。該文件高速系統哪些是用于輸入輸出的引腳。設備樹的修改也適用于使能RPU系統。

          有人曾經通過設備樹關閉了上默認閃爍的LED燈。設備樹文件位于BB-Black的/boot目錄下,是一個二進制文件,其內容自然無法看懂(如下圖),通常文件名為.dtb或者.dtbo。



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 阿尔山市| 珲春市| 长阳| 台湾省| 雅江县| 乐平市| 安康市| 武乡县| 寻乌县| 会昌县| 德化县| 蒙山县| 东源县| 五莲县| 涿州市| 新闻| 阿克陶县| 大同市| 班戈县| 赤壁市| 安乡县| 梨树县| 沧源| 南宁市| 准格尔旗| 杭锦旗| 清镇市| 清流县| 通海县| 胶南市| 纳雍县| 芜湖市| 巫溪县| 治多县| 双辽市| 宿州市| 衡阳市| 班戈县| 江达县| 施甸县| 会泽县|