CN105049379B - 网络接口单元和用于运行网络接口单元的方法 - Google Patents

网络接口单元和用于运行网络接口单元的方法 Download PDF

Info

Publication number
CN105049379B
CN105049379B CN201510179646.5A CN201510179646A CN105049379B CN 105049379 B CN105049379 B CN 105049379B CN 201510179646 A CN201510179646 A CN 201510179646A CN 105049379 B CN105049379 B CN 105049379B
Authority
CN
China
Prior art keywords
unit
edp
data
data segment
network interface
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.)
Active
Application number
CN201510179646.5A
Other languages
English (en)
Other versions
CN105049379A (zh
Inventor
A.布鲁内
H.洛伊韦尔
C.波尔
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Robert Bosch GmbH
Original Assignee
Robert Bosch GmbH
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Robert Bosch GmbH filed Critical Robert Bosch GmbH
Publication of CN105049379A publication Critical patent/CN105049379A/zh
Application granted granted Critical
Publication of CN105049379B publication Critical patent/CN105049379B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • H04L69/166IP fragmentation; TCP segmentation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/36Flow control; Congestion control by determining packet size, e.g. maximum transfer unit [MTU]

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明涉及一种网络接口单元(100),带有至少一个输入端子(110)用于接收以太网数据包(edp)以及至少一个输出端子(120),其特征在于分割单元(130),其被构造用于将接收的以太网数据包(edp)和/或通过网络接口单元(100)修改的以太网数据包(edp’)分割成具有可预给定长度的至少一个数据段(ds)并且用于经由输出端子(120)输出至少一个数据段(ds)。本发明还涉及用于运行网络接口单元的方法。

Description

网络接口单元和用于运行网络接口单元的方法
技术领域
本发明涉及带有至少一个用于接收以太网数据包的输入端子以及至少一个输出端子的网络接口单元。
此外本发明还涉及用于运行这种网络接口单元的方法。
背景技术
开始所述类型的网络接口单元是已知的并且例如被构造用于接收和/或发出所谓的以太网数据包、也即网络数据包,这些网络数据包尤其是符合IEEE(电气和电子工程师协会) 802.3标准。在此,以本身已知的方式经由必要时与其它网络接口单元分享的介质(“共享介质”)、尤其是经由电和/或光的数据连接进行以太网数据包的传输。这些已知的网络接口单元的缺点是其小的灵活性和由此受限的应用。
发明内容
本发明的任务是如下地改善网络接口单元和对网络接口单元的运行方法,使得现有技术的上述缺点被避免并且尤其是给出更大的灵活性和提高的应用。
该任务在开始所述类型的网络接口单元中按照本发明通过如下方式来解决:设置有分割单元,其被构造用于将接收的以太网数据包和/或通过网络接口单元修改的以太网数据包分割成具有可预给定长度的至少一个数据段并且用于经由输出端子输出至少一个数据段。由此,可以在输出端子上有利地输出具有可预给定长度、尤其是恒定或可变长度的数据段,由此,尤其是能够相对于传统网络接口单元实现在接收所输出的数据段的数据汇点(Datensenke)的构造方面的自由度。
尤其是,能够实现将由网络接口单元以一个或多个以太网数据包的形式接收的数据抽象或变换成至少一个其它数据格式。例如可以通过预给定要输出的数据段的长度来进行这种适配。此外有利的是,通过本发明的网络接口单元,可以将以太网数据包分解成恒定长度的数据段,其中所述以太网数据包可以具有从最小大约64字节至最大大约1518字节的已知的不同包长度,必要时加上前导和“起始帧定界符(SFD)”,从而能够实现数据段在布置在本发明网络接口单元之后的处理单元中的确定的运行时间或处理时间。
在有利的实施方式中规定:分割单元被构造用于给每个数据段指派一个数据段头,其中分割单元优选还被构造用于经由输出端子输出数据段头。由此,可以形成各个数据段向顺序、例如在由网络接口单元分割的所接收的以太网数据包内的数据顺序的分配,所述顺序也可以被使用在布置于网络接口单元之后的处理单元内部。特别有利的是,在一种实施方式中,可以为数据段头设置恒定的大小(例如以字节为单位的长度),使得关于数据段头的处理也得到例如每个数据段头的恒定的存储器要求、恒定的通过时间或处理时间等等的优点。
在另一有利的实施方式中规定,输出端子具有a)第一输出缓存器,用于至少暂时存储由分割单元产生的数据段中的一个或多个,和/或b)第二输出缓存器,用于至少暂时存储由分割单元产生的数据段头中的一个或多个。通过这种方式,通过本发明网络接口单元形成的数据段和/或所述数据段的数据段头可以至少暂时地被中间存储,例如在输出给布置在后面的处理单元之前。此外,根据一种实施方式,在一个或多个输出缓存器中的中间存储使得能够实现与缓存的数据(数据段和/或数据段头)对应的数据的如下处理,该处理必要时可以推断出,缓存的数据(数据段和/或数据段头)例如尤其是经由输出端子完全不输出给布置在后面的处理单元,使得相关的缓存的数据(数据段和/或数据段头)在输出之前还可以从一个或多个缓存器中被删除。这种策略例如在分析经过处理或缓存的数据(数据段和/或数据段头)的内容时是合乎目的的,只要该分析得出不考虑将经过处理或缓存的数据(数据段和/或数据段头)中的单个或多个用于输出。
在另一有利的实施方式中设置有分析单元,其被构造用于根据至少一个可预给定的准则来分析接收的以太网数据包,由此例如可以实现以太网数据包的过滤。
在另一有利的实施方式中规定,分析单元被构造用于:a)根据所述分析将标识(“信道ID”)指派给接收的以太网数据包,和/或b)根据所述分析修改接收的以太网数据包,以便获得修改的以太网数据包,其中分析单元优选被构造用于将修改的以太网数据包输出给分割单元。在一种实施方式中,例如也可以将所指派的标识输出给分割单元。例如,所指派的标识由分割单元写入至与以太网数据包或修改的以太网数据包相应的数据段的一个或多个数据段头。代替地或补充地,所述标识也可以例如在前面描述的对以太网数据包的修改的范畴中直接写入一个或多个数据段,由此能够在数据段中实现标识的带内信令类型。
在另一有利的实施方式中规定,分析单元被构造用于执行下面步骤中的一个或多个:-去除接收的以太网数据包的可预给定的部分(stripping(剥离))、尤其是至少部分地去除头数据,-代替接收的以太网数据包的可预给定的部分。由此,可以减少待输出的数据段的数据量或者待输出的数据段的数量以及必要时减少数据段头的相应数量,由此减轻布置在本发明网络接口单元后面的处理单元的载荷。
在另一有利的实施方式中规定,设置有次级输入端子用于接收数据段和与数据段对应的数据段头,其中设置有包处理单元,所述包处理单元被构造用于根据经由次级输入端子接收的数据段和/或数据段头来形成至少一个以太网数据包。由此,根据本发明的网络接口单元可以有利地将其例如由外部处理单元传送的数据段组合成以太网数据包以便经由合适的以太网兼容的介质进行标准化输出。
作为本发明任务的另外的解决方案,规定按照权利要求8的用于运行网络接口单元的方法。有利的扩展方案是从属权利要求的主题。
附图说明
下面参照附图阐述本发明的示例性实施方式。在图中:
图1示意性示出了按照第一实施方式的网络接口单元,
图2示意性示出了按照第二实施方式的网络接口单元,
图3示意性示出了按照第三实施方式的网络接口单元的方面,
图4示意性示出了按照第四实施方式的网络接口单元,
图5示意性示出了按照一种实施方式的过滤的第一方面,
图6示意性示出了按照一种实施方式的过滤的第二方面,
图7a,7b示意性示出了按照另外的实施方式的分割的方面,
图8示意性示出了按照一种实施方式的输出接口的一个方面,
图9示意性示出了按照一种实施方式的包处理单元的一个方面,以及
图10a,10b分别示意性示出了按照一种实施方式的流程图。
具体实施方式
图1示意性示出了按照第一实施方式的网络接口单元100。网络接口单元100具有输入端子110用于接收以太网数据包edp,例如按照IEEE802.3标准的以太网数据包。
在一种实施方式中,输入端子110例如直接与以太网交换机(未示出)连接,优选经由串行千兆比特介质独立接口(SGMII)类型的接口。代替地,输入端子110也可以经由降低千兆比特介质独立接口(RGMII)类型的接口例如与在ISO/OSI基础参考模型的比特传输层(物理层)上工作的接口连接。一般地,可以经由输入端子110将已经提及的以太网数据包edp输送给网络接口单元100。在一种实施方式中,输入端子110被构造用于传输千兆比特以太网(GbE)类型。
按照本发明,网络接口单元100具有至少一个输出端子120以及分割单元130,分割单元130被构造用于将接收的以太网数据包edp分割成至少一个具有可预给定长度的数据段ds并且经由输出端子120输出所述至少一个数据段ds。由此,可以在输出端子120上有利地输出具有可预给定长度、尤其是恒定或可变长度的数据段ds,由此尤其是相对于传统网络接口单元可以实现在接收输出的数据段的数据汇点(未示出)的构造方面的自由度。
尤其是,能够实现将由网络接口单元100以一个或多个以太网数据包edp的形式接收的数据抽象或变换成至少一个其它数据格式。例如可以通过预给定要输出的数据段ds的长度来进行这种适配。此外有利的是,通过本发明的网络接口单元100,可以将以太网数据包edp分解成恒定长度的数据段ds,其中所述以太网数据包可以具有从最小大约64字节至最大大约1518字节的已知的不同包长度,必要时加上前导和“起始帧定界符(SFD)”,从而能够实现数据段ds在布置在本发明网络接口单元100之后的处理单元(未示出)中的确定的运行时间或处理时间。
在一种有利的实施方式中,分割单元130被构造用于给每个数据段ds指派一个数据段头dsh,其中分割单元130优选还被构造用于经由输出端子120输出数据段头dsh。
图2示意性示出了按照第二实施方式的网络接口单元100a。网络接口单元100a如上面参照图1所描述地拥有输入端子110,用于接收一个或多个以太网数据包edp。在本实施方式中,在输入端子110之后布置有可选的服务过滤单元112,该服务过滤单元被构造用于根据一个或多个可预给定的准则来过滤到达的以太网数据包edp。下面参照图5描述服务过滤单元112的详细实施例。
在服务过滤单元112之后布置有分析单元140,该分析单元必要时在其输入端140a上接收由服务过滤单元112在其输出端112a上输出的经过滤的以太网数据包,并且被构造用于根据至少一个可预给定的准则来分析接收的以太网数据包。下面参照图6来描述分析单元140的详细实施例。
在一种优选的实施方式中,分析单元140被构造用于:a)根据所述分析将标识(“信道ID”)chid指派给接收的以太网数据包,和/或b)根据所述分析修改接收的以太网数据包,以便获得修改的以太网数据包,其中分析单元140优选被构造用于将修改的以太网数据包输出给分割单元130。
在另一种优选实施方式中,分析单元140被构造用于执行下面步骤中的一个或多个:去除接收的以太网数据包的可预给定的部分、尤其是至少部分地去除头数据(例如去除前导和/或SFD和/或目标MAC地址和/或源MAC地址和/或VLAN数据和/或校验和数据(CRC)),代替接收的以太网数据包的可预给定的部分。
在另一优选实施方式中,分析单元140被构造用于对接收的以太网数据包或其有用数据内容(有效载荷)进行分析,所述分析一直进行到ISO/OSI基础参考模型的层3(layer3)(网络层)或者甚至一直进行到ISO/OSI基础参考模型的层4(layer 4)、也即传输层中(在另外的实施方式中,也可以设想包括层5、6一起的分析)。换句话说,分析单元140在该优选的实施方式中可以实施对接收的以太网数据包或其有用数据内容的非常广泛的分析。根据这种分析,各个以太网数据包edp、edp’例如可以被丢弃、以其他方式和方法被过滤和/或被修改。由此可以有利地实现:例如一些TCP数据流或IP数据流或其他以以太网数据包的形式到达单元100的数据流完全不通过本发明分割单元130来加以处理、也即分割,因为它们不考虑以数据段ds的形式输出,例如因为布置在后面的处理单元不想或不应当处理相关的IP数据流。由此,本发明在产生数据段ds方面的效率被进一步提高。
在另一优选实施方式中,分割单元130被构造用于将通过网络接口单元100、尤其是前面描述的分析单元140修改的以太网数据包edp’分割成至少一个具有可预给定长度的数据段ds并且经由输出端子120输出所述至少一个数据段ds。
在另一优选实施方式中,输出端子120具有第一输出缓存器1202用于至少暂时存储由分割单元130产生的数据段ds中的一个或多个,和/或b)第二输出缓存器1204用于至少暂时存储由分割单元130产生的数据段头dsh中的一个或多个。可选地,也可以存在输出控制逻辑装置1206,该输出控制逻辑装置控制数据段ds和/或数据段头dsh、尤其是在第一输出缓存器1202或第二输出缓存器1204中至少暂时存储的数据段ds或数据段头dsh的输出。
图3示意性示出了按照第三实施方式的网络接口单元的方面。设置有次级输入端子150用于接收数据段和与数据段对应的数据段头。这种数据段或数据段头例如可以源自未在图3中描绘的数据源。此外,设置有包处理单元160,所述包处理单元被构造用于根据经由次级输入端子150接收的数据段和/或数据段头来形成至少一个以太网数据包edp’’。
特别有利的是,根据图3的配置150、160可以与前面已经参照图1、2描述的组件或网络接口单元100、100a组合。尤其是,包处理单元160的输出端子170可以类似于输入端子110(图1、2)地被构造为,使得该输出端子可以直接与以太网交换机(未示出)相连接,优选经由串行千兆比特介质独立接口(SGMII)类型的接口。
代替地,输出端子170也可以经由降低千兆比特介质独立接口(RGMII)类型的接口例如与在ISO/OSI基础参考模型的比特传输层(物理层)上工作的接口连接。
一般地,本发明的网络接口单元100、100a可以经由输出端子170将由包处理单元160形成的以太网数据包edp’’输出给以太网网络,例如经由也可以与输入端子110连接的相同或类似的介质。在一种实施方式中,输出端子170被构造用于传输千兆比特以太网(GbE)类型。
在一种优选实施方式中,包处理单元160具有组合单元162,该组合单元在输入侧将数据段DS和/或数据段头dsh从次级输入端子150取走并且使用一个或多个数据段或其数据段头来建立由其构成的一个或多个以太网数据包或以太网数据包的部分。在一种实施方式中,组合单元162例如可以被构造用于根据一个或多个数据段或相应的数据段头来建立如适于形成以太网数据包edp’’的有用数据包(“有效载荷”)。组合单元162将其输出数据(例如多个数据段ds和/或标识chid的聚集数据)转发给包构建单元164。
在一种实施方式中,组合单元162分析在其输入端上到达的数据段头dhs,识别第一数据段ds以用于待建立的以太网数据包edp’’以及必要时其它跟随的数据段,这些其它跟随的数据段同样应当成为待建立的以太网数据包edp’’的组成部分,并且将这一点发信号通知包构建单元164。在此情况下,组合单元162尤其是也可以分析或者使用分配给数据段的标识chid。
根据另一实施方式,包构建单元164可以例如将开始和/或目标地址(尤其是MAC地址)添加给由组合单元162接收的数据,以便使得以太网数据包完善或者进一步完成以太网数据包的形成。代替地或补充地,单元164可以形成用于待形成的以太网数据包edp’’的校验和(CRC,循环冗余校验)。
代替地或补充地,单元164可以具有所谓的“协议构造器”功能或者支持用于数据流控制(xon/xoff)的措施。在另一有利的实施方式中,设置有地址解析数据库(地址解析协议数据库,ARP数据库)166。在另一实施方式中,可以设置缓存存储器168,其支持包构建单元164的功能。
在又一实施方式中,次级输入端子150可以类似于输出端子120(图2)具有一个或多个缓存存储器,当前为输入缓存器,以便至少暂时地中间存储在次级输入端子150中到达的数据段或数据段头。用于从外部数据源到达的数据段的、在单元150中的输入缓存器在图3中用附图标记1502表示,并且用于数据段头的输入缓存器用附图标记1504表示。
图4示出了本发明网络接口单元的另一实施方式100b。网络接口单元100b拥有前面已经参照图2描述的组件110、112、140、130、120以及拥有前面参照图3已经描述的组件150、160、170。
附加地,设置有反馈单元1000,其具有与组件140、130类似的元件1140、1130。反馈单元1000的输出端子1120基本上与输出端子120相同地构造。
此外,反馈单元1000也可以拥有服务过滤单元1112,该服务过滤单元1112在其功能方面基本上相应于服务过滤单元112。
经由在图4左边描绘的从包处理单元160或其组件164至反馈单元1000的信号连接S1能够实现借助包处理单元160产生的以太网数据包至反馈单元1000的反馈,使得可以封闭经由组件1000、150、160、S1的反馈回路。
此外,通过可选的信号连接S2能够实现类似的反馈机制,信号连接S2能够实现在输出端170获得的以太网数据包edp’’续传给网络接口单元100b的输入端子110。例如在那里可以经由可集成在服务过滤单元112中的开关112a来控制:是从共同介质(未示出)到达的以太网数据包edp还是相反由包处理单元160产生的以太网数据包edp’’到达服务过滤单元112并且必要时用于续传给分析单元140。
图5示意性示出例如可以在服务过滤单元112(图2、图4)中进行的过滤的第一方面。在输入区段2000中获得如在图2中例如用附图标记edp表示并且被输送给输入端子110的以太网数据包。在下面更详细描述的过滤之后,到达的以太网数据包edp必要时在输出区域2002中被输出,例如用于续传给分析单元140,参见图2、图4。
在优选实施方式中,在第一询问步骤2004中,对到达的以太网数据包edp研究其MAC地址是否与本发明网络接口单元100、100a、100b的MAC目标地址相应或者MAC目标地址是否相应于网络接口单元想要监控的广播MAC或多播MAC地址。如果是这种情况,则分支到接下来的询问步骤2006中,在其中检验以太网数据包edp是否包含MAC-CTRL“暂停”类型的MAC控制消息。如果否,则分支到接下来的询问步骤2008中,询问步骤2008检验以太网数据包edp的以太网头是否具有值为0x8808的类型字段。如果不是这种情况,以太网数据包edp被转发给输出区域2002,用于输出给布置在后面的单元140(图2)。
只要检验步骤2006、2008之一得到:到达的以太网数据包edp包含 “暂停”类型的以太网控制元素(“暂停帧”),就分支到另外的询问步骤2010中,在其中询问:以太网“暂停包”是否被分析。询问步骤2010的控制可以通过相应的控制信号2012来实现,该控制信号说明暂停模式是否有效。
在另外的实施方式中,服务过滤单元112(图2、图4)可以设置针对前面参照图5描述的过程的其它或补充的过滤步骤,一般例如根据包含在以太网数据包或以太网数据帧中的(MAC)源和/或目标地址和/或类型信息来评价该以太网数据包或以太网数据帧。例如由此也可以研究或者过滤多播以太网包或所描述的“暂停帧”。
图6示意性示出了按照一种实施方式的过滤的第二方面,该第二方面例如可以在分析单元140(图2、图4)中实现。
如例如直接在输入端子110或在服务过滤单元112的输出端上获得的以太网数据包edp到达输入区域2100中。
在通过下面更详细描述的按照图6的结构进行了过滤或分析之后,到达输入区域2100中的以太网数据包edp必要时在输出区域2102中被输出给接下来的单元,例如分割单元130(图2、图4)。
如由图6可知的,根据一种实施方式,在输入区域2100中到达的以太网数据包edp被输送给一组过滤器路径GFP,这组过滤器路径参照可预给定的过滤器准则分析以太网数据包edp并且将相应的结果输出给分析级2104。此外,按照图6的配置具有一组GIP互联网协议(IP)地址过滤器,到达的以太网数据包edp同样被输送给这组IP地址过滤器。单独的IP地址过滤器的输出数据如在图6中所示地作为输入量作用于组GFP的过滤器路径。在优选实施方式中,过滤器路径的组GFP具有N那么多的过滤器路径,并且IP地址过滤器的组GIP具有J那么多的元件。只要到达的以太网数据包edp满足组GFP的多个过滤器路径的过滤器准则,就可以使用多个过滤器路径的优先级,以便例如能够实现标识chid向以太网数据包edp的分配。
在优选实施方式中,分析单元140被构造用于,将标识chid(图2)指派给到达的以太网数据包edp。为此,例如能够使用前面参照图6描述的措施。例如,根据分析级2104的输出数据将相应的标识chid(图2)分配给在功能块2108中到达的以太网数据包edp。
代替地或者补充地,也可以修改到达的以太网数据包edp,例如通过去除所有的头数据,使得仅仅还有以太网数据包edp的有用数据被续传给输出区域2102,必要时连同前面描述的标识chid一起。可选地,也可以通过分析单元140丢弃以太网数据包edp的部分或者整个以太网数据包,只要满足确定的过滤器准则,参见通过单元2104的分析。在该情况下,可以将相应的以太网数据包完全地也首先续传给输出区域2102,然后通过单元130(图2、图4)进行分割,并且必要时接着才丢弃,例如通过从输出缓存器1202、1204去除。在一种实施方式中,例如可以通过功能块2106来提供相应的控制信息2110并且必要时将该控制信息续传给输出端子120。
在一种实施方式中,输出缓存器1202、1204例如以环形缓存器的形式来实现,从而可以通过改变写指针(write pointer)指向相关环形缓存器的位置根据通过例如按照图6的分析单元140的处理来丢弃数据段或数据段头。
图7a和7b示意性示出了按照另外的实施方式的分割的方面,该分割例如可以通过本发明的分割单元130来实施。
在此情况下,图7a描绘了以太网数据包edp如何被分割成多个数据段ds_1,ds_2,…和多个分配的数据段头dsh_1,dsh_2…。在此情况下包含的数据段或数据段头例如可以被输送给按照图2的单元120。
与图7a不同,图7b示出了透明的分割,在其中以太网数据包edp被划分到数据段ds_1’,ds_2’…或分配的数据段头dsh_1’,dsh_2’…上。与按照图7a的实施方式不同,按照图7b的数据段dsh_1’已经包含有用数据“有效载荷”,而图7a的数据段ds_1的类似区域保持为空(“空”),并且按照图7a的以太网数据包edp的有用数据首次填充到第二数据段ds_2中。
图8示意性示出了按照一种实施方式的输出接口120的一个方面。有用数据写控制单元1208在输入侧被输送由分割单元130形成的数据段ds。第一输出缓存器1202或其至有用数据写控制单元1208的接口在本实施方式中被实现为,使得有用数据写控制单元1208可以像存取静态的直接存取存储元件(SRAM,静态RAM)那样对第一输出缓存器1202或其至有用数据写控制单元1208的接口进行存取,也即在预给定地址信息ADR和实际要写入到输出缓存器1202中的数据DATA的情况下。如由图8可以看出的,数据段头dsh直接被导送给第二输出缓存器1204。输出控制逻辑装置1206可以经由接口1206a像存取标准FIFO(先进先出)缓存存储器那样存取第一输出缓存器1202,而输出控制逻辑装置1206经由接口1206b对第二输出缓存器1204的存取根据预读FIFO类型进行。
如由图8可以看出的,第二输出缓存器1204可以除了针对数据段头dsh的第一缓存等待队列1204a之外还具有至少一个另外的缓存等待队列1204b,通过另外的缓存等待队列可以将当前控制信息从单元1208传送给单元1206。
在一种实施方式中,为运行按照图8的输出接口120得到下面的步骤。在数据段ds存储在第一输出缓存器1202中期间,产生所属的数据段头dsh并且然后将其存储在第二输出缓存器1204中。由此有利地实现:该数据段头可以在时间上在所属数据段之前被读出并且可以被输出给布置在后面的数据处理单元(未示出),参见箭头A。
在另一实施方式中可以得到:在将数据段ds存储在第一输出缓存器1202中期间,通过网络接口单元或其组件之一得到并行进行的分析,即所观察的有用数据的部分(所述部分被分割成一个或多个数据段)或整个有用数据(相应地一个或多个数据段)要被丢弃。在该情况下对根据SRAM的类型的第一输出缓存器1202的存取特别合乎目的,因为通过SRAM类型的存取可以简单并且有效地又从第一输出缓存器中删除任意的、不需要的数据段。这种删除例如可以由于所识别的校验和错误(CRC错误)等等来进行。出于同样的原因,也对第二输出缓存器1204进行SRAM类型的存取是特别有利的。
图9示意性示出了按照一种实施方式的包处理单元1600的方面。帧完善单元1602从组合单元162获得数据(箭头“B”)和/或所属的标识chid(图3),它们要以以太网数据包edp’’(图3)的形式被输出。包处理单元1600在一种实施方式中被构造用于,实施以下功能的一个或多个,尤其是根据标识chid:
-运送由组合单元162(图3)接收的数据帧,
-必要时完备化要建立的以太网数据包edp’’的头数据(“header”)的源和/或目标地址(例如MAC地址),
-为此必要时尤其是借助帧完善单元1602和/或地址完善单元1604进行在ARP数据库166中的ARP查找(查找地址),
-必要时,完备化头数据(“header”),例如针对ISO/OSI基础参考模型的层2(layer2)和/或层3(layer 3)的头数据,
-完全再建立数据帧(尤其是针对“UDP上的XCP(通用测量和校准协议)”应用情形)
-借助CRC单元1606的校验和生成。
在一种实施方式中,在ARP数据库166中的ARP查找可以例如包括发送至少一个IP地址和接收至少一个相应于IP地址的MAC地址。
在另一实施方式中,可以设置所谓的帧完善数据库1608,其支持前面提及的完备化头数据的步骤。
在另一实施方式中,可以设置流量整形单元(“traffic shaper”)1610以用于控制在单元1600内部的数据流,所述数据流尤其是也可以影响待发出的以太网数据包edp’’的速率,例如根据配置信息CFG,xon_xoff。流量整形单元1610根据一种实施方式可以尤其是也分析例如由单元1602可使用的缓存存储器1612的运行状态、尤其是填充状态并且将其包括在对数据流的控制中。
图10a示意性示出了本发明方法的一种实施方式的流程图。在步骤300中,网络接口单元100a(图2)在其输入端子110上接收从本身已知的物理以太网介质到达的以太网数据包edp,其中网络接口单元100a连接到所述以太网介质上。在接下来的步骤310(图2)中,到达的以太网数据包edp例如通过分割单元130(图2)被分割成至少一个例如128字节的可预给定长度的数据段ds,并且优选将相应的数据段头dsh分配给所述至少一个数据段ds。在接下来的步骤320中,所述至少一个数据段ds、优选与数据段头一起经由输出端子120(图2)输出。
可选地,在本发明方法的另一实施方式中,在步骤300和步骤310之间通过可选的服务过滤单元112和/或分析单元140进行过滤或分析或修改。
图10b示意性示出了本发明方法的另一实施方式的流程图。在步骤400中,网络接口单元100b(图4)的次级输入端子150从数据源(例如将网络接口单元100b用作以太网接口的微控制器)接收到达的数据段和/或数据段头。在步骤410中,包处理单元160根据经由次级输入端子150接收的数据段和/或数据段头来形成至少一个以太网数据包edp’’,在步骤420中所述至少一个以太网数据包edp’’经由输出端子170被输出给物理以太网介质,网络接口单元100b至少以输出端子170连接到所述以太网介质上。
在另一优选实施方式中,单元120、150有利地(分别)经由物理同步接口与用于数据段的数据汇点(在单元120的情况下)或者提供数据段的数据源(在单元170的情况下)连接。
在另一优选实施方式中,分割单元130被构造用于:产生具有例如128字节的恒定长度的数据段。通过分割成恒定的、尤其是必要时也在布置在后面的处理单元(未示出)中已知的长度的数据段,可以有利地实现对这些段的无阻塞的数据处理,并且布置在后面的处理在使用多个管线的情况下也可以特别有效地进行。
在另一优选的实施方式中,本发明的网络接口单元100、100a、100b或者其组件的一个或者多个以硬件和/或软件或固件的形式来实现。尤其是,本发明的功能也可以在使用专用集成电路(ASIC,application specific integrated circuit)和/或可编程逻辑电路(FPGA,现场可编程逻辑门阵列)或者通用可配置的硬件电路的情况下来实现。
在另一优选的实施方式中,本发明的网络接口单元100、100a、100b具有控制单元(未示出),该控制单元控制网络接口单元100、100a、100b的运行。然而在特别优选的实施方式中,网络接口单元100、100a、100b也可以被构造为由外部单元来加以控制。例如,该外部单元可以是布置在本发明的网络接口单元后面的处理单元(未示出),其从网络接口单元100(图1)获得数据段和/或数据段头作为输入数据,和/或是外部的处理单元,其给网络接口单元100、尤其是其次级输入端子150(图3)输送数据段和/或与数据段对应的数据段头以用于变换成一个或多个以太网数据包edp’’。一般地,可以使用例如外部或布置在后面的处理单元的微处理器和/或数字信号处理器或类似计算单元或功能来控制网络接口单元100。
在另一实施方式中,本发明的网络接口单元100、100a、100b也可以有利地被使用来实现一个或多个灵活并且高性能的以太网网络接口,例如用于微处理器等等的以太网网络接口,其中本发明的网络接口单元给微处理器输送产生的数据段ds或数据段头dsh作为输入数据,并且由微处理器根据由微处理器获得的数据段ds或数据段头dsh形成要在以太网介质上输出的以太网数据包edp’’。
尤其是,在使用本发明原理的情况下可以有利地实现完全符合IETF(InternetEngineering Task Force,因特网工程任务组)的以太网实现,该以太网实现同时提供硬件加速(在例如借助硬件或FPGA等等实现单元100的至少一些组件的情况下)以及例如在使用TCP的情况下的诊断功能。

Claims (14)

1.网络接口单元(100),带有至少一个输入端子(110)用于接收以太网数据包(edp)以及至少一个输出端子(120),其特征在于,所述网络接口单元(100)包括分割单元(130),该分割单元被构造用于将接收的以太网数据包(edp)和/或通过所述网络接口单元(100)修改的以太网数据包(edp’)分割成具有可预给定长度的至少一个数据段(ds)并且用于经由所述输出端子(120)输出所述至少一个数据段(ds),
其中所述网络接口单元(100)还包括分析单元(140),所述分析单元被构造用于针对接收的以太网数据包(edp)的有用数据内容对所述接收的以太网数据包进行分析,所述分析进行到ISO/OSI基础参考模型的一个或多个层,
其中根据所述分析丢弃、过滤和/或修改各个不考虑以数据段形式输出的以太网数据包。
2.根据权利要求1所述的网络接口单元(100),其中,所述分割单元(130)被构造用于给每个数据段(ds)指派一个数据段头(dsh),其中所述分割单元(130)还被构造用于经由所述输出端子(120)输出所述数据段头(dsh)。
3.根据前述权利要求之一所述的网络接口单元(100),其中,所述输出端子(120)具有a)第一输出缓存器(1202),用于至少暂时存储由所述分割单元(130)产生的数据段(ds)中的一个或多个,和/或b)第二输出缓存器(1204),用于至少暂时存储由所述分割单元(130)产生的数据段头(dsh)中的一个或多个。
4.根据权利要求1所述的网络接口单元(100),其中,所述分析单元(140)被构造用于:a)根据所述分析将标识(chid)指派给接收的以太网数据包,和/或b)根据所述分析修改接收的以太网数据包(edp),以便获得修改的以太网数据包(edp’),其中所述分析单元(140)被构造用于将所述修改的以太网数据包(edp’)输出给所述分割单元(130)。
5.根据权利要求1或4所述的网络接口单元(100),其中,所述分析单元(140)被构造用于执行下面步骤中的一个或多个:
-去除接收的以太网数据包(edp)的可预给定的部分,
-代替所述接收的以太网数据包(edp)的可预给定的部分。
6.根据权利要求5所述的网络接口单元(100),其中,去除的步骤包括至少部分地去除头数据。
7.根据权利要求1至2之一所述的网络接口单元(100),其中设置有次级输入端子(150)用于接收数据段(ds)和与所述数据段(ds)对应的数据段头(dsh),以及其中设置有包处理单元(160),所述包处理单元被构造用于根据经由所述次级输入端子(150)接收的数据段(ds)和/或数据段头(dsh)来形成至少一个以太网数据包(edp’’)。
8.用于运行网络接口单元(100)的方法,所述网络接口单元(100)带有至少一个输入端子(110)用于接收以太网数据包(edp)以及至少一个输出端子(120),其特征在于,分割单元(130)将接收的以太网数据包(edp)和/或通过所述网络接口单元(100)修改的以太网数据包(edp’)分割(310)成具有可预给定长度的至少一个数据段(ds)并且经由所述输出端子(120)输出(320)所述至少一个数据段(ds),
其中所述网络接口单元(100)还包括分析单元(140),其中所述分析单元(140)针对接收的以太网数据包(edp)的有用数据内容对所述接收的以太网数据包进行分析,所述分析进行到ISO/OSI基础参考模型的一个或多个层,
其中根据所述分析丢弃、过滤和/或修改各个不考虑以数据段形式输出的以太网数据包。
9.根据权利要求8所述的方法,其中,所述分割单元(130)给每个数据段(ds)指派一个数据段头(dsh),以及其中所述分割单元(130)还经由所述输出端子(120)输出所述数据段头(dsh)。
10.根据权利要求8至9之一所述的方法,其中,所述输出端子(120)具有a)第一输出缓存器(1202)并且至少暂时存储由所述分割单元(130)产生的数据段(ds)中的一个或多个,和/或b)具有第二输出缓存器(1204)并且至少暂时存储由所述分割单元(130)产生的数据段头(dsh)中的一个或多个。
11.根据权利要求8至9之一所述的方法,其中,所述分析单元(140)被构造用于:a)根据所述分析将标识(chid)指派给接收的以太网数据包,和/或b)根据所述分析修改接收的以太网数据包(edp),以便获得修改的以太网数据包(edp’),其中所述分析单元(140)被构造用于将所述修改的以太网数据包(edp’)输出给所述分割单元(130)。
12.根据权利要求8至9之一所述的方法,其中,所述分析单元(140)执行下面步骤中的一个或多个:
-去除接收的以太网数据包(edp)的可预给定的部分,
-代替所述接收的以太网数据包(edp)的可预给定的部分。
13.根据权利要求12所述的方法,其中去除的步骤包括至少部分地去除头数据。
14.根据权利要求8至9之一所述的方法,其中,设置次级输入端子(150)用于接收数据段(ds)和与所述数据段(ds)对应的数据段头(dsh),以及其中包处理单元(160)根据经由所述次级输入端子(150)接收的数据段(ds)和/或数据段头(dsh)来形成至少一个以太网数据包(edp’’)。
CN201510179646.5A 2014-04-17 2015-04-16 网络接口单元和用于运行网络接口单元的方法 Active CN105049379B (zh)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
DE102014207413.4A DE102014207413A1 (de) 2014-04-17 2014-04-17 Netzwerkschnittstelleneinheit und Verfahren zum Betreiben einer Netzwerkschnittstelleneinheit
DE102014207413.4 2014-04-17

