www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 電源 > 數(shù)字電源
[導讀]達芬奇(DaVinci)數(shù)字媒體技術平臺TMS320DM6446/3采用了ARM+DSP雙核的架構,本文從芯片的硬件結構入手介紹達芬奇DMSoC硬件部分及Linux OS的啟動過程。達芬奇DMSoC硬件概述如圖1所示,達芬奇數(shù)字媒體片上系統(tǒng)(DMSoC

達芬奇(DaVinci)數(shù)字媒體技術平臺TMS320DM6446/3采用了ARM+DSP雙核的架構,本文從芯片的硬件結構入手介紹達芬奇DMSoC硬件部分及Linux OS的啟動過程

達芬奇DMSoC硬件概述

如圖1所示,達芬奇數(shù)字媒體片上系統(tǒng)(DMSoC)提供:兩個內核(ARM+DSP);視頻處理子系統(tǒng)(VPSS);多種Boot模式(NOR Flash/NAND Flash/UART0 Boot Mode);兩個電源域;多個時鐘樹;多個引腳獨立或復用的外設。


圖1 DM6446功能結構框圖。

> ARM-DSP集成

對于雙核的達芬奇架構,大家最關心的就是兩個核之間的資源分配、通信方式及如何高效地實現(xiàn)資源共享各盡其能。ARM獨享(DSP不可用)的外設有: UART0/1/2,I2C,看門狗定時器,PWM0/1/2,ARM中斷控制器,USB2.0,ATA/CF,SPI,GPIO,VPSS, EMAC/MDIO,EMIFA CONTROL,VLYNQ,MMC/SD。DSP獨享(ARM不可用)的外設有:DSP中斷控制器,VICP。ARM和DSP共享的外設有:EDMA, Timer0/1,Power & Sleep Controller,ASP和EMIFA Data。


圖2 ARM-DSP集成結構。

如圖2所示,可以很清楚地看到ARM可以訪問DSP片內存儲器(L2RAM和L1P/D);DSP可以訪問ARM片內存儲器;ARM和DSP共享 DDR2和 AEMIF。因此,通常情況下ARM只需傳遞需要處理的數(shù)據(jù)地址指針給DSP,而無須大塊的數(shù)據(jù)搬移。ARM和DSP之間的通信可以通過相互中斷實現(xiàn)。 ARM可以中斷DSP(通過4個通用中斷和1個不可屏蔽中斷);DSP可以通過2個通用中斷來中斷ARM。ARM控制DSP的電源、時鐘、復位和引導。

> DMSoC存儲器映射

達芬奇DMSoC多個片上存儲器和兩個處理器及不同的子系統(tǒng)相關。為了簡化軟件開發(fā),DMSoC中所有的存儲器統(tǒng)一編址,如表1所示。


表1 DMSoC存儲器的映射地址。

[!--empirenews.page--]

DMSoC交換中心資源

以上大家看到DMSoC有非常豐富的外設和視頻處理硬件資源,而且ARM和 DSP又共享DDR2等存儲器資源,那么DMSoC又是如何確保ARM、DSP和VPSS同時訪問外設或存儲器資源時不會引起沖突呢?DMSoC中的交換中心資源(SCR:Switched Central Resource)會做出管理。如圖3所示,把任何一個發(fā)起數(shù)據(jù)傳輸?shù)脑捶Q為Master(每一個Master有一個專用的ID),這個Master要訪問的目的地稱為Slave,這樣在Master和Slave之間就構成一條數(shù)據(jù)傳輸?shù)耐?。從圖3中可以看到,在SCR中可以有很多并行的Master到 Slave的數(shù)據(jù)通路。如果是不同的Master、相同的Slave,那么可以通過設置每一個Master的優(yōu)先級來得到特殊應用系統(tǒng)的最佳性能。對于大多數(shù)的Master,可以通過寄存器MSTPRI0和MSTPRI1來設置它們的優(yōu)先級。如果Master是C64x+、VPSS和EDMA,可以通過它們自己的相關寄存器控制它們自己的優(yōu)先級,這樣可以更加靈活、快速的實現(xiàn)高的視頻數(shù)據(jù)吞吐帶寬。詳細信息可以參考DM6446的數(shù)據(jù)手冊。


圖3 DMSoC交換中心資源的結構框圖。

電源域及復位

達芬奇DMSoC有兩個電源域,分別是Always On域和DSP域。Always On域由CVDD ARM核電源供電,給ARM、總線、SCR和除VICP之外的所有外設提供電源;DSP電源域由CVDDDSP DSP核電源供電,給DSP和VICP提供電源。

