0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于異構(gòu)多核處理器和共享內(nèi)存技術(shù)實(shí)現(xiàn)片上通信設(shè)計(jì)

電子設(shè)計(jì) ? 來(lái)源:微計(jì)算機(jī)信息 ? 作者:唐豪川 ,祝永新 ? 2021-06-08 15:21 ? 次閱讀

1 引言

如今,隨著集成電路工藝發(fā)展到深亞微米的階段,處理器體系結(jié)構(gòu)的設(shè)計(jì)研究正朝著多 核的方向發(fā)展。Intel、IBM、SUN 等主流芯片產(chǎn)商已經(jīng)在市場(chǎng)上發(fā)布了自己的多核處理器。 目前多核處理器的發(fā)展尚處于起步階段,有很多問(wèn)題還有待解決。其中,一個(gè)十分重要的方 面就是設(shè)計(jì)高效的片上通信架構(gòu)。多個(gè)內(nèi)核上同時(shí)執(zhí)行的各個(gè)程序之間可能需要進(jìn)行數(shù)據(jù) 共享與同步,因此多核處理器的硬件結(jié)構(gòu)必須支持各個(gè)CPU 內(nèi)核之間的通信。一般說(shuō)來(lái), 異構(gòu)多核處理器和同構(gòu)多核處理器在通信機(jī)制的設(shè)計(jì)上有著不同的考慮。異構(gòu)多核處理器通 常是針對(duì)嵌入式系統(tǒng)的應(yīng)用,主要存在著總線、存儲(chǔ)控制器、共享存儲(chǔ)區(qū)等通信機(jī)制。

異構(gòu)多核處理器系統(tǒng)的幾種主要通信機(jī)制,事實(shí)上都可以通過(guò)一個(gè)共享存儲(chǔ)區(qū)來(lái)實(shí)現(xiàn),例如郵箱、消息、信號(hào)量實(shí)際上都是以共享存儲(chǔ)區(qū)作為傳播載體。同時(shí),也考慮到 SystemC 的設(shè)計(jì)方法可以支持設(shè)計(jì)者在不同層次上建模減小了代碼量和工作量,提供了更高的工作效 率。因此本文在采用共享存儲(chǔ)器通信機(jī)制的同時(shí),基于SystemC 提出且建立事務(wù)級(jí)多核通 信模型,并利用MP3 解碼程序?qū)嵗C明了本模型有效的實(shí)現(xiàn)了多核間的通信。

2 SystemC 通信總線模型

2.1 SystemC 簡(jiǎn)介

SystemC 由C++衍生而來(lái),在C++基礎(chǔ)上添加硬件擴(kuò)展庫(kù)和仿真庫(kù)構(gòu)成,從而使SystemC 可以建模不同抽象級(jí)別的包括軟件和硬件的復(fù)雜電子系統(tǒng)[4]。他的最基本的結(jié)構(gòu)單元是模塊 (module),模塊可以包含其他模塊或過(guò)程(process)和方法(method),過(guò)程如同C 語(yǔ)言中的函 數(shù)用以實(shí)現(xiàn)某一行為模塊,通過(guò)接口(port) 與其他模塊通信接口之間用信號(hào)(Signal) 相連。 一個(gè)完整的系統(tǒng)由多個(gè)模塊組成,每個(gè)模塊包含一個(gè)或多個(gè)過(guò)程和方法,過(guò)程是平行工作的。 基于SystemC 的設(shè)計(jì)方法支持設(shè)計(jì)者在不同層次上建模減小了代碼量和工作量提供了更高 的工作效率,也就是說(shuō)利用SystemC 與傳統(tǒng)的方法相比可以更為高效快速地進(jìn)行仿真。

2.2 模塊細(xì)化及基于SystemC 的通信總線行為級(jí)建

模 一個(gè)典型的片上系統(tǒng)模型框架通常包括總線、總線仲裁器、微處理器數(shù)字信號(hào)處理器 (L6P)、存儲(chǔ)器和其他專用集成電路(ASIC)。這樣一個(gè)復(fù)雜的系統(tǒng),傳統(tǒng)的設(shè)計(jì)辦法是全部 使用C/C++進(jìn)行描述以進(jìn)行系統(tǒng)級(jí)建模和驗(yàn)證,然后將硬件部分的描述手工翻譯為 VHDL/Verilog HDL,等硬件描述語(yǔ)言進(jìn)行描述。等硬件全部實(shí)現(xiàn)后再進(jìn)行軟件的設(shè)計(jì)與實(shí)現(xiàn)。在引入SystemC 作為建模語(yǔ)言的情況下,整個(gè)系統(tǒng)可以方便地用一種語(yǔ)言進(jìn)行描述、 建模、仿真、細(xì)化,直到最終實(shí)現(xiàn)。