Publications (2)

Publication Number Publication Date
CN105049379A CN105049379A (zh) 2015-11-11
CN105049379B true CN105049379B (zh) 2020-08-04

Family

ID=54249917

Family Applications (2)

Application Number Title Priority Date Filing Date
CN201520229049.4U Active CN204906429U (zh) 2014-04-17 2015-04-16 网络接口单元
CN201510179646.5A Active CN105049379B (zh) 2014-04-17 2015-04-16 网络接口单元和用于运行网络接口单元的方法

Family Applications Before (1)

Application Number Title Priority Date Filing Date
CN201520229049.4U Active CN204906429U (zh) 2014-04-17 2015-04-16 网络接口单元

Country Status (5)

Country Link
US (1) US20150304461A1 (zh)
JP (1) JP2015208000A (zh)
KR (1) KR20150120302A (zh)
CN (2) CN204906429U (zh)
DE (1) DE102014207413A1 (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111614793B (zh) * 2020-04-22 2022-03-04 上海御渡半导体科技有限公司 一种基于fpga的以太网交换机的mac地址管理装置及方法

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1374781A (zh) * 2001-03-06 2002-10-16 株式会社Ntt都科摩 分组通信方法与分组通信***并分组发送装置和分组接收装置以及分组接发装置
CN1832455A (zh) * 2005-02-18 2006-09-13 美国博通公司 网络设备及处理数据的方法
CN101060481A (zh) * 2007-02-05 2007-10-24 中兴通讯股份有限公司 一种Turbo码传输块的分段方法
CN101119316A (zh) * 2006-08-03 2008-02-06 富士通株式会社 分组传输装置及其控制方法
CN101572911A (zh) * 2002-09-24 2009-11-04 富士通株式会社 数据包传输/发送方法及移动通信***
EP2661048A1 (en) * 2012-05-04 2013-11-06 Huawei Technologies Co., Ltd Processing method and apparatus for member link in multilink group

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6781992B1 (en) * 2000-11-30 2004-08-24 Netrake Corporation Queue engine for reassembling and reordering data packets in a network
US7986694B2 (en) * 2004-02-03 2011-07-26 Realtek Semiconductor Corp. Method for fragmenting an incoming packet into a first outgoing packet and a second outgoing packet
US20060075067A1 (en) * 2004-08-30 2006-04-06 International Business Machines Corporation Remote direct memory access with striping over an unreliable datagram transport
JP4942375B2 (ja) * 2006-03-27 2012-05-30 株式会社ソニー・コンピュータエンタテインメント ネットワーク処理装置
JP4412369B2 (ja) * 2007-09-04 2010-02-10 日本電気株式会社 分散型処理システム、分散型処理方法、端末、及び、プログラム
US8854971B2 (en) * 2012-02-03 2014-10-07 Apple Inc. System and method employing intelligent feedback mechanisms for traffic suspension on a client device
US8902901B2 (en) * 2012-03-23 2014-12-02 Itron, Inc. Communication packet conversion

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1374781A (zh) * 2001-03-06 2002-10-16 株式会社Ntt都科摩 分组通信方法与分组通信***并分组发送装置和分组接收装置以及分组接发装置
CN101572911A (zh) * 2002-09-24 2009-11-04 富士通株式会社 数据包传输/发送方法及移动通信***
CN1832455A (zh) * 2005-02-18 2006-09-13 美国博通公司 网络设备及处理数据的方法
CN101119316A (zh) * 2006-08-03 2008-02-06 富士通株式会社 分组传输装置及其控制方法
CN101060481A (zh) * 2007-02-05 2007-10-24 中兴通讯股份有限公司 一种Turbo码传输块的分段方法
EP2661048A1 (en) * 2012-05-04 2013-11-06 Huawei Technologies Co., Ltd Processing method and apparatus for member link in multilink group

Also Published As

Publication number Publication date
CN105049379A (zh) 2015-11-11
US20150304461A1 (en) 2015-10-22
JP2015208000A (ja) 2015-11-19
DE102014207413A1 (de) 2015-10-22
KR20150120302A (ko) 2015-10-27
CN204906429U (zh) 2015-12-23

Similar Documents

Publication Publication Date Title
KR102239717B1 (ko) 패킷 처리 방법 및 장치
USRE48645E1 (en) Exporting real time network traffic latency and buffer occupancy
US8351352B1 (en) Methods and apparatus for RBridge hop-by-hop compression and frame aggregation
US11425058B2 (en) Generation of descriptive data for packet fields
US9118576B2 (en) Network device with a programmable core
US8767747B2 (en) Method for transferring data packets in a communication network and switching device
EP3742683B1 (en) Method and device for processing packet by using unified sr label stack
CN105337852B (zh) 更新业务流报文的处理方式的方法及装置
US20210083970A1 (en) Packet Processing Method and Apparatus
US20150023223A1 (en) Method and Device for Filtering Media Packets
EP3094053A1 (en) Predictive egress packet classification for quality of service
JP6027370B2 (ja) データネットワーク向けエンドツーエンド遅延情報の埋め込み
CN107925595B (zh) 网关装置以及运算装置
US20210392084A1 (en) Transmission Of Packets Over A TSN Aware Network
KR20220058576A (ko) 데이터 송신을 제어하기 위한 방법 및 장치, 및 저장 매체
US9143448B1 (en) Methods for reassembling fragmented data units
CN105049379B (zh) 网络接口单元和用于运行网络接口单元的方法
WO2017024818A1 (zh) 一种处理数据报文的方法及装置
US11909848B2 (en) Multi-flow compression
US8488489B2 (en) Scalable packet-switch
JP2004201032A (ja) 複数ルートを用いた高信頼化伝送方法およびシステムおよび高信頼化伝送用ルータ
KR101440271B1 (ko) 패킷 처리 방법 및 시스템

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant