CN101674335A - 具有多个传输端口的单一网络接口装置与其方法 - Google Patents
具有多个传输端口的单一网络接口装置与其方法 Download PDFInfo
- Publication number
- CN101674335A CN101674335A CN200810160875A CN200810160875A CN101674335A CN 101674335 A CN101674335 A CN 101674335A CN 200810160875 A CN200810160875 A CN 200810160875A CN 200810160875 A CN200810160875 A CN 200810160875A CN 101674335 A CN101674335 A CN 101674335A
- Authority
- CN
- China
- Prior art keywords
- controller
- buffer
- package
- data
- physical layer
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Landscapes
- Small-Scale Networks (AREA)
Abstract
本发明揭露一种具有多个传输端口的单一网络接口装置,该网络接口装置可支援二个或二个以上的实体网络传送路径所进行的数据传收,并透过一主机接口来上传所接收的数据至一主机,或透过该主机接口来由该主机下载待传送至网络的数据。故藉由本发明,可增加网络通信的速率,并能进一步利用主机接口的频宽。
Description
技术领域
本发明是关于一种网络接口装置及其方法,尤其是一种能增加数据传收效率的网络接口装置及其方法。
背景技术
现有的网络数据传收机制是一个网络端口对应一个网络控制器,藉以经由一主机接口(如PCI Express接口)在主机与网络间进行数据的传送与接收。
以PCI Express 1.1接口为例,其使用依2.5GHz时钟速率运作的连线,一PCI Express通道(Lane)于单一方向可达到每秒250MB的频宽,于上行或下行方向都有250MB的频宽。PCI Express接口可结合多个通道,提供更高频宽,因此x8PCI Express接口具有单一通道的8倍频宽(即单一方向的频宽为2GB/s),又例如一般显示卡使用的x16PCI Express接口,拥有的单一方向总频宽为每秒4GB。
然而以Gigabit以太网络控制器为例,其所提供的数据传输速度往往受限于网络环境而远低于Gigabit/每秒(传送或接收),但许多PCI-E接口的Gigabit乙太网络控制器却是x8PCI-E接口,其接口频宽可达2GB/s,显见尚有一半以上的PCI-E的频宽未能被网络控制器充份使用。倘若以目前PCI Express 2.0接口而言,其将时钟速率提升一倍到达5.0GHz,亦即可将接口频宽提升一倍,使x8PCI Express 2.0的单一方向的频宽可达每秒4GB,因此将有更多的频宽未能被网络传输充份利用。
发明内容
因此,本发明目的之一在于提供一种网络接口装置以解决前述问题。
本发明另一目的在于利用一网络控制器来处理多个网络端口所形成的多个实体网络连线的数据,藉以增加网络通信效率与该网络控制器与一主机间的接口的频宽使用率。
依据本发明所揭露的网络接口控制器的一实施例,其包含:一实体层电路,包括一第一实体层电路以及一第二实体层电路,其分别用来经由一第一网络端口以及一第二网络端口来执行封包的传送与接收;一媒体存取控制器,包括一第一媒体存取控制器以及一第二媒体存取控制器,该第一媒体存取控制器依据待传送数据所对应的一目的地址来产生一封包以输出,以及于接收一封包时依据一第一MAC地址来处理该封包,该第二媒体存取控制器则依据待传送数据所对应的一目的地址来产生一封包以输出,以及于接收一封包时依据一第二MAC地址来处理该封包;一数据流向控制器,耦接至第一与第二媒体存取控制器,用来依据一接收规则来接收第一或第二媒体存取控制器所输出的数据,以及依据一传送规则来传送数据至第一或第二媒体存取控制器;一主机接口控制器,耦接至数据流向控制器与一主机接口(例如PCIExpress接口),用来接收数据流向控制器所输出的数据并将其经由主机接口上传至一主机,以及经由主机接口由主机下载数据后,输出该数据至数据流向控制器。
依据本发明所揭露的网络接口控制器的另一实施例,其包含:一实体层电路,包括一第一实体层电路以及一第二实体层电路,其分别用来经由一第一网络端口以及一第二网络端口来执行封包的传送与接收;一第一先进先出缓冲器,耦接该第一实体层电路;一第二先进先出缓冲器,耦接该第二实体层电路;一数据流向控制器,耦接该第一与第二先进先出缓冲器,用来依据一接收规则来接收第一或第二先进先出缓冲器所输出的数据,以及依据一传送规则来传送数据至第一或第二先进先出缓冲器;一单一媒体存取控制器,用于依据待传送数据所对应的一目的地址来产生一具有第一或第二MAC地址的封包以输出,以及于接收一封包时依据第一及第二MAC地址来处理该封包;一主机接口控制器,耦接至该单一媒体存取控制器与一主机接口(例如PCI Express接口),用来接收单一媒体存取控制器所输出的数据并将其经由主机接口上传至一主机,以及经由主机接口由主机下载数据后,输出该数据至单一媒体存取控制器。
依据本发明所揭露的一种单一网络接口装置的一实施例,其包含:一第一收发器,用来经由一第一网络线来传送与接收封包;一第二收发器,用来经由一第二网络线来传送与接收封包;一第一缓冲器,耦接该第一收发器,用来暂存待传送至该第一收发器的封包,并用来暂存由该第一收发器所接收的封包;一第二缓冲器,耦接该第二收发器,用来暂存待传送至该第二收发器的封包,并用来暂存由该第二收发器所接收的封包;一主机接口电路,耦接该第一缓冲器与该第二缓冲器,用来使该第一缓冲器与该第二缓冲器的其中一个透过一主机接口与一电脑主机进行数据的传送。
附图说明
图1是本发明的网络接口控制器第一实施例的示意图;
图2是图1的实体层电路所包含的第一实体层电路的一实施例示意图;
图3是图1的实体层电路所包含的第二实体层电路的一实施例示意图;
图4是图1的媒体存取控制器所包含的第一媒体存取控制器的一实施例示意图;
图5是图1的媒体存取控制器所包含的第二媒体存取控制器的一实施例示意图;
图6是图1的数据流向控制器的一实施例示意图;
图7是图1的数据流向控制器所包含的接收规则控制器的另一实施例示意图;
图8是图1的数据流向控制器所包含的接收规则控制器的又一实施例示意图;
图9是图8的仲裁器的一实施例示意图;
图10是图1的网络接口控制器的一变化实施例示意图;
图11是图1的网络接口控制器的另一变化实施例示意图;
图12是本发明的网络接口控制器第二实施例的示意图;
图13是图12的数据流向控制器的一实施例示意图;
图14是图12的单一媒体存取控制器的一实施例示意图;
图15是图12的数据流向控制器的另一实施例示意图;
图16是图12的网络接口控制器的一变化实施例示意图;以及
图17是图12的网络接口控制器的另一变化实施例示意图。
【主要元件符号说明】
10、11、12网络端口
100、100_1、100_2、100_3、100_4、100_5网络接口控制器
101、101a、101b、101c实体层电路
102、102a、102b、102C媒体存取控制器
103数据流向控制器
104主机接口控制器
105主机接口
106主机
107时钟产生器
108单一媒体存取控制器
201收发器
202转换电路
203、303媒体独立接口
204MII控制器
205自动信息交换电路
401MAC传收电路
402、502、160FIFO
402a、502a、160a传送FIFO
402b、502b、160b接收FIFO
601、701接收规则控制器
602传送规则控制器
602a目的地址辨识器
602b FIFO使用空间监测器
602c传送仲裁器
603路径选择器
700暂存器
601c、701a、701b比较器
具体实施方式
以下就本发明的网络接口控制器的各实施例分别说明之。
第一较佳实施例:
请参阅图1,其是本发明的网络接口控制器的第一较佳实施例示意图,如图所示,该网络接口控制器100包含:一实体层电路101(Physical LayerCircuit;简称PHY),包括一第一实体层电路101a以及一第二实体层电路101b,其分别用来经由一第一网络端口10以及一第二网络端口11来执行封包的传送与接收,该第一网络端口10以及一第二网络端口11于本实施例中是RJ45连接器;一媒体存取控制器102(Media Access Controller;简称MAC),包括一第一媒体存取控制器102a以及一第二媒体存取控制器102b,该第一媒体存取控制器102a依据待传送数据所对应的一目的地址(DestinationAddress)来产生一封包以输出,以及于接收一封包时依据一第一MAC地址(MAC Address)来处理该封包,该第二媒体存取控制器102b则依据待传送数据所对应的一目的地址来产生一封包以输出,以及于接收一封包时依据一第二MAC地址来处理该封包;一数据流向控制器103,耦接至第一与第二媒体存取控制器102a、102b,用来依据一接收规则来接收第一或第二媒体存取控制器102a、102b所输出的数据,以及依据一传送规则来传送数据至第一或第二媒体存取控制器102a、102b;一主机接口控制器104,耦接至数据流向控制器103与一主机接口105(例如PCI Express 1.1接口或通用串行总线(Universal Serial Bus;USB)接口),用来接收数据流向控制器103所输出的数据并将其经由主机接口105上传至一主机106,以及经由主机接口105由主机106下载数据后,输出该数据至数据流向控制器103;以及一时钟产生器107,用来提供一第一时钟Clk1予该实体层电路101以及该媒体存取控制器102,并提供一第二时钟Clk2予该数据流向控制器103及该主机接口控制器104,其中该第二时钟Clk2为该第一时钟Clk1的二倍或二倍以上。
请参阅图2,其是前述第一实体层电路101a的示意图,由图可知,该第一实体层电路101a包含:一收发器201(Transceiver),用来依据IEEE 802.3的标准规范执行封包的传送与接收;一转换电路202,用来依据IEEE 802.3的标准规范将第一媒体存取控制器102a所输出的封包转换为适当的信号以传送至网络,以及将从网络接收的信号转换为第一媒体存取控制器102a可进一步处理的封包;一第一媒体独立接口203(Media Independent Interface;简称MII),用来作为第一实体层电路101a与第一媒体存取控制器102a的沟通接口;一MII控制器204,用以控制该第一媒体独立接口203;以及一自动信息交换电路205,用来与网络连接对象交换彼此的传收能力等资讯,在此需注意的是本发明各实施例的网络接口控制器100可支援多种传输速度,例如支援10Megabit、100Megabit以及1Gigabit的传输速度,故一旦自动信息交换电路确认双方所共同支援的最大连线速度,本发明的网络接口控制器100即可运作于该最大连线速度,而关于此连线速度确认机制请参考美国第RE 39,116与RE 39,405号专利的说明。另外,由于本实施例中第二实体层电路101b的架构与第一实体层电路101a相同,如图3所示,故不再重复说明。
请参阅图4,其是前述第一媒体存取控制器102a的示意图,如图所示,该第一媒体存取控制器102a包含:一MAC传收电路401,用来将待传送的数据封装(Encapsulate)成一封包并透过前述第一媒体独立接口203传送至第一实体层电路101a,并用来将经由第一媒体独立接口203所接收的一封包加以过滤(Filter)并输出至数据流向控制器103;以及一第一先进先出缓冲器402(First In,First Out;简称FIFO),耦接于该MAC传收电路401及该数据流向控制器103之间,包含一第一传送FIFO 402a用来暂存前述待传送的数据,以及一第一接收FIFO 402b用来暂存前述过滤后的数据。请注意,本实施例中,该第一先进先出缓冲器402是一非同步先进先出缓冲器(Asynchronous FIFO),其与MAC传收电路401间的存取速率依据前述第一时钟Clk1,而与数据流向控制器103间的存取速率依据前述第二时钟Clk2,关于非同步先进先出缓冲器的背景知识可参考美国专利第5951635号、第6845414号及第7315600号等专利内容。另外,由于本实施例中第二媒体存取控制器102b的架构与第一媒体存取控制器102a相同,如图5所示,故不再重复说明。
请参阅图6,其是前述数据流向控制器103的示意图,如图所示,该数据流向控制器103包含一接收规则控制器601,其用来实现先前提及的接收规则,该接收规则控制器601包含:一第一指标差计算器601a,用来计算第一接收FIFO 402b的写入指标(Write Pointer)与读取指标(Read Pointer)的差异(后称第一使用空间Distance 1),其中该写入指标用来记录写入第一接收FIFO 402b的数据量,该读取指标则用来记录由第一接收FIFO 402b读出的数据量,故该第一使用空间Distance 1指第一接收FIFO 402b的已使用空间;一第二指标差计算器601b,用来计算前述第二接收FIFO的写入指标与读取指标的差异(后称第二使用空间Distance 2),该第二使用空间Distance 2对应第二接收FIFO 502b的剩余储存空间;一使用空间比较器601c,用来比较该第一使用空间Distance 1与该第二使用空间Distance 2,藉以产生一比较信号(后称Comp),本实施例中,当第一使用空间Distance 1大于第二使用空间Distance 2时,Comp为第一逻辑值,反之则为第二逻辑值。
请继续参阅图6,数据流向控制器103另包含一传送规则控制器602,其用来实现前述的传送规则,包含:一目的地址辨识器602a,依据主机106所提供的资讯来辨识待传送数据所对应的目的地址,并将该目的地址与已传送数据所对应的目的地址来加以比较,藉以产生一辨识信号,本实施例中,该目的地址辨识器602a为一查表电路(look-up table),储存有最近特定笔数的已传送数据所对应的目的地址,且当该辨识信号为第一数位值时,代表待传送数据的目的地址与先前某笔经由第一FIFO 402所传送的数据的目的地址相同,当该辨识信号为第二数位值时,代表待传送数据的目的地址与先前某笔经由第二FIFO 502所传送的数据的目的地址相同,而当该辨识信号为一第三数位值时,代表待传送数据的目的地址与最近特定笔数的已传送数据所对应的目的地址均不相同;一FIFO使用空间监测器602b,其实施例如同该接收规则控制器601,所差者仅在于该FIFO使用空间监测器602b比较该第一与第二传送FIFO 402、502的读写指标差来产生一监测信号,当该监测信号为第一逻辑值时表示第一传送FIFO 402a的已使用空间较大,若为第二逻辑值则表示第二传送FIFO 502a的已使用空间较大;以及一传送仲裁器602c,用来依据该辨识信号及该监测信号产生一传送控制信号。本实施例中,当辨识信号为第一数位值时,该传送控制信号为第一逻辑值;当辨识信号为第二数位值时,该传送控制信号为第二逻辑值;当辨识信号为第三数位值且监测信号为第二逻辑值时,该传送控制信号为第一逻辑值;当辨识信号为第三逻辑值且监测信号为第一逻辑值时,传送控制信号为第二逻辑值。此外,在本发明另一实施例中,可仅依据该目的地址辨识器602a的辨识信号来产生传送控制信号,其中当辨识信号为第三数位值时,仲裁器602c可随机、依序轮流或依据一预定规则来产生具有第一逻辑值或第二逻辑值的传送控制信号。在本发明又一实施例中,上述目的地址辨识的工作可由主机106执行,亦即主机106依据本发明的网络接口控制器100的一驱动程序来执行目的地址辨识的工作,并透过前述主机接口105、主机接口控制器104来提供辨识结果予传送规则控制器602。
请继续参阅图6,数据流向控制器103尚包含一路径选择器603,其耦接前述接收规则控制器601、传送规则控制器602以及主机接口控制器104,用来依据Comp的逻辑值将第一或第二接收FIFO 402b、502b耦接至主机接口控制器104,并由主机接口控制器104将第一或第二接收FIFO 402b、502b的数据透过主机接口105上传至主机106,本实施例中,当Comp为第一逻辑值时,路径选择器603将第一接收FIFO 402b耦接至主机接口控制器104;而当Comp为第二逻辑值时,路径选择器603将第二接收FIFO 502b耦接至主机接口控制器104。另外,路径选择器603亦依据传送规则控制器602的传送控制信号来将主机接口控制器104耦接至第一或第二传送FIFO 402a、502a,使主机接口控制器104将待传送数据输出至该第一或第二传送FIFO 402a、502a,本实施例中,当传送控制信号为第一逻辑值时,路径选择器603将主机接口控制器104耦接至第一传送FIFO 402a;当传送控制信号为第二逻辑值时,路径选择器603将主机接口控制器104耦接至第二传送FIFO 502a。再者,本实施例中,路径选择器603的实施为一开关电路,由于开关电路属本技术领域的公知常识,故在此不予赘述。
请参阅图7,其是本发明接收规则控制器701的另一实施例示意图,其与图6的接收规则控制器601的差别在于本实施例另包含:一第一比较器701a,用来比较第一使用空间Distance 1与一暂存器700所储存的一使用阈值,并产生一第一比较信号(后称Comp1),本实施例中当第一使用空间Distance1大于该使用阈值时,第一比较信号为第一逻辑值,反之则为第二逻辑值;一第二比较器701b,用来比较第二使用空间Distance 2与该使用阈值,并产生一第二比较信号(后称Comp2),本实施例中当第二使用空间Distance 2大于该使用阈值时,第二比较信号为第一逻辑值,反之则为第二逻辑值;一计时器701c,用来依据一预定工作周期产生一计时信号,亦即该计时信号会于一预定时间后由第一/第二逻辑值转为第二/第一逻辑值,且当Comp逻辑值转换时,该计时器701c会进行重置,并从输出第二逻辑值的计时信号来重新开始;以及一接收仲裁器701d,用来接收Comp、Comp1、Comp2及计时信号以产生一接收控制信号。
图7所示的实施例中,当Comp1或Comp2为第二逻辑值时,代表第一或第二接收FIFO 402b、502b所储存的数据少于或等于该使用阈值(本实施例中该使用阈值设为零),因此接收仲裁器701d无需依据计时信号来定期轮询(polling)第一及第二接收FIFO 402b、502b,仅需依据Comp来产生接收控制信号以通知路径选择器603将第一或第二接收FIFO 402b、502b耦接至主机接口控制器104,换言之,当Comp为第一/第二逻辑值时,代表仅第一/第二接收FIFO 402b、502b存有需处理的数据,因此接收仲裁器701d产生具有第一/第二逻辑值的接收控制信号,使路径选择器603将第一/第二接收FIFO402b/502b耦接至主机接口控制器104;而当Comp1与Comp2均为第一逻辑值时,代表第一及第二接收FIFO 402b、502b所储存的数据均大于该使用阈值,因此接收仲裁器701d依据Comp及计时信号来产生该接收控制信号以通知路径选择器603将第一或第二接收FIFO 402b、502b耦接至主机接口控制器104,亦即接收控制信号于Comp由第一/第二逻辑值转换为第二/第一逻辑值时(此时计时信号重置为第二逻辑值),指示将第二/第一接收FIFO 402b、502b耦接至主机接口控制器104,又于前述预定时间后计时信号由第二逻辑值转换为第一逻辑值时,指示将第一/第二接收FIFO 402b、502b耦接至主机接口控制器104,藉此接收仲裁器701d便能依据Comp来指示优先处理待处理数据较多的第一或第二接收FIFO 402b、502b,又能依据计时信号以定时轮询(polling)第一及第二接收FIFO 402b、502b是否有数据需处理,以避免等待时间过久。请注意,前述Comp1与Comp2为第二逻辑值时,接收仲裁器701d依据Comp及计时信号来产生接收控制信号的运作等同一XOR闸。
请参阅图8,其是本发明接收规则控制器的另一实施例示意图,本实施例的接收规则控制器801包含:前述第一指标差计算器601a,用来计算第一使用空间Distance 1;前述第二指标差计算器601b,用来计算第二使用空间Distance 2;一暂存器700,用来储存一致能阈值;一第一比较器701a,用来比较第一使用空间Distance 1与该致能阈值,藉以产生一第一致能信号(后称En1),本实施例中当该第一使用空间Distance 1大于该致能阈值,En1为第一逻辑值,反之则为第二逻辑值;一第二比较器701b,用来比较第二使用空间Distance 2与该致能阈值,藉以产生一第二致能信号(后称En2),本实施例中当该第二使用空间大于该致能阈值,En2为第一逻辑值,反之则为第二逻辑值;前述计时器701c,用来产生前述计时信号;以及一接收仲裁器701d,如图9所示,用来依据En1、En2及计时信号TS以产生一接收控制信号。请参阅图9,本实施例中,当En1为第一逻辑值而En2为第二逻辑值时,代表第一使用空间Distance 1大于该致能阈值而第二使用空间Distance 2小于该致能阈值,此时接收控制信号为第一逻辑值,用以指示路径选择器603将主机接口控制器104耦接至第一接收FIFO 402b;当En1为第二逻辑值而En2为第一逻辑值时,代表第一使用空间Distance1小于该致能阈值但第二使用空间Distance2大于该致能阈值,此时接收控制信号为第二逻辑值,用以指示路径选择器603将主机接口控制器104耦接至第二接收FIFO 502b;当En1与En2均为第一逻辑值时,若Comp为第一逻辑值,代表第一使用空间Distance 1大于第二使用空间Distance 2,此时接收控制信号为第一逻辑值,以指示路径选择器603将主机接口控制器104耦接至第一接收FIFO 402b,但若Comp为第二逻辑值,代表第二使用空间Distance 2大于第一使用空间Distance 1,则接收控制信号指示路径选择器603将主机接口控制器104耦接至第二接收FIFO 502b;而当En1与En2均为第二逻辑值时,仲裁器701d仅依据计时信号TS的逻辑值转变来指示路径选择器603进行切换,亦即当计时信号TS为第一/第二逻辑值,路径选择器603将主机控制器104耦接至第一/第二接收FIFO 402b/502b。
前述实施例虽以计算FIFO的读写指标差为例,然而FIFO为避免发生满溢(Overflow)及/或短缺(Underrun)的情形,可包含一监测电路来监测本身的储存空间使用量,例如包含一计数器来计数共有多少Byte存入FIFO以及多少Byte被读出FIFO,因此该计数器的计数值亦可用来取代前述实施例的读写指标差。此外,也可使用不同阈值分别与前述第一及第二使用空间来比较,藉以增加实施的可能性。事实上,本领域技术人员应当能依据本发明的揭露内容来作一均等的变化实施。
在另一实施例中,可依据一传送规则使得该第一实体层电路101a的第一收发器201与该第一实体层电路101b的第二收发器201实质上达到负载平衡(load balance),例如传送规则包含依据第一及第二收发器201的数据流量(Throughput)多寡来优先选择数据流向较少者执行传送。而上述各个装置于实作中可为网络接口卡(Network Interface Card,NIC)或为主机板内建网络(LAN On Motherboard-LOM)。
综上所述,本发明的第一较佳实施例提供了一网络控制器以处理二个实体网络路径的数据传收,然而二个以上的实体网络路径的数据传收亦能为本发明所支持,如图10所示,然需注意的是图10的第三时钟Clk3为第一时钟Clk1的三倍或三倍以上,且数据流向控制器需103比较第一、第二及第三媒体存取控制器102a、102b、102c的第一、第二及第三FIFO的使用空间以及待传送数据的目的地址等参数,藉以决定第一、第二、第三FIFO与主机接口控制器104的耦接关系。此外,第一媒体存取控制器102a与第一实体层电路101a及第一网络端口10等构成的第一实体网络路径与第二媒体存取控制器102b、第二实体层电路101b及第二网络端口11等构成的第二实体网络路径可运作在不同频率,如图11所示,第一实体网络路径依据第一时钟Clk1运作,而第二实体网络路径依据第四时钟Clk4运作,至于第二时钟Clk2于本实施例中为第一或第四时钟Clk1、Clk4较高者的至少二倍。
第二较佳实施例:
请参阅图12,其是本发明的网络接口控制器的第二较佳实施例示意图,如图所示,该网络接口控制器1003包含:一实体层电路101,包括一第一实体层电路101a以及一第二实体层电路101b,其架构与功能与第一较佳实施例中所述相同,于此不再重复叙述;一第一先进先出缓冲器402,包含一第一传送FIFO 402a以及一第一接收FIFO 402b,其架构与功能与第一实施例中所述相仿,所差者主要在于本实施例的第一先进先出缓冲器402并非设置于第一媒体存取控制器102a中,而作为第一实体层电路101a与数据流向控制器103间的缓冲器;一第二先进先出缓冲器502,包含一第二传送FIFO 502a与一第二接收FIFO 502b,其架构与功能与第一实施例中所述相仿,所差者主要在于本实施例的第二先进先出缓冲器502并非设置于第二媒体存取控制器102b中,而作为第二实体层电路101b与数据流向控制器间103的缓冲器;一数据流向控制器103,其架构与功能与第一较佳实施例中所述相仿,所差者主要在于本实施例的数据流向控制器103耦接于第一与第二先进先出缓冲器402、502以及一单一媒体存取控制器108之间,另外,本实施例的数据流向控制器103于传送时依据该媒体存取控制器所输出的封包资讯来决定传送路径,例如当某一封包的资讯包含第一MAC地址,数据流向控制器103即选择耦接第一传送FIFO 402a以传送封包,而当另一封包的资讯包含第二MAC地址时,数据流向控制器103即选择耦接第二传送FIFO 502a来传送封包;前述单一媒体存取控制器108,其架构与功能与第一实施例中所述的第一或第二媒体存取控制器102a、102b相仿,所差者主要在于本实施例的媒体存取控制器依据第二时钟Clk2来运作,且包含如第一较佳实施例所述的目的地址辨识器602a,其用来辨识待传送数据的目的地址,藉以提供一辨识信号予一MAC地址分配器,该MAC地址分配器再将该待传送数据附加第一或第二MAC地址以构成封包;一主机接口控制器104,其架构与功能与第一较佳实施例中所述相仿,所差者主要在于本实施例的主机接口控制器104耦接该单一媒体存取控制器108而非数据流向控制器103;以及一时钟产生器107,其提供一第一时钟Clk1予实体层电路101以及第一与第二先进先出缓冲器402、502,并提供一第二时钟Clk2予该数据流向控制器103、该媒体存取控制器以及该主机接口控制器104,其中该第二时钟Clk2为该第一时钟Clk1的二倍或二倍以上。
上述数据流向控制器的实施例示意图如图13所示,其与图6所示的数据流向控制器103的主要差别在于传送规则控制器602,由于本实施例中数据流向控制器103接收单一媒体存取控制器108所输出的封包,该封包中已包含有第一MAC地址或第二MAC地址的资讯,因此传送规则控制器103只要利用一MAC地址辨识器602d来辨识出该封包所包含的MAC地址,即能输出一控制信号予路径选择器603来选择将该封包输出至第一或第二先进先出缓冲器402、502。
另请参阅图14,其是单一媒体存取控制器108的实施例示意图,如图所示,该单一媒体存取控制器108与图4或图5的第一或第二媒体存取控制器102a、102b的主要差别在于另包含:一目的地址辨识器108a,用来辨识待传送数据的目的地址,并产生一辨识信号,本实施例中,该目的地址辨识器108a与第一较佳实施例所述者相同,储存有最近特定笔数的已传送数据所对应的目的地址,且当该辨识信号为第一数位值时,代表待传送数据的目的地址与先前某笔经由前述第一先进先出缓冲器402所传送的数据的目的地址相同,当该辨识信号为第二数位值时,代表待传送数据的目的地址与先前某笔经由前述第二先进先出缓冲器502所传送的数据的目的地址相同,而当该辨识信号为一第三数位值时,代表待传送数据的目的地址与最近特定笔数的已传送数据所对应的目的地址均不相同;以及一MAC地址分配器108b,用来依据该辨识信号来决定将待传送数据附加第一或第二MAC地址以构成封包,当辨识信号为第一数位值,MAC地址分配器108b即将相对应的传送数据附上第一MAC地址以构成封包来传送,当辨识信号为第二数位值,MAC地址分配器108b即将相对应的传送数据附上第二MAC地址以构成封包来传送,而当辨识信号为第三数位值,MAC地址分配器108b将相对应的传送数据随机、轮流、或依照一预定顺序附上第一及第二MAC地址其中之一以构成封包来传送。另外,与第一较佳实施例不同处尚有该单一媒体存取控制器108包含一先进先出缓冲器108c,其具有一传送FIFO与一接收FIFO,该先进先出缓冲器108c的运作与图4或图5的第一先进先出缓冲器402或第二先进先出缓冲器502相仿,所差者仅在于此处的先进先出缓冲器108c是一同步缓冲器。
请注意,上述目的地址辨识器108a及MAC地址分配器108b亦可改设置于数据流向控制器103的传送规则控制器602中,如图15所示。本变化实施例中,单一媒体存取控制器108的实施即如同图4或图5所示,所输出的封包包含一原始MAC地址以及一目的地址,而目的地址辨识器108a辨识待传送封包所包含的目的地址以产生辨识信号,MAC地址分配器108b则依据辨识信号来使用第一或第二MAC地址以取代该待传送封包中的原始MAC地址,并控制路径选择器603将MAC地址取代后的封包输出至第一或第二传送FIFO 402a、502a。
综上所述,本发明的第二较佳实施例亦提供了一网络控制器以处理二个实体网络路径的数据传收,然而类似第一实施例,二个以上的实体网络路径的数据传收亦能为本发明所支持,如图16所示。此外,类似第一实施例,本实施例中,第一先进先出缓冲器402、第一实体层电路101a与第一网络端口10等构成的第一实体网络路径与第二先进先出缓冲器502、第二实体层电路101b及第二网络端口11等构成的第二实体网络路径可运作在不同频率,如图17所示,其中第一实体网络路径依据第一时钟运作Clk1,而第二实体网络路径依据第四时钟Clk4运作,至于第二时钟Clk2于本实施例中为第一或第四时钟较Clk1、Clk4高者的至少二倍。
惟以上所述者,仅为本发明的较佳实施例而已,当不能以此限定本发明实施的范围,即依本发明权利要求及发明说明内容所作的等效变化与修饰,皆属本发明可能涵盖的范围。
Claims (31)
1.一种网络接口控制器,包含:
一第一实体层电路,用来经由一第一网络端口来传送与接收封包;
一第二实体层电路,用来经由一第二网络端口来传送与接收封包;
一第一媒体存取控制器,耦接该第一实体层电路,用来依据待传送数据所对应的一目的地址来产生封包以输出至该第一实体层电路,以及依据一第一MAC地址来处理由该第一实体层电路所接收的封包;
一第二媒体存取控制器,耦接该第二实体层电路,用来依据待传送数据所对应的一目的地址来产生封包以输出至该第二实体层电路,以及依据一第二MAC地址来处理由该第二实体层电路所接收的封包;
一数据流向控制器,耦接至该第一与第二媒体存取控制器,用来依据一接收规则来接收该第一或第二媒体存取控制器所输出的数据,以及依据一传送规则来传送数据至该第一或第二媒体存取控制器;
一主机接口控制器,耦接该数据流向控制器,用来接收该数据流向控制器所输出的数据并将其经由一主机接口上传至一主机,以及用来经由该主机接口由该主机下载数据后将其输出至该数据流向控制器。
2.如权利要求1所述的网络接口控制器,还包括:
一时钟产生器,用来提供一第一时钟予该第一实体层电路以及该第一媒体存取控制器,并用来提供一第四时钟予该第二实体层电路以及该第二媒体存取控制器,以及用来提供一第二时钟予该数据流向控制器及该主机接口控制器,其中该第二时钟为该第一时钟的二倍或二倍以上。
3.如权利要求2所述的网络接口控制器,其中该第四时钟等于或小于该第一时钟。
4.如权利要求1所述的网络接口控制器,其中该主机接口是一PCIExpress接口或是一USB接口。
5.如权利要求1所述的网络接口控制器,其中该第一实体层电路包含:
一第一收发器,用来经由该第一网络端口来执行封包的传送与接收;
一第一转换电路,用来将该第一媒体存取控制器所输出的封包转换为适当的信号以传送至该第一收发器;
一第一媒体独立接口,用来作为该第一实体层电路与该第一媒体存取接口的沟通接口;以及
一第一自动信息交换电路,用来与一网络连线对象交换资讯;以及
该第二实体层电路包含:
一第二收发器,用来经由该第二网络端口来执行封包的传送与接收;
一第二转换电路,用来将该第二媒体存取控制器所输出的封包转换为适当的信号以传送至该第二收发器;
一第二媒体独立接口,用来作为该第二实体层电路与该第二媒体存取接口的沟通接口;以及
一第二自动信息交换电路,用来与一网络连线对象交换资讯。
6.如权利要求1所述的网络接口控制器,其中该第一媒体存取控制器包含:
一第一MAC传收电路,用来将待传送的数据封装成一封包并透过该第一媒体独立接口传送至该第一实体层电路,并用来将经由该第一媒体独立接口所接收的一封包加以过滤以输出至该数据流向控制器;以及
一第一缓冲器,耦接于该第一MAC传收电路及该数据流向控制器之间,包含一第一传送缓冲器用来暂存前述待传送的数据,以及包含一第一接收缓冲器用来暂存前述过滤后的数据,该第一缓冲器是一非同步(Asynchronous)缓冲器,其与该第一MAC传收电路间的存取速率依据该第一时钟,而与该数据流向控制器间的存取速率依据该第二时钟;以及
该第二媒体存取控制器包含:
一第二MAC传收电路,用来将待传送的数据封装成一封包并透过该第一媒体独立接口传送至该第二实体层电路,并用来将经由该第二媒体独立接口所接收的一封包加以过滤以输出至该数据流向控制器;以及
一第二缓冲器,耦接于该第二MAC传收电路及该数据流向控制器之间,包含一第二传送缓冲器用来暂存前述待传送的数据,以及包含一第二接收缓冲器用来暂存前述过滤后的数据,该第二缓冲器是一非同步缓冲器,其与该第二MAC传收电路间的存取速率依据该第四时钟,而与该数据流向控制器间的存取速率依据该第二时钟。
7.如权利要求1所述的网络接口控制器,其中该数据流向控制器包含:
一传送规则控制器,用来依据一传送规则来产生一传送控制信号;
一接收规则控制器,用来依据一接收规则来产生一接收控制信号;以及
一路径选择器,用来依据该传送控制信号将该第一或第二传送缓冲器耦接至该主机控制接口,以及依据该接收控制信号将来第一或第二接收缓冲器耦接至该主机控制接口。
8.如权利要求7所述的网络接口控制器,其中该传送规则控制器包含:
一目的地址辨识器,用来依据该主机所提供的资讯来辨识待传送数据的一目的地址,藉以产生该传送控制信号。
9.如权利要求7所述的网络接口控制器,其中该接收规则控制器依据一第一接收缓冲器的储存空间使用状况与一第二接收缓冲器的储存空间使用状况来产生该接收控制信号。
10.如权利要求9所述的网络接口控制器,其中该接收规则控制器进一步依据一计时信号来产生该接收控制信号。
11.一种网络接口控制器,包含:
一第一实体层电路,用来经由一第一网络端口来传送与接收封包;
一第二实体层电路,用来经由一第二网络端口来传送与接收封包;
一第一缓冲器,耦接该第一实体层电路,包含一第一传送缓冲器用来暂存待传送至该第一实体层电路的封包,并包含一第一接收缓冲器用来由该第一实体层电路所接收的封包,该第一缓冲器是一非同步(Asynchronous)缓冲器;
一第二缓冲器,耦接该第二实体层电路,包含一第二传送缓冲器用来暂存待传送至该第二实体层电路的封包,并包含一第二接收缓冲器用来由该第二实体层电路所接收的封包,该第二缓冲器是一非同步缓冲器;
一数据流向控制器,耦接至该第一与第二缓冲器,用来依据一接收规则来接收该第一或第二缓冲器所输出的封包,以及依据一传送规则来传送封包至该第一或第二缓冲器;
一媒体存取控制器,耦接该数据流向控制器,用来依据待传送数据来产生封包以输出至该数据流向控制器,并过滤由该数据流向控制器所接收的封包以输出数据;
一主机接口控制器,耦接该媒体存取控制器,用来接收该媒体存取控制器所过滤的数据并将其经由一主机接口上传至一主机,以及用来经由该主机接口由该主机下载待传送数据后将其输出至该媒体存取控制器。
12.如权利要求11所述的网络接口控制器,还包括:
一时钟产生器,用来提供一第一时钟予该第一实体层电路与该第一缓冲器,并用来提供一第四时钟予该第二实体层电路以及该第二缓冲器,以及用来提供一第二时钟予该数据流向控制器、该媒体存取控制器以及该主机接口控制器,其中该第二时钟为该第一时钟的二倍或二倍以上。
13.如权利要求12所述的网络接口控制器,其中该第四时钟等于或小于该第一时钟。
14.如权利要求12所述的网络接口控制器,其中该主机接口是一PCIExpress接口或是一USB接口。
15.如权利要求12所述的网络接口控制器,其中该第一实体层电路包含:
一第一收发器,用来经由该第一网络端口来执行封包的传送与接收;
一第一转换电路,用来将该第一缓冲器所输出的封包转换为适当的信号以传送至该第一收发器;
一第一媒体独立接口,用来作为该第一实体层电路与该第一缓冲器的沟通接口;以及
一第一自动信息交换电路,用来与一网络连线对象交换资讯;以及
该第二实体层电路包含:
一第二收发器,用来经由该第二网络端口来执行封包的传送与接收;
一第二转换电路,用来将该第二缓冲器所输出的封包转换为适当的信号以传送至该第二收发器;
一第二媒体独立接口,用来作为该第二缓冲器与该第二媒体存取接口的沟通接口;以及
一第二自动信息交换电路,用来与一网络连线对象交换资讯。
16.如权利要求12所述的网络接口控制器,其中该媒体存取控制器包含:
一MAC传收电路,用来将待传送的数据封装成一封包并将其传送至该数据流向控制器,并用来将经由该数据流向控制器所接收的一封包加以过滤以输出至该主机接口控制器;以及
一缓冲器,耦接于该MAC传收电路及该主机接口控制器之间,包含一传送缓冲器用来暂存前述待传送的数据,以及包含一接收缓冲器用来暂存前述过滤后的数据。
17.如权利要求16所述的网络接口控制器,其中该媒体存取控制器进一步包含:
一目的地址辨识器,用来辨识待传送数据所对应的一目的地址,并产生一辨识信号;以及
一MAC地址分配器,用来依据该辨识信号以将待传送数据附加一第一MAC地址或一第二MAC地址以形成封包。
18.如权利要求12所述的网络接口控制器,其中该数据流向控制器包含:
一传送规则控制器,用来依据一传送规则来产生一传送控制信号;
一接收规则控制器,用来依据一接收规则来产生一接收控制信号;以及
一路径选择器,用来依据该传送控制信号将该第一或第二传送缓冲器耦接至该媒体存取控制器,以及依据该接收控制信号将来第一或第二接收缓冲器耦接至该媒体接口控制器。
19.如权利要求18所述的网络接口控制器,其中该传送规则控制器包含:
一MAC地址辨识器,用来依据该媒体存取控制器所提供的资讯来辨识待传送封包所包含的一MAC地址,藉以产生该传送控制信号。
20.如权利要求18所述的网络接口控制器,其中该传送规则控制器包含:
一目的地址辨识器,用来辨识待传送封包所对应的一目的地址,并产生一辨识信号;以及
一MAC地址分配器,用来依据该辨识信号以将待传送封包的一原始MAC地址修改为一第一MAC地址或一第二MAC地址,并利用该传送控制信号使该路径选择器将修改后具有该第一MAC地址的封包输出至第一传送FIFO或将修改后具有该第二MAC地址的封包输出至该第二传送FIFO。
21.如权利要求18所述的网络接口控制器,其中该接收规则控制器依据该第一接收缓冲器的储存空间使用状况与该第二接收缓冲器的储存空间使用状况来产生该接收控制信号。
22.如权利要求21所述的网络接口控制器,其中该接收规则控制器进一步依据一计时信号来产生该接收控制信号。
23.一种单一网络接口装置,该装置包含:
一第一收发器,用来经由一第一网络线来传送与接收封包;
一第二收发器,用来经由一第二网络线来传送与接收封包;
一第一缓冲器,耦接该第一收发器,用来暂存待传送至该第一收发器的封包,并用来暂存由该第一收发器所接收的封包;
一第二缓冲器,耦接该第二收发器,用来暂存待传送至该第二收发器的封包,并用来暂存由该第二收发器所接收的封包;以及
一主机接口电路,耦接该第一缓冲器与该第二缓冲器,用来使该第一缓冲器与该第二缓冲器的其中一个透过一主机接口与一电脑主机进行数据的传送。
24.如权利要求23所述的装置,其中该单一网络接口装置依据一传送规则来控制封包的传送。
25.如权利要求24所述的装置,其中该传送规则用以使得该第一收发器与该第二收发器实质上达到负载平衡(load balance)。
26.如权利要求23所述的装置,其中,该装置具有一第一MAC地址以及一第二MAC地址。
27.如权利要求23所述的装置,还包含:
一第一网络端口,耦接于该第一收发器与该第一网络线之间;以及
一第二网络端口,耦接于该第一收发器与该第一网络线之间。
28.如权利要求27所述的装置,其中,该第一网络端口与该第二网络端口是一乙太网络端口。
29.如权利要求28中任一所述的装置,其中,该装置是一网络接口卡(Network Interface Card,NIC)或是一主机板内建网络(LAN On Motherboard,LOM)。
30.如权利要求23中任一所述的装置,其中该第一缓冲器与该第二缓冲器是一非同步缓冲器(Asynchronous Buffer)。
31.如权利要求23中任一所述的装置,其中,该主机接口是一PCIExpress接口或是一USB接口。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN200810160875.2A CN101674335B (zh) | 2008-09-12 | 2008-09-12 | 具有多个传输端口的单一网络接口装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN200810160875.2A CN101674335B (zh) | 2008-09-12 | 2008-09-12 | 具有多个传输端口的单一网络接口装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN101674335A true CN101674335A (zh) | 2010-03-17 |
CN101674335B CN101674335B (zh) | 2014-01-08 |
Family
ID=42021319
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN200810160875.2A Active CN101674335B (zh) | 2008-09-12 | 2008-09-12 | 具有多个传输端口的单一网络接口装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN101674335B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102857494A (zh) * | 2011-06-30 | 2013-01-02 | 美国博通公司 | 通用网络接口控制器 |
US9253121B2 (en) | 2012-12-31 | 2016-02-02 | Broadcom Corporation | Universal network interface controller |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100251779B1 (ko) * | 1997-07-25 | 2000-04-15 | 윤종용 | 피디에이취망과 에이티엠망 사이의 인터페이스 장치 |
US8009563B2 (en) * | 2003-12-19 | 2011-08-30 | Broadcom Corporation | Method and system for transmit scheduling for multi-layer network interface controller (NIC) operation |
CN1331038C (zh) * | 2005-07-21 | 2007-08-08 | 华中科技大学 | 基于对象的存储控制器及其使用的调度方法 |
-
2008
- 2008-09-12 CN CN200810160875.2A patent/CN101674335B/zh active Active
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102857494A (zh) * | 2011-06-30 | 2013-01-02 | 美国博通公司 | 通用网络接口控制器 |
CN102857494B (zh) * | 2011-06-30 | 2015-11-18 | 美国博通公司 | 通用网络接口控制器 |
US9253121B2 (en) | 2012-12-31 | 2016-02-02 | Broadcom Corporation | Universal network interface controller |
Also Published As
Publication number | Publication date |
---|---|
CN101674335B (zh) | 2014-01-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI379567B (en) | Single network interface card (nic) with multiple-ports and method thereof | |
CN101227402B (zh) | 聚合链路流量分担方法及装置 | |
CN108011694B (zh) | 一种基于fc的高效数据交换方法 | |
CN105024942B (zh) | 一种动态流量监控方法 | |
KR100750880B1 (ko) | 가변 길이 데이터 패킷의 이종 네트워크 스위칭을 위한시스템 및 방법 | |
US11500541B2 (en) | Memory system and controlling method | |
CN102185833B (zh) | 一种基于fpga的fc i/o并行处理方法 | |
JP2006238413A (ja) | Usbハブ、usb対応装置及び通信システム | |
CN103873550A (zh) | 用于ecu和/或测量设备之间的数据传输的方法 | |
CN102647320A (zh) | 适用于高速1553总线协议控制的集成电路 | |
CN104054309A (zh) | 在网络边缘有效使用数据包缓冲和带宽资源的设备 | |
EP2936766A1 (en) | Apparatus and method for encoding mdio into sgmii transmissions | |
CN109787981A (zh) | 协议转换系统、方法、装置、设备和存储介质 | |
US9411400B1 (en) | Methods and systems for advertsing available credit at memory of network device ports based on temperature | |
CN107888337A (zh) | 一种fpga、fpga处理信息的方法、加速装置 | |
CN101674335B (zh) | 具有多个传输端口的单一网络接口装置 | |
CN108614792A (zh) | 1394事务层数据包存储管理方法及电路 | |
CN108011795B (zh) | 一种实现通信设备中多板卡和多数据通道管理的方法及系统 | |
US6690670B1 (en) | System and method for transmission between ATM layer devices and PHY layer devices over a serial bus | |
WO2018196833A1 (zh) | 报文发送方法和报文接收方法及装置 | |
CN208924235U (zh) | 处理器以及网络安全装置 | |
CN112631985B (zh) | 一种链路共享的片上网络 | |
US7411972B2 (en) | Link layer device with non-linear polling of multiple physical layer device ports | |
CN101296189A (zh) | 分布式流处理网络设备以及其中的报文传输方法 | |
US8780736B2 (en) | Communication apparatus and heat generation suppressing method |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant |