<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 基于Java的FPGA可編程嵌入式系統

基于Java的FPGA可編程嵌入式系統

作者: 時(shí)間:2010-09-19 來(lái)源:網(wǎng)絡(luò ) 收藏

  應用程序通過(guò)類(lèi)HWInterface提供的方法訪(fǎng)問(wèn)本地庫。上面的代碼中給出了setParam的具體實(shí)現。其中,CID是包括硬件方法映射到的緩存地址的一個(gè)對象,對應于每個(gè)硬件方法的CID都是唯一的,因此,該地址和緩存區大小都是事先已經(jīng)確定了的。但是,由于中只有一個(gè)配置控制器,我們無(wú)法同時(shí)就兩個(gè)或多個(gè)硬件方法向進(jìn)行編程,也可以說(shuō)同一時(shí)刻只能有一個(gè)硬件方法在使用配置控制器。為此,引入了一個(gè)靜態(tài)變量ConfigStatus來(lái)反映配置控制器的當前狀態(tài)。所以,訪(fǎng)問(wèn)配置控制器的函數configHW()是靜態(tài)的同步的。

  使用上面給出的接口,則下面這段代碼

  methodA()

  {

  …;

  int a = objA.m1(2); //SW method

  int b = objB.m2(3); //HW method

  int c = a + b;

  …;

  }

  就應該寫(xiě)成下面的形式:

  methodA()

  {

  …;

  1 HWInterface.configHW(cid2); // cid2 is the ID of HW method m2

  2 Object P = new Integer(3);

  3 HWInterface.SetParam(cid2,P);

  4 HWInterface.startHW(cid2);

  5 int a = objA.m1(2);

  6 Object R = new Integer();

  7 While(HWInterface.getResult(cid2, R) == 0)

  ; //wait until HW method finished

  8 HWInterface.getResult(cid2, R);

  9 int b = ((Integer)R.getValue());

  10 int c = a + b;

  …;

  }

  在上例中,為了執行中的函數objB.m2(),首先對進(jìn)行編程(Line1)。然后,將參數拷貝到硬件方法的輸 入緩存中(Line3),并對硬件方法進(jìn)行初始化(Line4)。最后,采用了一個(gè)循環(huán)函數持續檢查硬件方法緩存的狀態(tài)(Line7,8),直至計算完成,然后拷貝得到結果(Line9)。

  3. 實(shí)現

  使用ARM710T處理器和Virtex的FPGA,根據上文給出的設計方案,我們實(shí)現了一個(gè)開(kāi)發(fā)平臺。該平臺包括一個(gè)網(wǎng)絡(luò )接口,兩個(gè)調試接口,一個(gè)PCI主機接口和一個(gè)串行口。并移植了一個(gè)操作系統和一個(gè)小巧的實(shí)時(shí)運行環(huán)境。如圖4:

  

  4. 總結

  本文用一種全新的思路,對傳統的系統進(jìn)行了改進(jìn),實(shí)現了一種能夠支持多種應用的嵌入式系統平臺。利用FPGA的性和平臺良好的移植性能,該平臺完全能夠滿(mǎn)足我們的設計要求。當然,也有不足之處,比如對配置控制器的狀態(tài)的獲取,可以考慮使用中斷的方式來(lái)實(shí)現,而不是采用本文中的循環(huán)查詢(xún)機制。這將在以后的工作中加以改進(jìn)。

linux操作系統文章專(zhuān)題:linux操作系統詳解(linux不再難懂)

fpga相關(guān)文章:fpga是什么



上一頁(yè) 1 2 3 下一頁(yè)

關(guān)鍵詞: 嵌入式 系統 可編程 FPGA Java 基于

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>