在使用 SystemC 建立片上總線行為級(jí)模型時(shí),根據(jù)總線一般模型中各個(gè)模塊的行為特 性,進(jìn)行了進(jìn)一步的模型細(xì)化,得出片上總線行為級(jí)模型的SystemC 模塊結(jié)構(gòu)圖,如圖1 所示。在模型細(xì)化的過(guò)程中,總線主設(shè)備被劃分為直接型主設(shè)備、阻塞型主設(shè)備和非阻塞型 主設(shè)備;總線從設(shè)備被劃分為快速存儲(chǔ)器、慢速存儲(chǔ)器和代表ASIC 的通用串口;通信總線和 仲裁器模塊保持不變。

總線采用分層通道的方式實(shí)現(xiàn),實(shí)現(xiàn)了直接型接口、阻塞型接口和從設(shè)備接口。在某些 時(shí)鐘的上升沿,總線收集到來(lái)自各個(gè)主設(shè)備的從設(shè)備讀寫(xiě)請(qǐng)求,并將這些請(qǐng)求加入請(qǐng)求隊(duì)列。 在時(shí)鐘的下降沿,總線將請(qǐng)求發(fā)送給總線仲裁器,由總線仲裁器根據(jù)一定的仲裁規(guī)則進(jìn)行仲 裁,從請(qǐng)求隊(duì)列中選擇出合適的主設(shè)備請(qǐng)求并通過(guò)從設(shè)備接*由總線從設(shè)備進(jìn)行服務(wù)。

3 基于異構(gòu)多核的通信模塊設(shè)計(jì)與實(shí)現(xiàn)

3.1 設(shè)計(jì)原理

按照上文中提到的總線架構(gòu),多核處理器作為通信總線的主設(shè)備而共享存儲(chǔ)區(qū)作為總線 的從設(shè)備形成了整個(gè)系統(tǒng)模型,但考慮到異構(gòu)多核與同構(gòu)多核相比存在一個(gè)問(wèn)題:即由于不 同內(nèi)核的應(yīng)用程序采用的是不同的交叉編譯器,因此高級(jí)語(yǔ)言所指定的內(nèi)存空間是無(wú)法做到 一致的,即便是直接寫(xiě)匯編程序指定內(nèi)存地址,由于操作系統(tǒng)分配給不同模擬器的程序空間 是不同的,也無(wú)法做到共享存儲(chǔ)。也就是說(shuō),無(wú)論是高級(jí)語(yǔ)言編程,還是匯編語(yǔ)言編程,都 要解決二進(jìn)制代碼和內(nèi)核模擬器之間的通信。因此上文中提到的基于SystemC 的通信總線 就需要針對(duì)不同的異構(gòu)多核組合進(jìn)行相應(yīng)的修改,缺少通用性,違反了模塊設(shè)計(jì)封裝化原則。

經(jīng)過(guò)不斷的探索和比較,本文最終采用了一種從方法學(xué)角度和可擴(kuò)展性角度來(lái)看,都比 較合適的方法: 在各個(gè)處理器與通信總線之間添加一個(gè)通信控制模塊(CMCCtrl-- Communication control)如圖2 所示。

該模塊用來(lái)專門(mén)處理各個(gè)核之間的通信指令,對(duì)其進(jìn)行解釋翻譯,并將最終行為直觀的 告訴總線,達(dá)到核間通信的目的。新架構(gòu)設(shè)計(jì)按照SystemC 交易級(jí)建模(TLM)原則,為以后 多核功能的擴(kuò)展性提供可能性。

3.2 通信機(jī)制

為了異構(gòu)多核通信的實(shí)現(xiàn),需要向多核仿真器的每個(gè)模擬器內(nèi)核擴(kuò)展三條訪問(wèn)共享存儲(chǔ) 區(qū)的指令,分別是:申請(qǐng)空間、讀取和寫(xiě)入。

在內(nèi)核代碼中對(duì)共享存儲(chǔ)區(qū)訪問(wèn)指令進(jìn)行譯碼之后,需要對(duì)共享存儲(chǔ)區(qū)發(fā)出操作請(qǐng)求, 與操作請(qǐng)求一起發(fā)送的是操作的信息,對(duì)于申請(qǐng)、讀取和寫(xiě)入三種操作,各自的操作信息如 下表所示:

當(dāng) CMCCtrl 受到接收到來(lái)自Core1/Core2 的訪問(wèn)請(qǐng)求,模塊觸發(fā)。同時(shí)隨著請(qǐng)求一起接 收下來(lái)的其他信息,包括指令編碼、請(qǐng)求的數(shù)據(jù)類型、地址偏移等等。CMCCtrl 對(duì)這些請(qǐng)求 信息進(jìn)行分析,當(dāng)判斷出核間需要數(shù)據(jù)通信后,將需要的信息提取發(fā)送至總線模塊。具體模 塊描述如下:

SC_MODULE(CMCCtrl)

{ sc_inout isCore1, isCore2; //來(lái)自Core1/Core2 的訪問(wèn)請(qǐng)求,是本模塊的觸發(fā)信號(hào)

sc_out core1_latency, core2_latency; //返回給Core1/Core2 的延時(shí)信息

sc_inout data_value; //需要傳遞的數(shù)據(jù)

sc_port bus_port; //通信總線模塊接口

/*返回給Core1/Core2 的應(yīng)答信號(hào),表明CORE1/Core2 獲得了共享存儲(chǔ)區(qū)的訪問(wèn)權(quán),并

且可以繼續(xù)執(zhí)行下一個(gè)周期的操作*/

sc_inout ackCore1, ackCore2;

/*隨著isCore1/isCore2 請(qǐng)求一起接收下來(lái)的請(qǐng)求信息,包括指令編碼、請(qǐng)求的數(shù)據(jù)類型、

地址移等等*/

sc_inout data_type, array_capacity, data_index, data_id;

/*隨著is Core1/isCore2 請(qǐng)求一起接收下來(lái)的,表明當(dāng)前Core1/Core2 運(yùn)行的周期數(shù),用

于進(jìn)行內(nèi)核調(diào)度判斷和訪存沖突分析*/

sc_in core1_cycle, core2_cycle;

/*對(duì)isCore1 或者isCore2 的上升沿敏感的響應(yīng)函數(shù),它被定義為線程類型,是CMCCtrl

類的實(shí)現(xiàn)函數(shù)。函數(shù)內(nèi)部需要對(duì)兩個(gè)內(nèi)核的訪問(wèn)請(qǐng)求進(jìn)行判斷、控制,并調(diào)用相應(yīng)的其

它成員函數(shù)。*/

void Controller();

//對(duì)于每一個(gè)write_shm_data 請(qǐng)求,將數(shù)據(jù)寫(xiě)入指定的共享存儲(chǔ)區(qū)空間

void WriteShmDataHandler(struct InstBuffer *inst);

//對(duì)于每一個(gè)read_shm_data 請(qǐng)求,將數(shù)據(jù)寫(xiě)入指定的共享存儲(chǔ)區(qū)空間

void ReadShmDataHandler(struct InstBuffer *inst);

……

SC_HAS_PROCESS(CMCCtrl);

// constructor

CMCCtrl (sc_module_name _name){……}

};

4 MP3 解碼程序的多核測(cè)試

為了更加充分進(jìn)行驗(yàn)證,并展示多核通信模塊在實(shí)際應(yīng)用中的價(jià)值,本文選擇了MP3 解碼程序進(jìn)行基于多核系統(tǒng)的移植,并驗(yàn)證仿真結(jié)果以及仿真效率。

MP3編碼的主要方法是在頻域上對(duì)音頻文件內(nèi)容進(jìn)行編碼壓縮,而解碼過(guò)程是還原頻域 的內(nèi)容再變換成原始的時(shí)域音頻信號(hào)。按照ISO/IEC11172-3標(biāo)準(zhǔn),MP3解碼算法分為同步與 校驗(yàn)、Huffman解碼、比例因子解析、反量化、重排序、立體聲處理等十個(gè)部分。

在考慮應(yīng)用程序的多核移植時(shí),可以是數(shù)據(jù)劃分也可以是任務(wù)劃分的。對(duì)于MP3代碼, 如果采用數(shù)據(jù)劃分式,則可以在不同的處理器內(nèi)核上解不同的數(shù)據(jù)幀。而如果采用任務(wù)劃分 方式,則可以將解碼的不同過(guò)程在多個(gè)內(nèi)核之間形成流水作業(yè),采用共享存儲(chǔ)區(qū)進(jìn)行不同流 水級(jí)之間的數(shù)據(jù)傳遞。顯然后者需要更多的核間通信,更適合于驗(yàn)證其性能,因此,本文采 用了按照任務(wù)劃分的方式進(jìn)行代碼的多核移植。

在測(cè)試中,我們采用ARM+PISA的雙核系統(tǒng),因此需要將MP3解碼程序按照功能劃分為 兩部分,分別放在兩個(gè)內(nèi)核上運(yùn)行,形成流水線。本文所采用的MP3解碼軟件在ARM開(kāi)發(fā) 套件(ARM Design Suit)軟件仿真平臺(tái)上測(cè)試的結(jié)果表明:合成多項(xiàng)濾波器部分占用了大 約50%的計(jì)算量。根據(jù)這個(gè)結(jié)論,本文粗略地對(duì)應(yīng)用程序在雙核之間進(jìn)行任務(wù)劃分:其中 一個(gè)內(nèi)核運(yùn)行計(jì)算量最大的合成濾波,另外一個(gè)內(nèi)核實(shí)現(xiàn)Huffman解碼、比例因子解析、反 量化等步驟。兩個(gè)內(nèi)核通過(guò)系統(tǒng)提供的通信控制模塊進(jìn)行通信并保持同步。

表2是這一測(cè)試的統(tǒng)計(jì)結(jié)果。統(tǒng)計(jì)數(shù)據(jù)提供了兩方面的信息:

1)MP3解碼程序的雙核加速比,由統(tǒng)計(jì)結(jié)果中的“運(yùn)行周期數(shù)”反映;

2)多核仿真器在進(jìn)行MP3解碼仿真時(shí)的仿真效率,由“仿真時(shí)間”和“仿真速度”兩 項(xiàng)統(tǒng)計(jì)結(jié)果反映。

5 總結(jié)

無(wú)論考慮單位計(jì)算性能的能耗因素,還是對(duì)于提高處理器性能,多核體系結(jié)構(gòu)尤其是異 構(gòu)多核體系結(jié)構(gòu)都是當(dāng)前的熱點(diǎn)研究方向。本文主要論述了面向異構(gòu)多核處理器的片上通信設(shè)計(jì)。對(duì)于處理器的內(nèi)核間通信,采用了共享內(nèi)存技術(shù)。

本模型充分體現(xiàn)了SystemC的語(yǔ)言優(yōu)勢(shì),對(duì)進(jìn)一步了解和探討異構(gòu)多核處理器結(jié)構(gòu)、核 間通信、異構(gòu)多核低功耗設(shè)計(jì)等方面打下一定基礎(chǔ)。

本文作者創(chuàng)新點(diǎn): 提出了一種基于SystemC的異構(gòu)多核通信架構(gòu)模型,并通過(guò)添加控制 模塊解決異構(gòu)多核間通信通用性問(wèn)題。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19100

    瀏覽量

    228814
  • 芯片
    +關(guān)注

    關(guān)注

    452

    文章

    50206

    瀏覽量

    420884
  • 存儲(chǔ)器
    +關(guān)注

    關(guān)注

    38

    文章

    7430

    瀏覽量

    163515
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    【米爾NXP i.MX 93開(kāi)發(fā)板試用評(píng)測(cè)】1、異構(gòu)核心通信技術(shù)內(nèi)容

    前言 很多異構(gòu)核心使用的是標(biāo)準(zhǔn)的OpenAMP,OpenAMP(Open Asymmetric Multi-Processing)是一個(gè)開(kāi)源的軟件框架,用于在異構(gòu)多核處理器系統(tǒng)中
    發(fā)表于 09-21 20:24

    多核處理器設(shè)計(jì)九大要素

    機(jī))節(jié)點(diǎn)集成到同一芯片內(nèi),各個(gè)處理器并行執(zhí)行不同的線程或進(jìn)程。在基于SMP結(jié)構(gòu)的單芯片多處理機(jī)中,處理器之間通過(guò)外Cache或者是外的
    發(fā)表于 04-13 09:48

    典型的支持多核處理器的RTOS功能解析

    1、基于同步原語(yǔ)擴(kuò)展的實(shí)時(shí)操作系統(tǒng) 在多核處理器的每一個(gè)處理器都運(yùn)行一個(gè)完全相同的RTOS,然后提供擴(kuò)展的組件庫(kù),這種組件庫(kù)提供相應(yīng)的同步原語(yǔ)以支持
    發(fā)表于 06-29 08:30

    創(chuàng)龍帶您解密TI、Xilinx異構(gòu)多核SoC處理器核間通訊

    進(jìn)行控制操作和多媒體顯示;DSP天生為數(shù)字信號(hào)處理而生,擅長(zhǎng)進(jìn)行專用算法運(yùn)算;FPGA擅長(zhǎng)高速、多通道數(shù)據(jù)采集和信號(hào)傳輸。同時(shí),異構(gòu)多核SoC處理器核間通過(guò)各種
    發(fā)表于 09-08 09:39

    MPU進(jìn)化,多核異構(gòu)處理器有多強(qiáng)?

    /G2L系列以及TI的AM62x系列等等。雖然這些處理器的品牌及性能有所不同,但多核通信原理基本一致,都是基于寄存和中斷傳遞消息,基于共享
    發(fā)表于 11-21 09:45

    【玩轉(zhuǎn)多核異構(gòu)處理器對(duì)共享外設(shè)和資源的調(diào)配方法

    多核異構(gòu)CPU中,多個(gè)內(nèi)核就如同多個(gè)大腦,而外設(shè)和內(nèi)存等資源就如同手足,那么多個(gè)大腦該如何控制手足才能保證它們正常有序地運(yùn)行呢?以NXP i.MX8M Plus處理器的A核和M核為例
    發(fā)表于 02-07 15:46

    基于OKMX8MP-C板的多核異構(gòu)處理器對(duì)外設(shè)和內(nèi)存資源的使用方法

    多核異構(gòu)CPU中,多個(gè)內(nèi)核就如同多個(gè)大腦,而外設(shè)和內(nèi)存等資源就如同手足,那么多個(gè)大腦該如何控制手足才能保證它們正常有序地運(yùn)行呢?以NXP i.MX8M Plus處理器的A核和M核為例
    發(fā)表于 02-21 15:05

    多核異構(gòu)處理器對(duì)共享外設(shè)和資源的調(diào)配方法

    多核異構(gòu)CPU中,多個(gè)內(nèi)核就如同多個(gè)大腦,而外設(shè)和內(nèi)存等資源就如同手足,那么多個(gè)大腦該如何控制手足才能保證它們正常有序地運(yùn)行呢?以NXP i.MX8M Plus處理器的A核和M核為例
    發(fā)表于 03-10 11:54

    嵌入式異構(gòu)多核通信架構(gòu)設(shè)計(jì)

    為了克服目前嵌入式異構(gòu)多核處理器通信架構(gòu)無(wú)法提供高效的
    發(fā)表于 12-04 11:30 ?26次下載

    基于排隊(duì)論的多核處理器總線爭(zhēng)用延時(shí)分析

    多核處理器處理器領(lǐng)域發(fā)展的必然趨勢(shì)。多核之間的通信可以利用基于總線的共享cache
    發(fā)表于 01-16 13:26 ?16次下載

    基于SystemC的異構(gòu)多核通信模塊設(shè)計(jì)

    通過(guò)分析異構(gòu)多核體系中處理核的核間通信,采用共享
    發(fā)表于 01-20 15:01 ?10次下載

    基于SystemC的異構(gòu)多核通信模塊設(shè)計(jì)

    通過(guò)分析異構(gòu)多核體系中處理核的核間通信,采用共享
    發(fā)表于 07-17 16:51 ?19次下載

    多核處理器存儲(chǔ)系統(tǒng)研究

    針對(duì) 多核處理器 計(jì)算能力和訪存速度間差異不斷增大對(duì)多核系統(tǒng)性能提升的制約問(wèn)題,分析幾款典型多核處理器存儲(chǔ)系統(tǒng)的設(shè)計(jì)特點(diǎn),探討
    發(fā)表于 07-27 15:49 ?29次下載
    <b class='flag-5'>多核</b><b class='flag-5'>處理器</b><b class='flag-5'>片</b><b class='flag-5'>上</b>存儲(chǔ)系統(tǒng)研究

    異構(gòu)多核處理器任務(wù)調(diào)度算法

    任務(wù)調(diào)度響應(yīng)實(shí)時(shí)性方面表現(xiàn)優(yōu)異,但卻不適用于異構(gòu)多核處理器環(huán)境。為此,提出一種高實(shí)時(shí)性任務(wù)調(diào)度算法HRSA。在Min-Min調(diào)度算法的基礎(chǔ)融合LSF,EDF,HVF算法的調(diào)度策略,將
    發(fā)表于 02-07 11:07 ?2次下載

    探究一種新的可配置處理器異構(gòu)多核線程級(jí)動(dòng)態(tài)調(diào)度模型

    本文針對(duì)基于可配置處理器異構(gòu)多核結(jié)構(gòu),提出一種新的線程級(jí)動(dòng)態(tài)調(diào)度模型。此類異構(gòu)多核系統(tǒng)中每個(gè)核分別針
    的頭像 發(fā)表于 04-27 18:20 ?2010次閱讀