雙核架構的達芬奇DMSoC的功耗也非常有競爭力,這一方面取決于芯片本身的工藝,另一方面也取決于芯片內部時鐘和電源的結構。如圖4所示,達芬奇 DMSoC有電源休眠控制器(Power & Sleep Controller)管理芯片電源的開關及復位。可以用軟件控制DSP電源域,控制DSP及其模塊時鐘的開關和復位。PSC不支持ARM及其模塊的斷電控制、ARM的本地復位和ARM的時鐘關斷控制。同時PSC可以中斷ARM和DSP,支持IcePick仿真(emulation)特性。


圖4 DM6446的電源休眠控制器。

[!--empirenews.page--]

關于達芬奇DMSoC的復位類型、觸發(fā)源及對應的復位對象請參考表2。


表2 DMSoC的復位類型。

達芬奇DMSoC初始化流程

> 達芬奇DMSoC復位狀態(tài)

DM644x 上電復位后,芯片的絕大部分模塊都處于不工作狀態(tài)。鎖相環(huán)PLL處于旁路(Bypass)模式;DSP子系統(tǒng)的狀態(tài)取決于DSP_BT引腳;UART1和 UART2也處于不工作狀態(tài),UART0的狀態(tài)取決于BTSEL引腳(如果BTSEL=11,UART0工作);EMIFA處于工作狀態(tài),其數(shù)據(jù)總線寬度由EM_WIDTH決定,地址總線寬度由AEAW決定;芯片的大部分引腳都被配置為GPIO引腳。引腳復用通過寄存器PINMUX0和PINMUX1控制。

> 達芬奇DMSoC初始化順序

(1)DMSoC復位。芯片的配置由PSC決定,取決于BTSEL[0-3]、EM_WIDTH、AEWA和DSP_BT的狀態(tài)。

(2)ROM boot loader(如果被選)。NAND或者UART0的初始化。

(3)引導加載(Boot-loading)。以U-boot為例,①使能電源域:DDR2和DSP;②設置時鐘頻率(ARM、DSP和DDR2時鐘的乘除系數(shù));③設置引腳復用控制器;④設置ARM引導啟動操作系統(tǒng)。

(4)操作系統(tǒng)啟動。以Linux為例,①初始化ARM;②初始化硬件系統(tǒng);③初始化Linux環(huán)境。

> U-boot初始化順序

通常情況下,ARM Linux要求boot loader中有少許的初始化。目前TI的DVEVM使用的是U-boot-1.1.3。U-boot代碼中首先運行的是u- boot/cpu/arm926ejs/start.S,芯片和一些DVEVM板的硬件配置主要在u- boot/board/davinci/platform.S和davinci.c中完成。其中u- boot/board/davinci/platform.S設置最基本的系統(tǒng)硬件環(huán)境,包括系統(tǒng)PLL及DDR2的初始化、PSC的配置及使能 UART0、AEMIF等硬件模塊。有些工程師設計的達芬奇板可能用到了和DVEVM不同的Flash,那么就要根據(jù)用到的Flash參數(shù)修改u- boot/board/davinci/flash.c。另外,關于DM644x支持的NAND Flash ID,請參考TMS320DM644x DMSoC的相關文檔。

以NOR Flash boot為例,DVEVM u-boot初始化下列的達芬奇DMSoC內容:

(1)關中斷和MMU。

(2)使能DSP電源域(PTCMD),把DSP置為復位狀態(tài)。

(3)初始化PLL,使能DDR2,軟復位DDR2并且重新使能DDR2,使其脫離復位狀態(tài)。

(4)初始化系統(tǒng)PLL。

(5)配置AEMIF引腳為NOR Flash接口。

(6)VTP校準。

[!--empirenews.page--]

完成以上步驟之后,U-boot準備引導ARM Linux。

(1)配置系統(tǒng)的內存(通過ATAG_ MEM塊和mem=)NAND Flash和DDR2。

(2)通過TFTP加載等加載方式,加載內核到指定的存儲地址。

(3)如果定義過,加載RAM Disk。

(4)初始化傳遞到內核的引導參數(shù)(EMAC地址,串口,控制臺,視頻格式等)

