九、發明說明: 【發明所屬之技術領域】 本發明是關於一種網路介面裝置及其方法,尤其是一 種能増加資料傳收效率的網路介面裝置及其方法。 【先前技術】 現有之網路資料傳收機制是一個網路埠對應一個網路 控制器,藉以經由-主機介面(如PCI Express介面)在主 機與網路間進行資料之傳送與接收。 以PCI Express Μ介面為例,其使用依2 5 GHz時脈 速率運作的連線,- PCI Express通道(Lan〇於單一方向 可達到每秒250 MB的頻寬,於上行或下行方向都有25〇mb 的頻寬。PCI Express介面可結合多個通道,提供更高頻寬 因此x8 PCI Express介面具有單一通道的8倍頻寬(即單 -方向之頻寬為2GB/S),又例如_般顯示卡使用的χΐ6 Pd Εχρ⑽介面,擁有的單—方向總頻寬為每秒備。 然而以Gigabit乙太網路控制器為例,其所提供的資料 傳輸速度往往受限於網路環境而遠低於咖耐每秒(傳送 或接收)i_許^ PCI-E介面之Gigabit乙太網路控制器卻 是x8 PCI-E介面,其介面頻寬可達2GB/s,顯見尚有一半 以上的PCI-E之頻寬未能被網路控制器充份使用。倘若以 目前PCJ Exp簡2.0介面而言,其將時脈速率提昇一倍到 達5.0 GHz,亦即可將介面頻寬提昇一倍,使χ8 ρα Exp謂2.0的單-方向之頻宽可達每秒4gb,因此將有更 1379567 多的頻寬未能被網路傳輸充份利用。 【發明内容】 因此’本發明目的之一在於提供一種網路介面裝置以 解決前述問題。 本發明另一目的在於利用一網路控制器來處理複數個 網路埠所形成之複數個實體網路連線之資料藉以增加網 路通訊效率與該網路控制器與一主機間之介面的頻寬使用 〇 依據本發明所揭露之網路介面控制器之一實施例,其 包含:一實體層電路,包括一第一實體層電路以及一第二 實體層電路,其分別用來經由—第一網路埠以及一第二網 路埠來執行封包之傳送與接收;一媒體存取控制器,包括 一第一媒體存取控制器以及一第二媒體存取控制器該第 一媒體存取控制器依據待傳送資料所對應之—目的位址來 產生一封包以輸出,以及於接收一封包時依據一第一 MAC: 位址來處理該封包,該第二媒體存取控制器則依據待傳送 資料所對應之一目的位址來產生一封包以輸出,以及於接 收一封包時依據一第二MAC位址來處理該封包;一資料流 向控制H 接至第—與第二媒體存取控制器用來依據 -接收規則來接收第一或第二媒體存取控制器所輸出之資 料,以及依據—傳送規則來傳送資料至第一或第二媒體存 取控制器,一主機介面控制器,耦接至資料流向控制器與 -主機介面(例如ρα Εχρ咖介面),用來接收資料流向 7 控制器所輸出之資料並將其經由主機介面上傳至一主機, 以及經由主機介面由主機下載資料後,輸出該資料至資料 流向控制器。 依據本發明所揭露之網路介面控制器之另一實施例, 其包含:一實體層電路’包括一第一實體層電路以及一第 一實體層電路,其分別用來經由一第一網路埠以及一第二 網路槔來執行封包之傳送與接收;一第—先進先出緩衝器 ’耗接該第一實體層電路;一第二先進先出缓衝器,耦接 該第二實體層電路;一資料流向控制器,麵接該第一與第 一先進先出緩衝器,用來依據一接收規則來接收第一或第 二先進先出緩衝器所輸出之資料,以及依據一傳送規則來 傳送資料至第一或第二先進先出緩衝器;一單一媒體存取 控制器,用於依據待傳送資料所對應之一目的位址來產生 具有第一或第二MAC位址之封包以輸出,以及於接收一 封包時依據第-及第二MAC位址來處理該封包;一主機介 面控制器,耗接至該單-媒體存取控制器與—主機介面( J如PCI Express介面)’用來接收單一媒體存取控制器所 輪出之資料並將其經由主機介面上傳至—主機,以及經由 機介面由主機下載資料後,輸出該資料至單一媒體存取 控制器》 據本發明所揭露之一種單一網路介面裝置之-實施 :拉其包含:-第—收發器’用來經由一第一網路線來傳送 接收封包;-第二收發器’用來經由一第二網路線來傳送 '接收封包;-第-緩衝器’純該第_收發器,用來暫存 待傳送至該第一收發器之封包,並用來暫存由該第一收發器 所接收之封包;一第二緩衝器,耦接該第二收發器,用來暫 存待傳送至該第二收發器之封包,並用來暫存由該第二收發 器所接收之封包;一主機介面電路,耦接該第一缓衝器與該 第二緩衝器,用來使該第一緩衝器與該第二緩衝器的其中 一個透過一主機介面與一電腦主機進行資料的傳送。 【實施方式】 以下就本發明之網路介面控制器之各實施例分別說明 之。 直_一較隹竇施你丨: 請參閱圖1 ’其係本發明之網路介面控制器之第一較佳 實施例示意圖,如圖所示,該網路介面控制器100包含: 一實體層電路 101 ( Physical Layer Circuit ;簡稱 PHY ),包 括一第一實體層電路l〇la以及一第二實體層電路1〇 lb,其 分別用來經由一第一網路槔1 〇以及一第二網路槔11來軌行 封包之傳送與接收,該第一網路埠10以及一第二網路埠i i 於本實施例中係RJ45連接器;一媒體存取控制器102 ( Media Access Controller;簡稱 MAC),包括一第一媒體存 取控制器102a以及一第二媒體存取控制器l〇2b,該第一媒 體存取控制器l〇2a依據待傳送資料所對應之一目的位址( Destination Address)來產生一封包以輸出,以及於接收一 封包時依據一第一 MAC位址(MAC Address)來處理該封 包,該第二媒體存取控制器102b則依據待傳送資料所對應 之一目的位址來產生一封包以輸出,以及於接收一封包時 依據-第二MAC位址來處理該封包;—f料流向控制器 103叙接至第一與第二媒體存取控制器i〇2a、l〇2b,用來 依據一接收規則來接收第一或第二媒體存取控制器1〇2a、 l〇2b所輸出之資料,以及依據一傳送規則來傳送資料至第 一或第二媒體存取控制器l〇2a、102b; 一主機介面控制器 1〇4,耦接至資料流向控制器103與一主機介面1〇5 (例如 PCI Express 1.1介面或通用序列匯流排(Universal Serial Bus ; USB)介面)’用來接收資料流向控制器1〇3所輸出之 資料並將其經由主機介面1〇5上傳至一主機1〇6,以及經由 主機介面105由主機1〇6下載資料後,輪出該資料至資料 流向控制器103;以及一時脈產生器107,用來提供一第一 時脈Clkl予該實體層電路ι〇1以及該媒體存取控制器1〇2 ’並提供一第二時脈Clk2予該資料流向控制器1〇3及該主 機介面控制器104,其中該第二時脈Clk2為該第一時脈 Clkl之二倍或二倍以上。 請參閱圖2,其係前述第一實體層電路101a之示意圖 ,由圖可知,該第一實體層電路l〇la包含:_收發器201 (Transceiver),用來依據IEEE 802.3之標準規範執行封包 的傳送與接收;一轉換電路202 ’用來依據IEEE 802.3之標 準規範將第一媒體存取控制器102a所輸出之封包轉換為適 當之訊號以傳送至網路,以及將從網路接收之訊號轉換為 第一媒體存取控制器102a可進一步處理之封包;一第一媒 體獨立介面 203 ( Media Independent Interface ;簡稱 MII), 用來作為第一實體層電路1〇la與第一媒體存取控制器1〇2a 之溝通介面;一 Mil控制器204,用以控制該第—媒體獨立 介面203 ;以及一自動訊息交換電路2〇5,用來與網路連接 對象交換彼此的傳收能力等資訊,在此需注意的是本發明 各實施例之網路介面控制器100可支援多種傳輸速度,例 如支援lOMegabit、lOOMegabit以及lGigabit之傳輪速度, 故一旦自動訊息交換電路確認雙方所共同支援之最大連線 速度,本發明之網路介面控制器100即可運作於該最大連 線速度,而關於此連線速度確認機制請參考美國第RE 39,116與RE 39,405號專利之說明。另外,由於本實施例中 第二實體層電路101b之架構與第一實體層電路1〇la相同, 如圖3所示,故不再重複說明。 請參閱圖4’其係前述第一媒體存取控制器i〇2a之示 意圖’如圖所示,該第一媒體存取控制器l〇2a包含:_ MAC傳忮電路401,用來將待傳送之資料封裝( Encapsulate )成一封包並透過前述第一媒體獨立介面203傳 送至第一實體層電路l〇la,並用來將經由第一媒體獨立介 面203所接收之一封包加以過濾(Filter)並輸出至資料流 向控制器103;以及一第一先進先出緩衝器402 ( First In, First Out;簡稱FIFO),耦接於該MAC傳收電路401及該 資料流向控制器103之間,包含一第一傳送fif〇 402a用來 暫存前述待傳送之資料,以及一第一接收FIFO 402b用來暫 存前述過濾後之資料。請注意,本實施例中,該第一先進 先出緩衝器402係一非同步先進先出緩衝器(ASynchronoUs FIFO),其與MAC傳收電路401間之存取速率係依據前述 1379567 第一時脈Clkl,而與資料流向控制器103間之存取速率係 依據前述第二時脈Clk2 ,關於非同步先進先出緩衝器之背 景知識可參考美國專利第5951635號、第6845414號及第 7315600號等專利内容。另外,由於本實施例中第二媒體存 取控制器102b之架構與第一媒體存取控制器1〇2a相同如 圖5所示,故不再重複說明。 請參閱圖6,其係前述資料流向控制器丨〇3之示意圖, 如圖所示,該資料流向控制器1〇3包含一接收規則控制器 601,其用來實現先前提及之接收規則,該接收規則控制器 601包含:一第一指標差計算器6〇la,用來計算第一接收 FIFO 402b之寫入指標(Write p〇inter)與讀取指標(以“ Pointer)之差異(後稱第一使用空間Distanee υ,其中該 寫入指標係用來記錄寫入第一接收FIF〇 4〇2b之資料量該 讀取指標則用來記錄由第一接收FIFO 402b讀出之資料量, 故該第一使用空間Distance 1係指第一接收FIFO 402b之已 使用空間;一第二指標差計算器6〇lb,用來計算前述第二 接收FIFO之寫入指標與讀取指標之差異(後稱第二使用空 間Distance 2 ),該第二使用空間Distance 2係對應第二接 收FIFO 502b之剩餘儲存空間;一使用空間比較器6〇lc, 用來比較該第一使用空間Distance 1與該第二使用空間 Distance 2,藉以產生一比較訊號(後稱c〇mp ),本實施例 中,當第一使用空間Distance 1大於第二使用空間Distance 2時’ Comp為第一邏輯值,反之則為第二邏輯值。 請繼續參閱圖6’資料流向控制器1〇3另包含一傳送規 12 1379567 則控制器602,其用來實現前述之傳送規則,包含:—目的 位址辨識器602a,依據主機1〇6所提供之資訊來辨識待傳 送資料所對應之目的位址,並將該目的位址與已傳送資料 所對應之目的位址來加以比較,藉以產生一辨識訊號本 實施例中,該目的位址辨識器602a為一查表電路(l〇〇k·叩 table),儲存有最近特定筆數之已傳送資料所對應之目的位 址,且當該辨識訊號為第一數位值時,代表待傳送資料之 目的位址與先前某筆經由第一FIFO 402所傳送之資料之目 的位址相同,當該辨識訊號為第二數位值時,代表待傳送 資料之目的位址與先前某筆經由第二FIF〇 5〇2所傳送之資 料之目的位址相同,而當該辨識訊號為一第三數位值時, 代表待傳送資料之目的位址與最近特定筆數之已傳送資料 所對應之目的位址均不相同;一 FIF〇使用空間監測器6〇2b ,其實施例如同該接收規則控制器6〇1,所差者僅在於該 FIFO使用空間監測器6〇2b係比較該第一與第二傳送FiF〇 402 ' 502之讀寫指標差來產生一監測訊號,當該監測訊號 為第一邏輯值時表示第一傳送FIF〇 4〇2a之已使用空間較大 ,若為第二邏輯值則表示第二傳送FIFO 502a之已使用空間 較大,以及傳送仲裁器602c,用來依據該辨識訊號及該 監測訊號產生一傳送控制訊號。本實施例中,當辨識訊號 為第一數位值時,該傳送控制訊號為第一邏輯值;當辨識 訊號為第二數位值時,該傳送控制訊號為第二邏輯值;當 辨識訊號為第三數位值且監測訊號為第二邏輯值時該傳 送控制訊號為第-邏輯值;當辨識訊號為第三邏輯值且監 13 1379567 測訊號為苐一邏輯值時,傳送控制訊號為第二邏輯值。此 外,在本發明另—實施例中,可僅依據該目的位址辨識器 6〇2a之辨識訊號來產生傳送控制訊號,其中當辨識訊號為 第三數位值時,仲裁器6〇2c可隨機、依序輪流或依據一預 ,規貝j來產生纟有第__邏輯值或第二邏輯值之傳送控制訊 號。在本發明又—實施例中,上述目的位址辨識之工作可 由主機106執行,亦即主機1〇6依據本發明之網路介面控 制态100之一驅動程式來執行目的位址辨識之工作,並透 過前述主機介面105、主機介面控制器1〇4來提供辨識結果 予傳送規則控制器602。 請繼續參閱圖6,資料流向控制器103尚包含一路徑選 擇器603,其耦接前述接收規則控制器601、傳送規則控制 器602以及主機介面控制器104,用來依據Comp之邏輯值 將第一或第二接收FIFO 402b、502b耦接至主機介面控制器 104 ’並由主機介面控制器1〇4將第一或第二接收fif〇 402b、502b之資料透過主機介面ι〇5上傳至主機ι〇6,本 實施例中,當Comp為第一邏輯值時,路徑選擇器603將第 一接收FIFO 402b耦接至主機介面控制器1〇4 ;而當Comp 為第二邏輯值時,路徑選擇器603將第二接收FIFO 502b耦 接至主機介面控制器104。另外,路徑選擇器603亦依據傳 送規則控制器602之傳送控制訊號來將主機介面控制器1 〇4 輕接至第一或第二傳送FIFO 402a、502a,使主機介面控制 器104將待傳送資料輪出至該第一或第二傳送FIFO 402a、 502a ’本實施例中’當傳送控制訊號為第一邏輯值時,路徑 14 1379567 選擇器603將主機介面控制器1〇4耦接至第一傳送FIFO 402a ;當傳送控制訊號為第二邏輯值時,路徑選擇器6〇3將 主機介面控制器104耦接至第二傳送FIF〇 5〇2a。再者,本 實施例中’路徑選擇器603之實施為一開關電路,由於開 關電路係屬本技術領域之通常知識,故在此不予贅述。 请參閲圖7,其係本發明接收規則控制器7〇丨之另一實 施例示意圖,其與圖6之接收規則控制器6〇1之差別在於 本實施例另包含:一第一比較器7〇la,用來比較第一使用 空間Distance 1與一暫存器700所儲存之一使用門檻值,並 產生第一比較訊號(後稱Comp 1 ),本實施例中當第—使 用空間Distance 1大於該使用門檻值時,第一比較訊號為第 一邏輯值’反之則為第二邏輯值;一第二比較器7〇lb,用 來比較第二使用空間Distance 2與該使用門檻值,並產生一 第二比較訊號(後稱Comp2 ),本實施例中當第二使用空間 Distance 2大於該使用門檻值時,第二比較訊號為第一邏輯 值,反之則為第二邏輯值;一計時器70 U,用來依據一預 定工作週期產生一計時訊號,亦即該計時訊號會於一預定 時間後由第一 /第二邏輯值轉為第二/第一邏輯值,且當 Comp邏輯值轉換時,該計時器701c;會進行重置,並從輸 出第二邏輯值之計時訊號來重新開始;以及—接收仲裁器 7〇ld,用來接收Comp、Compl、Comp2及計時訊號以產生 —接收控制訊號。 圖7所示之實施例中,當Compl或Comp2為第二邏輯 值時’代表第一或第二接收FIFO 402b、502b所錯存之資料 15 1379567 少於或等於該使用門檻值(本實施例中該使用門檻值設為 零),因此接收仲裁器701d無需依據計時訊號來定期輪詢 (polling)第一及第二接收FIFO 402b、502b,僅需依據 Comp來產生接收控制訊號以通知路徑選擇器603將第一或 第二接收FIFO 402b ' 502b耦接至主機介面控制器1〇4,換 言之,當Comp為第一/第二邏輯值時,代表僅第一/第二接 收FIFO 402b、502b存有需處理之資料,因此接收仲裁器 701d產生具有第一 /第二邏輯值之接收控制訊號,使路徑選 擇器603將第一/第二接收FIFO 402b/502b耦接至主機介面 控制器104 ;而當Compl與Comp2均為第一邏輯值時,代 表第一及第二接收FIFO 402b、502b所儲存之資料均大於該 使用門摇值’因此接收仲裁器701d依據Comp及計時訊號 來產生該接收控制訊號以通知路徑選擇器603將第一或第 二接收FIFO 402b、502b耦接至主機介面控制器1〇4,亦即 接收控制訊號於Comp由第一/第二邏輯值轉換為第二/第一 邏輯值時(此時计時訊號重置為第二邏輯值),指示將第一/ 第一接收FIFO 402b ' 502b耦接至主機介面控制器1〇4,又 於前述預定時間後計時訊號由第二邏輯值轉換為第一邏輯 值時’指示將第一/第二接收FIFO 402b、502b搞接至主機 介面控制器104,藉此接收仲裁器701d便能依據comp來 指示優先處理待處理資料較多之第一或第二接收FIF〇 4〇2b 、502b ’又能依據計時訊號以定時輪詢(p〇丨丨ing)第一及第 二接收FIFO 402b、502b是否有資料需處理,以避免等待時 間過久。請注意,前述Compl與Comp2為第二邏輯值時, 16 接收仲裁器701d依據Comp及計時訊號來產生接收控制訊 號之運作等同一 XOR閘。 請參閱圖8,其係本發明接收規則控制器之另一實施例 示意圖,本實施例之接收規則控制器801包含:前述第一 指標差計算器60la,用來計算第一使用空間Distance 1 ;前 述第二指標差計算器601b,用來計算第二使用空間 Distance 2 ; —暫存器700,用來儲存一致能門檻值;一第 一比較器701a,用來比較第一使用空間Distance 1與該致 能門檻值,藉以產生一第一致能訊號(後稱Enl ),本實施 例中當該第一使用空間Distance 1大於該致能門楹值,Enl 為第一邏輯值,反之則為第二邏輯值;一第二比較器701b ,用來比較第二使用空間Distance 2與該致能門檻值,藉以 產生一第二致能訊號(後稱En2 ),本實施例中當該第二使 用空間大於該致能門檻值,En2為第一邏輯值,反之則為第 二邏輯值;前述計時器701c,用來產生前述計時訊號;以 及一接收仲裁器701d,如圖9所示,用來依據Enl、En2及 計時訊號TS以產生一接收控制訊號。請參閱圖9,本實施 例中’當Enl為第一邏輯值而En2為第二邏輯值時,代表 第一使用空間Distance 1大於該致能門檻值而第二使用空間 Distance 2小於該致能門檻值,此時接收控制訊號為第一邏 輯值,用以指示路徑選擇器603將主機介面控制器104耦 接至第一接收FIFO 402b ;當Enl為第二邏輯值而En2為第 —邏輯值時,代表第一使用空間Distancel小於該致能門檀 值但第二使用空間Distance2大於該致能門檻值,此時接收 1379567 控制訊號為第二邏輯值,用以指示路徑選擇器603將主機 介面控制器104耦接至第二接收FIFO 502b ;當Enl與En2 均為第一邏輯值時,若Comp為第一邏輯值,代表第一使用 工間Distance 1大於第二使用空間Distance 2,此時接收控 制訊號為第一邏輯值,以指示路徑選擇器603將主機介面 控制器104耦接至第一接收FIF0 402b,但若c〇nip為第二 邏輯值’代表第二使用空間Distance 2大於第一使用空間 Distance 1,則接收控制訊號指示路徑選擇器603將主機介 面控制器104耦接至第二接收FIF0 502b ;而當Eni與En2 均為第二邏輯值時,仲裁器7〇ld僅依據計時訊號TS之邏 輯值轉變來指示路徑選擇器603進行切換,亦即當計時訊 號ts為第一/第二邏輯值,路徑選擇器6〇3將主機控制器 104麵接至第一/第二接收fif〇 402b/502b。 前述實施例雖以計算FIFO之讀寫指標差為例,然而 FIFO為避免發生滿溢(〇verfi〇w)及/或短缺 之情形,可包含一監測電路來監測本身之儲存空間使用量 ,例如包含一 S十數器來計數共有多少By ^存入FlF〇以及 多少Byte被讀出FIFO,因此該計數器之計數值亦可用來取 代前述實施例之讀寫指標差。此外,也可使用不同門檻值 分別與前述第一及第二使用空間來比較,藉以增加實施之 可能性。事實上,本技術領域具有通常知識者當能依據本 發明之揭露内容來作一均等之變化實施。 在另一實施例中,可依據一傳送規則使得該第一實體 層電路101a的第一收發器2〇1與該第一實體層電路1〇忱的 18 1379567 第二收發器201實質上達到負載平衡(load balance),例如傳 送規則包含依據第一及第二收發器201之資料流量( Throughput)多寡來優先選擇資料流向較少者執行傳送。而 上述各個裝置於實作中可為網路介面卡(Network Interface Card, NIC)或為主機板内建網路(LAN On Motherboard . LOM)。 綜上所述,本發明之第一較佳實施例提供了一網路控 制器以處理二個實體網路路徑之資料傳收,然而二個以上 之實體網路路徑之資料傳收亦能為本發明所支持,如圖J 〇 所示’然需注意的是圖10之第三時脈Clk3為第一時脈 Clkl之三倍或三倍以上,且資料流向控制器需1〇3比較第 一、第二及第三媒體存取控制器102a、1〇2b、l〇2c之第一 '第二及第三FIFO之使用空間以及待傳送資料之目的位址 等參數,藉以決定第一、第二、第三FIF〇與主機介面控制 器104之耦接關係。此外,第一媒體存取控制器1〇2&與第 一實體層電路101a及第一網路埠1〇等構成之第一實體網路 路徑與第二媒體存取控制器1〇2b、第二實體層電路1〇11?及 第二網路埠11等構成之第二實體網路路徑可運作在不同頻 率,如圖π所示,第一實體網路路徑係依據第一時脈Clkl 運作,而第二實體網路路徑係依據第四時脈ak4運作,至 於第-時m cik2於本實施例中為第_或第四時脈Clkl、 Clk4較高者之至少二倍。 19 第二較佳實施例: 請參閱圖12’其係本發明之網路介面控制器之第二較 佳實施例示意圖,如圖所示’該網路介面控制器1 〇〇 3包 含:一實體層電路101,包括一第一實體層電路l〇la以及 一第二實體層電路101b’其架構與功能與第一較佳實施例 中所述相同,於此不再重覆敘述;一第一先進先出緩衝器 402,包含一第一傳送FIFO 402a以及一第一接收fif〇 402b ’其架構與功能與第一實施例中所述相仿,所差者主 要在於本實施例之第一先進先出緩衝器4〇2並非設置於第 一媒體存取控制器102a中,而係作為第一實體層電路1〇la 與資料流向控制器103間之緩衝器;一第二先進先出緩衝 器502,包含一第二傳送FIF0 502a與一第二接收fif〇 502b,其架構與功能與第一實施例中所述相仿,所差者主 要在於本實施例之第二先進先出緩衝器502並非設置於第 二媒體存取控制器102b中,而係作為第二實體層電路1〇比 與資料流向控制器間103之緩衝器;一資料流向控制器ι〇3 ,其架構與功能與第一較佳實施例中所述相仿,所差者主 要在於本實施例之資料流向控制器1〇3係耦接於第—與第 二先進先出緩衝器402、502以及一單一媒體存取控制器 108之間,另外’本實施例之資料流向控制器1〇3於傳送時 係依據該媒體存取控制器所輸出之封包資訊來決定傳送路 徑,例如當某一封包之資訊包含第一 MAC位址資料流向 控制器103即選擇耦接第一傳送FIF〇 4〇2a以傳送封包,而 當另-封包之資訊包含第二MAC位址時,資料流向控制器 1379567 103即選擇耦接第二傳送fiF0 5〇2a來傳送封包;前述單一 媒體存取控制器108,其架構與功能與第一實施例中所述之 第一或第二媒體存取控制器102a、i〇2b相仿,所差者主要 在於本實施例之媒體存取控制器係依據第二時脈Clk2來運 作’且包含如第一較佳實施例所述之目的位址辨識器6〇2a ’其用來辨識待傳送資料之目的位址,藉以提供一辨識訊 號予一 MAC位址分配器,該]viAC位址分配器再將該待傳 送資料附加第一或第二MAC位址以構成封包;一主機介面 控制器104’其架構與功能與第一較佳實施例中所述相仿, 所差者主要在於本實施例之主機介面控制器1(M係耦接該 單一媒體存取控制器108而非資料流向控制器1 〇3 ;以及一 時脈產生器107’其提供一第一時脈cikl予實體層電路1〇1 以及第一與第二先進先出緩衝器402、502,並提供一第二 時脈Clk2予該資料流向控制器1 〇3、該媒體存取控制器以 及該主機介面控制器1〇4,其中該第二時脈cik2為該第一 時脈Clkl之二倍或二倍以上。 上述資料流向控制器之實施例示意圖如圖13所示,其 與圖6所示之資料流向控制器1〇3之主要差別在於傳送規 則控制器602,由於本實施例中資料流向控制器1〇3係接收 單一媒體存取控制器108所輸出之封包,該封包中已包含 有第一 MAC位址或第二MAC位址之資訊,因此傳送規則 控制器103只要利用一 MAC位址辨識器6〇2d來辨識出該 封包所包含之MAC位址,即能輸出一控制訊號予路徑選擇 器603來選擇將該封包輸出至第一或第二先進先出緩衝器 21 1379567 402、502。 另-月參閱圖14,其係單—媒體存取控制器ι〇8之實施 例丁意目 > 圓所不,該單一媒體存取控制器與圖* 或園5之第—或第二媒體存取控制器102a、1{)2b之主要差 另L含·一目的位址辨識器108a,用來辨識待傳送 資料之目的位址,並產生—辨識訊號’本實施例中,該目 的位址辨識器1G8a與第—較佳實施例所述者相同儲存有 最近特定筆數之已傳送資料所對應之目的位址且當該辨 j訊號為第-數位值時,代表待傳送資料之目的位址與先 前某筆經由前述第-先進先出緩衝器402所傳送之資料之 目的位址相同,當該辨識訊號為第二數位值時代表待傳 送資料之目的位址與先前某筆經由前述第二先進先出緩衝 f 502所傳送之資料之目的位址相同而當該辨識訊號為 一第二數位值時,代表待傳送資料之目的位址與最近特定 筆數之已傳送資料所㈣之目的位址均不相同;以及一 mac位址分配器祕,用來依據該辨識訊號來決^將 送資料附加第-或第二MAC位址以構成封包,當辨識訊號 為第-數位值,MAC位址分配器職即將相對應之 料附上第- MAC位址以構成封包來傳送,當辨識訊號為第 二數位值,MAC位址分配器1()8b即將相對應之傳送資料附 上第二MAC位址以構成封包來傳送’而當辨識訊號為第三 數位值’MAC位址分配器娜將相對應之傳送資料隨機了 輪流、或依照-預定順序附上第一及第=MAC位址其令之 一以構成封包來傳送n與第-較佳實施例不同處2 22 1379567 有該單-媒體存取控制器1G8包含—先進先出緩衝器職 ’其具有一傳送FIFO與一接收FIF〇,該先進先出緩衝器 108c之運作與圖4或圖5之第-先進先出緩衝器術或第 二先進先出缓衝器502相仿,所差者僅在於此處之先進先 出緩衝器108c係一同步緩衝器。 請注意,上述目的位址辨識器1〇8a及MAC位址分配 器l〇8b亦可改設置於資料流向控制器1〇3之傳送規則控制 器602中,如圖15所示。本變化實施例中,單一媒體存取 控制器108之實施即如同圖4或圖5所示,所輸出之封包 包含一原始MAC位址以及一目的位址,而目的位址辨識器 l〇8a辨識待傳送封包所包含之目的位址以產生辨識訊號, MAC位址分配器108b則依據辨識訊號來使用第一或第二 MAC位址以取代該待傳送封包_之原始mAC位址,並控 制路徑選擇器603將MAC位址取代後之封包輸出至第—戈 第二傳送 FIFO 402a、502a。 综上所述,本發明之第二較佳實施例亦提供了 一網路 控制器以處理二個實體網路路徑之資料傳收,然而類似第 一實施例,二個以上之實體網路路徑之資料傳收亦能為本 發明所支持,如圖16所示。此外,類似第一實施例,本實 施例中,第一先進先出緩衝器402、第一實體層電路i〇la 與第一網珞埠10等構成之第一實體網路路徑與第二先進先 出緩衝器502、第二實體層電路l〇lb及第二網路埠u等構 成之第二實體網路路徑可運作在不同頻率,如圖17所示, 其中第一實體網路路徑係依據第一時脈運作Clkl,而第二 23 1379567 至於第二時脈 、Clk4高者之 實體網路路徑係依據第四時脈ak4運作, ⑽於中為第_或第^脈較au 至少二倍。 准以上所述者,僅為本發明之較佳實施例而已,當不 能以此限^本發明實施之範圍,即依本發明中請專利i圍 及發明說㈣容所作之等效變化與修飾,皆屬本發明專利 可能涵蓋之範圍。 【圖式簡單說明】 圖1是本發明之網路介面控制器第一實施例之示意圖 > 圖2是圖1之實體層電路所包含之第一實體層電路之 一實施例示意圖; 圖3是圖1之實體層電路所包含之第二實體層電路之 一實施例示意圖; 圖4是圖1之媒體存取控制器所包含之第一媒體存取 控制器之一實施例示意圖; 圖5是圖1之媒體存取控制器所包含之第二媒體存取 控制器之一實施例示意圖; 圖6是圖1之資料流向控制器之一實施例示意圖; 圖7是圖1之資料流向控制器所包含之接收規則控制 器之另一實施例示意圖; 圖8是圖1之資料流向控制器所包含之接收規則控制 器之又一實施例示意圖; 24 1379567 圖9是圖8之仲裁器之一實施例示意圖; 圖10是圖1之網路介面控制器之一變化實施例示意圖 , 圖11是圖1之網路介面控制器之另一變化實施例示意 圖; 圖12是本發明之網路介面控制器第二實施例之示意圖 圖13是圖12之資料流向控制器之一實施例示意圖; 圖14是圖12之單一媒體存取控制器之一實施例示意
fSJ . 園, 圖15是圖12之資料流向控制器之另一實施例示意圖 圖16是圖12之網路介面控制器之一變化實施例示意 圖;以及 圖17是圖12之網路介面控制器之另一變化實施例示 意圖。 25 1379567 【主要元件符號說明】 10、11、12網路埠 網路介面 100 、 1001 、 100_2 、 1003 、 100_4 、 100_5 控制器 101、 101a、101b、101c 實體層電路 102、 102a、102b、102C媒體存取控制器 103 資料流向控制器 104 主機介面控制器 105 主機介面 106 主機
107 時脈產生器 108 單一媒體存取控制器 201 收發器 202 轉換電路 203、303 媒體獨立介面 204 MII控制器
205 自動訊息交換電路 401 MAC傳收電路 402、502、160 FIFO
402a、502a、160a 傳送 FIFO 402b、502b、160b 接收 FIFO 601、701 接收規則控制器 602 傳送規則控制器 602a 目的位址辨識器 602b FIFO使用空間監測器 602c 傳送仲裁器 603 路徑選擇器 700 暫存器 601c、701a、701b 比較器 26