新聞中心

EEPW首頁(yè) > 電源與新能源 > 設(shè)計(jì)應(yīng)用 > 基于網(wǎng)絡(luò)編碼的多信源組播通信系統(tǒng),包括源代碼,原理圖等(二)

基于網(wǎng)絡(luò)編碼的多信源組播通信系統(tǒng),包括源代碼,原理圖等(二)

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

模塊中的狀態(tài)和階段,任何一個(gè)模塊都可以響應(yīng)來(lái)自PCI總線寄存器的訪問(wèn)和控制要求,而PCI總線寄存器可以通過(guò)軟件來(lái)控制。也就是說(shuō),硬件和軟件的通信是通過(guò)PCI總線完成的。

本文引用地址:http://m.butianyuan.cn/article/201612/326828.htm

  數(shù)據(jù)以及控信息在硬件和主機(jī)系統(tǒng)之間是通過(guò)PCI總線傳輸?shù)?,以Linux網(wǎng)絡(luò)存儲(chǔ)棧作為接口的。NetFPGA向主機(jī)發(fā)送分組數(shù)據(jù)的過(guò)程如圖2.5-2a所示:

  分組到達(dá),發(fā)往CPU隊(duì)列;

  中斷程序通知驅(qū)動(dòng)程序有分組到達(dá);

  驅(qū)動(dòng)程序設(shè)置和初始化DMA傳送器;

  NetFPGA通過(guò)DMA總線發(fā)送分組;

  中斷程序發(fā)送DMA結(jié)束信號(hào);

  驅(qū)動(dòng)程序把分組傳遞到網(wǎng)絡(luò)存儲(chǔ)棧;

  

  圖2.5-2a:NetFPGA向主機(jī)發(fā)送數(shù)據(jù) 圖2.5-2b:主機(jī)向NetFPGA發(fā)送數(shù)據(jù)

  主機(jī)向NetFPGA發(fā)送分組數(shù)據(jù)的過(guò)程如圖2.5-2b所示:

  控制軟件通過(guò)網(wǎng)絡(luò)socket發(fā)送分組,分組被遞交給驅(qū)動(dòng)程序;

  驅(qū)動(dòng)程序設(shè)置和初始化DMA傳送器;

  中斷程序發(fā)送DMA結(jié)束信號(hào);

  主機(jī)訪問(wèn)寄存器是通過(guò)系統(tǒng)調(diào)用系統(tǒng)內(nèi)核的ioctl( )函數(shù)作為接口的。讀寫寄存器的操作函數(shù)如下,這兩個(gè)函數(shù)內(nèi)部調(diào)用了ioctl( )函數(shù)。

  readReg(nf2device *dev, int address, unsigned *rd_data)

  writeReg(nf2device *dev, int address, unsigned *wr_data)

  例如: readReg(&nf2, OQ_NUM_PKTS_STORED_0, &val);

  主機(jī)訪問(wèn)NetFPGA寄存器的過(guò)程如下:

  (1)控制軟件調(diào)用ioctl( )函數(shù)操作網(wǎng)絡(luò)socket,由函數(shù)ioctl傳遞給驅(qū)動(dòng)程序;

  (2)驅(qū)動(dòng)程序完成PCI寄存器的讀寫


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

評(píng)論


技術(shù)專區(qū)

關(guān)閉