(5)獲得ARM Linux機類型值(DVEVM為#901)。

(6)設置kernel tagged list。

(7)用初始值設置ARM的寄存器。

(8)調用內核。

> Linux 初始化步驟

(1)Linux內核需要從引導加載程序(U-boot)中得到以下參數(shù)。

* 已經初始化的memory系統(tǒng)。

* R0=0;R1為ARM Linux機類型值。

* R2指向ATAG結構體的內容:①物理memory區(qū);②是否使用RAM DISK及其壓縮版的地址;③視頻驅動程序具體的初始化參數(shù);④內核命令行;⑤其他參數(shù)(串口和版本號)。

更多關于Linux內核引導參數(shù)的信息可以參考Linux/Documentation/kernel-parameters.txt。如果要想傳遞給內核更多的參數(shù),再u-boot中的bootargs中設置就可以了。

(2)對于壓縮的內核(aka uImage),Linux 最初啟動Linux/arch/kernel/head.s。

(3)start_kernel()運行。位于Linux/init/main.c。

(4)Linux的第一個進程init()運行。

總結

經過上面介紹,很多DSP工程師可能會對達芬奇DMSoC及Linux啟動流程有一個感性的認識,雙核架構的達芬奇DMSoC帶給我們的是一加一大于二的性價比,要想了解更多的細節(jié),請參考數(shù)據(jù)手冊和應用文檔。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

CPU親和度通過限制進程或線程可以運行的CPU核心集合,使得它們只能在指定的CPU核心上執(zhí)行。這可以減少CPU緩存的失效次數(shù),提高緩存命中率,從而提升系統(tǒng)性能。

關鍵字: Linux 嵌入式

在Linux系統(tǒng)性能優(yōu)化中,內存管理與網絡連接處理是兩大核心領域。vm.swappiness與net.core.somaxconn作為關鍵內核參數(shù),直接影響系統(tǒng)在高負載場景下的穩(wěn)定性與響應速度。本文通過實戰(zhàn)案例解析這兩個...

關鍵字: Linux 內存管理

對于LLM,我使用b谷歌Gemini的免費層,所以唯一的成本是n8n托管。在使用了n8n Cloud的免費積分后,我決定將其托管在Railway上(5美元/月)。然而,由于n8n是開源的,您可以在自己的服務器上托管它,而...

關鍵字: 人工智能 n8n Linux

在Linux系統(tǒng)管理中,權限控制是安全運維的核心。本文通過解析/etc/sudoers文件配置與組策略的深度應用,結合某金融企業(yè)生產環(huán)境案例(成功攔截98.7%的非法提權嘗試),揭示精細化權限管理的關鍵技術點,包括命令別...

關鍵字: Linux 用戶權限 sudoers文件

Linux內核中的信號量(Semaphore)是一種用于資源管理的同步原語,它允許多個進程或線程對共享資源進行訪問控制。信號量的主要作用是限制對共享資源的并發(fā)訪問數(shù)量,從而防止系統(tǒng)過載和數(shù)據(jù)不一致的問題。

關鍵字: Linux 嵌入式

在云計算與容器化技術蓬勃發(fā)展的今天,Linux網絡命名空間(Network Namespace)已成為構建輕量級虛擬網絡的核心組件。某頭部互聯(lián)網企業(yè)通過命名空間技術將測試環(huán)境資源消耗降低75%,故障隔離效率提升90%。本...

關鍵字: Linux 云計算

在Linux內核4.18+和主流發(fā)行版(RHEL 8/Ubuntu 20.04+)全面轉向nftables的背景下,某電商平臺通過遷移將防火墻規(guī)則處理效率提升40%,延遲降低65%。本文基于真實生產環(huán)境案例,詳解從ipt...

關鍵字: nftables Linux

在Linux設備驅動開發(fā)中,等待隊列(Wait Queue)是實現(xiàn)進程睡眠與喚醒的核心機制,它允許進程在資源不可用時主動放棄CPU,進入可中斷睡眠狀態(tài),待資源就緒后再被喚醒。本文通過C語言模型解析等待隊列的實現(xiàn)原理,結合...

關鍵字: 驅動開發(fā) C語言 Linux

在Unix/Linux進程間通信中,管道(pipe)因其簡單高效被廣泛使用,但默認的半雙工特性和無同步機制容易導致數(shù)據(jù)競爭。本文通過父子進程雙向通信案例,深入分析互斥鎖與狀態(tài)機在管道同步中的應用,實現(xiàn)100%可靠的數(shù)據(jù)傳...

關鍵字: 管道通信 父子進程 Linux

RTOS :RTOS的核心優(yōu)勢在于其實時性。它采用搶占式調度策略,確保高優(yōu)先級任務能夠立即獲得CPU資源,從而在最短時間內完成處理。RTOS的實時性是通過嚴格的時間管理和任務調度算法實現(xiàn)的,能夠滿足對時間敏感性要求極高的...

關鍵字: Linux RTOS
關閉