一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

一种数据分组交换系统和方法与流程

2022-03-31 08:53:53 来源:中国专利 TAG:


1.本发明属于计算机网络领域,并特别涉及一种数据分组交换系统和方法。


背景技术:

2.目前数据交换网络中具有交换数据量大,承载业务种类复杂的特点,其中多播功能在诸如分布式计算,机器学习等多种业务中被广泛使用。现有的多播方案主要从网络传输协议和机制层面对多播功能进行优化。
3.在专利“处理多播报文的方法和交换接入装置”(cn 102594650 a)公开了一种在传输机制方面针对多播报文的处理方法及其处理装置。该发明首先根据多播报文的多播地址在多播路由表中查找对应的多播目的地址;根据多播目的地址在单播路由表单播目的地址;再根据单播目的地址查找对应的可用链路;最后在可用链路中选择发送链路,将多播报文复制多份,按照单播报文的发送方式进行发送。该专利降低了多播报文处理难度,可以与单播报文共用单播路由表;但该专利在多播报文复制时增加了对网络芯片中存储器的资源开销,同时增加了与单播报文仲裁时的冲突几率。
4.在专利“交换网络芯片的信元处理方法及装置”(cn 102281192 a)中公开了一种交换网络芯片对多播数据分组(网络中的数据包)处理的方法和装置,数据分组一般由服务器的网卡端产生,数据分组一般由分组头部和分组载荷组成,分组头部包含原地址,目的地址,传输协议等关键信息,分组载荷主要包含需要传输具体数据内容。该专利中交换网络芯片接收数据分组,并提取数据分组的目的端口表示和输入链路号;交换网络芯片查找多播路由表确定第一比特位图;根据第一比特位图进行负载均衡处理得到第二比特位图,根据第二比特位图将多播分组复制转发到输出端口。该发明可以根据端口负载情况对多播分组的输出端口进行调整,交换网络芯片能够适应不同的工作模式。但是其对于多播分组在复制转发过程中可能由于输出端口无法全部同时使用而造成多播分组阻塞后续分组的问题。
5.在专利“改善多播业务hol阻塞的队列管理方法”(cn 111131089 a)中公开了一种改善多播分组造成的队头阻塞问题的队列管理办法。该专利中实现了二级多播发送队列,优先读取第二级多播发送队列调度信息,若第二级调度信息中目的端口全部空闲,则复制转发该多播分组,否则读取第一级调度信息,若第一级调度信息中的目的端口为部分空闲,则转发该多播分组到空闲端口,并记录未转发的目的端口到第二级调度信息中,等待下次调度。该发明可以缓解由于多播分组无法转发到所有目的端口导致的队头阻塞问题,但是其需要2次仲裁,增加了交换时延和逻辑复杂性,同时需要额外的缓存资源来存储第二级调度信息和未及时转发的多播分组,增加了资源开销。
6.发现现有技术中对多播分组的处理主要是两条技术路线:从传输机制上对多播分组的路由策略进行优化,以及在调度机制上对多播分组的复制转发过程进行优化。现有交换芯片架构通常在缓存多播分组和单播分组时会统一存储到队列中,而从传输机制上的优化会导致多播分组复制传输时对单播分组阻塞;同时,现有交换芯片架构通常采用集中式的仲裁和分发方式,所有输入端口的队列头部分组都会竞争输出端口仲裁,而调度机制的
优化则会导致调度和仲裁的逻辑更加复杂,同时会占用更多的缓存资源。


技术实现要素:

7.本发明的目的是克服上述现有多播分组处理过程中对多播分组的阻塞影响,同时通过分散式两级仲裁的方式降低仲裁逻辑的复杂度,提出了一种多播分组交换方法及系统。
8.针对现有技术的不足,本发明提出一种数据分组交换方法,其中包括:
9.步骤1、构建由多个子交换模块构成的交换系统,该交换系统的子交换模块按照行列规则排布,且每行子交换模块均设有输入分发模块,该交换系统中每一列的子交换模块两两相连;
10.步骤2、待交换的数据分组通过输入分发模块进入该交换系统,根据该数据分组携带的目的地址,将该数据分组分发到输入分发模块所在行的某一子交换模块并将其作为初始交换模块,该初始交换模块将该数据分组存储到单独的一个队列中等待端口仲裁授权;
11.步骤3、该数据分组被授权后,根据该目的地址将该数据分组分发给该交换系统中某一行的子交换模块并将其作为目的子交换模块,该目的子交换模块将该数据分组存储到另一个单独的队列,等待输出端口仲裁之后输出该数据分组。
12.所述的数据分组交换方法,其中该子交换模块包括:输入缓存队列in_q、输入队列仲裁模块in_arb、子交换系统sub_xbr、子端口仲裁模块p_arb、输出队列缓存out_q、输出队列仲裁模块out_arb、行多播分组控制模块row_ctrl和列多播分组控制模块col_ctrl;
13.每个该子交换模块对应一个输入端口,数据分组从输入端口进入该子交换模块后,该行多播分组控制模块根据该数据分组的分组类型,将该数据分组缓存到对应输入缓存队列,每个子交换模块共有多个输入缓存队列,每个输入缓存队列按照先入先出的方式存放数据分组;每个输入缓存队列的头部分组竞争输入队列仲裁模块的授权,其中多播分组的竞争优先级高于单播分组,输入队列仲裁模块、子端口仲裁模块和列多播分组控制模块会根据每个参与竞争的头部分组的目的端口是否空闲来授权,综合所有仲裁结果授权给对应的输入缓存队列的头部分组,授权后的数据分组根据其数据分组类型存入该输出队列缓存,每个输出队列缓存按照先入先出的方式存放数据分组;每个输出队列缓存的头部分组竞争输出队列仲裁模块的授权,输出队列缓存的头部分组被授权后输出,到达输出端口,完成传输。
14.所述的数据分组交换方法,其中该行多播分组控制模块和列多播分组控制模块,用于对多播分组的分发和授权控制,当多播分组进入子交换模块后,行多播分组控制模块根据多播分组携带的地址位图,将多播分组同时分发到对应的同行的子交换模块中,同时行多播分组控制模块会从地址位图截取相应部分组成新的位图信息,位图信息会随着该多播分组进入子交换模块;该多播分组进入子交换模块后,需要子端口仲裁模块、输出队列仲裁模块和列多播分组控制模块的授权才能进入子交换系统向目的子交换模块传输,其中列多播分组控制模块根据该位图信息来判断目的子交换模块对应的端口是否空闲,从而决定该多播分组的授权结果。
15.所述的数据分组交换方法,其中仲裁具体流程包括:
16.步骤s1,该输入队列仲裁模块按照优先级从高到低的顺序,依次检查所有输入缓
存队列是否存在队列头部数据分组,若有,则执行步骤s2;否则继续下一轮检查;
17.步骤s2,该输入队列仲裁模块提取头部分组的row_route_map交给子端口仲裁模块,执行步骤s3;
18.步骤s3,子端口仲裁模块比对row_route_map与子交换系统中各个输出端口状态,如果row_route_map中每一位有效的行号且与之对应的子交换系统的输出端口处于空闲状态,则仲裁成功,执行步骤s4;否则仲裁失败,执行步骤s1;
19.步骤s4,子端口仲裁模块将row_route_map交给列多播分组控制模块仲裁,执行步骤s5;
20.步骤s5,列多播分组控制模块比对row_route_map与对应行的目的子交换模块的对应输出队列缓存状态,如果row_route_map中每一位有效行号且与之对应的输出队列缓存状态空闲,则仲裁成功,执行步骤s6;否则执行步骤s1;
21.步骤s6,队列头部分组得到仲裁授权后,从输入缓存队列中输出到子交换系统,执行步骤s7;
22.步骤s7,子交换系统按照数据分组的row_route_map中对应的有效行号直接分发到对应输出端口,执行步骤s8;
23.步骤s8,数据分组通过子交换系统转发到达目的子交换模块,并存入对应输出队列缓存,执行步骤s9;
24.步骤s9,输出队列仲裁模块按照优先级从高到低的顺序,依次检查每个输出队列缓存是否存在队列头部数据分组,直到检测到第一个头部数据分组,则执行步骤s10;否则继续下一轮检查;
25.步骤s10,队列头部数据分组得到输出队列仲裁模块仲裁授权,将队列头部数据分组传输到输出总线,完成传输。
26.5.如权利要求4所述的数据分组交换方法,其中该地址位图长度为n
×
m,m和n分别为该交换系统的行数和列数,目的端口记为0到n
×
m-1,端口状态使用1bit数据表示,1表示有效,0表示无效;数据分组进入位于第i行第j列的子交换模块之后,行多播分组控制模块分别提取该地址位图中各字段的端口状态,并对每段数据做按位或运算,得到该col_route_map;其中0≤i≤m-1、0≤j≤n-1,i和j均为整数。
27.本发明还提出了一种数据分组交换系统,其中包括:
28.模块1,用于构建由多个子交换模块构成的交换系统,该交换系统的子交换模块按照行列规则排布,且每行子交换模块均设有输入分发模块,该交换系统中每一列的子交换模块两两相连;
29.模块2,用于将待交换的数据分组通过输入分发模块进入该交换系统,根据该数据分组携带的目的地址,将该数据分组分发到输入分发模块所在行的某一子交换模块并将其作为初始交换模块,该初始交换模块将该数据分组存储到单独的一个队列中等待端口仲裁授权;
30.模块3,用于在该数据分组被授权后,根据该目的地址将该数据分组分发给该交换系统中某一行的子交换模块并将其作为目的子交换模块,该目的子交换模块将该数据分组存储到另一个单独的队列,等待输出端口仲裁之后输出该数据分组。
31.所述的数据分组交换系统,其中该子交换模块包括:输入缓存队列in_q、输入队列
仲裁模块in_arb、子交换系统sub_xbr、子端口仲裁模块p_arb、输出队列缓存out_q、输出队列仲裁模块out_arb、行多播分组控制模块row_ctrl和列多播分组控制模块col_ctrl;
32.每个该子交换模块对应一个输入端口,数据分组从输入端口进入该子交换模块后,该行多播分组控制模块根据该数据分组的分组类型,将该数据分组缓存到对应输入缓存队列,每个子交换模块共有多个输入缓存队列,每个输入缓存队列按照先入先出的方式存放数据分组;每个输入缓存队列的头部分组竞争输入队列仲裁模块的授权,其中多播分组的竞争优先级高于单播分组,输入队列仲裁模块、子端口仲裁模块和列多播分组控制模块会根据每个参与竞争的头部分组的目的端口是否空闲来授权,综合所有仲裁结果授权给对应的输入缓存队列的头部分组,授权后的数据分组根据其数据分组类型存入该输出队列缓存,每个输出队列缓存按照先入先出的方式存放数据分组;每个输出队列缓存的头部分组竞争输出队列仲裁模块的授权,输出队列缓存的头部分组被授权后输出,到达输出端口,完成传输。
33.所述的数据分组交换系统,其中该行多播分组控制模块和列多播分组控制模块,用于对多播分组的分发和授权控制,当多播分组进入子交换模块后,行多播分组控制模块根据多播分组携带的地址位图,将多播分组同时分发到对应的同行的子交换模块中,同时行多播分组控制模块会从地址位图截取相应部分组成新的位图信息,位图信息会随着该多播分组进入子交换模块;该多播分组进入子交换模块后,需要子端口仲裁模块、输出队列仲裁模块和列多播分组控制模块的授权才能进入子交换系统向目的子交换模块传输,其中列多播分组控制模块根据该位图信息来判断目的子交换模块对应的端口是否空闲,从而决定该多播分组的授权结果。
34.所述的数据分组交换系统,其中仲裁具体包括:
35.模块s1,用于按照优先级从高到低的顺序,依次检查所有输入缓存队列是否存在队列头部数据分组,若有,则调用模块s2;否则继续下一轮检查;
36.模块s2,用于提取头部分组的row_route_map交给子端口仲裁模块,调用模块s3;
37.模块s3,用于比对row_route_map与子交换系统中各个输出端口状态,如果row_route_map中每一位有效的行号且与之对应的子交换系统的输出端口处于空闲状态,则仲裁成功,调用模块s4;否则仲裁失败,调用模块s1;
38.模块s4,用于将row_route_map交给列多播分组控制模块仲裁,调用模块s5;
39.模块s5,用于比对row_route_map与对应行的目的子交换模块的对应输出队列缓存状态,如果row_route_map中每一位有效行号且与之对应的输出队列缓存状态空闲,则仲裁成功,调用模块s6;否则调用模块s1;
40.模块s6,用于在队列头部分组得到仲裁授权后,从输入缓存队列中输出到子交换系统,调用模块s7;
41.模块s7,用于使子交换系统按照数据分组的row_route_map中对应的有效行号直接分发到对应输出端口,调用模块s8;
42.模块s8,用于使数据分组通过子交换系统转发到达目的子交换模块,并存入对应输出队列缓存,调用模块s9;
43.模块s9,用于按照优先级从高到低的顺序,依次检查每个输出队列缓存是否存在队列头部数据分组,直到检测到第一个头部数据分组,则调用模块s10;否则继续下一轮检
查;
44.模块s10,用于使队列头部数据分组得到输出队列仲裁模块仲裁授权,将队列头部数据分组传输到输出总线,完成传输。
45.所述的数据分组交换系统,其中该地址位图长度为n
×
m,m和n分别为该交换系统的行数和列数,目的端口记为0到n
×
m-1,端口状态使用1bit数据表示,1表示有效,0表示无效;数据分组进入位于第i行第j列的子交换模块之后,行多播分组控制模块分别提取该地址位图中各字段的端口状态,并对每段数据做按位或运算,得到该col_route_map;其中0≤i≤m-1、0≤j≤n-1,i和j均为整数。
46.由以上方案可知,本发明的优点在于:
47.本发明从属于硬件底层的交换芯片架构出发,设计了由分散式的子交换模块组成交换架构。本发明相比现有基于集中式仲裁分发交换架构的多播分组传输优化技术,将复杂的集中式仲裁逻辑拆分成两级分散式仲裁,降低了仲裁复杂度;本发明中多播分组与单播分组分别缓存至不同的输入缓存队列和输出缓存队列,避免了由于多播分组阻塞而影响后续单播分组传输的问题,同时提升了多播分组的仲裁优先级,提升交换架构的传输效率;本发明将分发过程拆分为2个阶段,提高了分发效率,同时采用相同的route_map格式,节约了存储资源。
附图说明
48.图1是本发明的系统示意图;
49.图2是本发明的子交换模块示意图;
50.图3是本发明route_map、col_route_map和row_route_map示意图;
51.图4是本发明仲裁流程图。
具体实施方式
52.发明人通过研究交换芯片架构,充分了解数据分组在硬件级别的交换芯片中的处理流程之后发现,以上技术问题可以通过在硬件层面上对交换芯片架构进行优化设计而解决。在本发明中,交换芯片架构由若干子交换模块组成,子交换模块按照行列整齐排布,多播分组从某一个子交换模块进入,经过两级子交换模块之后到达输出端口。本发明的技术难点主要在于将交换系统分成多个子交换模块,多播分组复杂的仲裁和调度过程分散到两级子交换模块中,从而降低了调度和仲裁的逻辑复杂度;同时本发明采用了多播分组和单播分组多队列存储的设计,降低了多播分组对单播分组的影响,避免多播分组造成队头阻塞。为了实现上述技术效果,本技术提出了以下关键点:
53.关键点1,交换系统分为多个子交换模块组成,子交换模块按照行列规则排布,全交换系统共有p个端口,分为n
×
m个子交换模块,其中p=n
×
m,m为行数,n为列数,m和n都为大于等于1的正整数。每个子交换模块对应交换系统的一个输入和输出端口,子交换模块之间通过连线连接。数据分组首先从输入端口进入交换系统,输入端口所在行的输入分发模块会根据数据分组携带的目的地址将数据分组分发到该行的行目的子交换模块。行目的子交换模块收到数据分组之后,将数据分组存储到单独的一个存储队列中等待端口仲裁模块的授权,数据分组被授权之后,分发给某一行的列目的子交换模块;列目的子交换模块收到
数据分组之后将数据分组存储到一个单独的队列,等待输出端口仲裁之后输出到输出端口。
54.本发明的由子交换模块组成的交换系统可以将复杂的集中式仲裁逻辑拆分成两级分散式仲裁,减少了竞争每一级仲裁的队列数,降低了每一级仲裁复杂度,从而提升了整体架构仲裁效率。
55.关键点2,子交换模块包括:输入缓存队列in_q、输入队列仲裁模块in_arb、子交换系统sub_xbr、子端口仲裁模块p_arb、输出队列缓存out_q、输出队列仲裁模块out_arb、行多播分组控制模块row_ctrl和列多播分组控制模块col_ctrl等模块组成。根据关键点1中所述,每个子交换模块对应一个输入端口,数据分组从输入端口进入子交换模块后,row_ctrl根据数据分组的多播或单播分组类型缓存入对应in_q,每个子交换模块共有a
×
n个in_q,a为大于1的正整数,每个in_q按照“先入先出”的方式存放数据分组,其中多播分组和单播分组会被分别存入不同的in_q;每个in_q的头部分组竞争in_arb的授权,其中多播分组的竞争优先级高于单播分组,in_arb,p_arb和col_ctrl会根据每个参与竞争的头部分组的目的端口是否空闲来授权,综合上述3个模块的仲裁结果授权给对应的in_q的头部分组,授权后的数据分组进入sub_xbr后,被传输到对应的目的子交换模块,进入目的子模块后,根据数据分组类型存入out_q,每个子交换模块共有b
×
m个out_q,b为大于1的正整数;其中多播分组和单播分组会被分别存入不同的out_q,每个out_q按照“先入先出”的方式存放数据分组;每个out_q的头部分组竞争out_arb的授权,其中多播分组的竞争优先级高于单播分组,头部分组被out_arb授权后输出,到达输出端口,完成传输。
56.本发明的子交换模块将多播分组与单播分组分别缓存至不同的输入缓存队列和输出缓存队列,使得多播分组在竞争仲裁时,即使未能竞争成功,也不会影响到其他单播分组的竞争,从而避免了由于多播分组阻塞而影响后续单播分组传输的问题;同时考虑到与单播分组仲裁时仅需要一个目的端口空闲即可授权的方式不同,多播分组通常需要若干目的端口空闲才能完成授权,本发明中多播分组在竞争仲裁时具有比单播分组更高的优先级,从而保证多播分组可以尽可能快速的完成传输,从而避免占用更多的目的端口资源,提升交换架构的效率。
57.关键点3,根据关键点1和关键点2中所述的子交换模块和数据分组传输过程,其中行多播分组控制模块row_ctrl和列多播分组控制模块col_ctrl主要负责对多播分组的分发和授权控制。当多播分组进入子交换模块后,row_ctrl模块会根据多播分组携带的地址位图信息route_map,将多播分组同时分发到对应的同行的子交换模块中,同时row_ctrl会从route_map截取相应部分组成新的位图信息col_map,col_map会随着多播分组进入子交换模块;多播分组进入子交换模块后,需要in_arb,p_arb和col_ctrl这3个模块的授权才能进入sub_xbr进行向目的子交换模块的传输,其中col_ctrl根据col_map来判断目的子交换模块对应的端口是否是空闲的,从而决定多播分组的授权结果。
58.本发明中为了节约宝贵的存储资源,多播分组和单播分组采用相同的route_map格式,同时row_ctrl和col_ctrl也会对单播分组进行处理,即本发明将单播分组看作目的端口只有1个的多播分组。本发明设计的row_ctrl和col_ctrl将多播分组的多次分发拆分为2个阶段,相比现有交换架构的集中式仲裁和分发机制,降低了仲裁的复杂度,提高了分发效率;同时本发明中多播分组和单播分组采用相同的route_map格式,相比现有交换架构
中分别维护多播分组路由表和单播分组路由表的方式,降低了读取路由信息的复杂度,同时也节约了宝贵的存储资源。
59.为让本发明的上述特征和效果能阐述的更明确易懂,下文特举实施例,并配合说明书附图作详细说明如下。
60.图1是表示本发明的一个实施方式的交换系统结构图。该交换系统包括m
×
n个子交换模块,其中m为行数且为大于1的正整数,n为列数且为大于1的正整数。每行设置1个输入分发模块11,输入分发模块与本行n个子交换模块12对应的n个输入端口10连接,接收从输入端口输入的数据分组;输入分发模块输出n条数据总线,本行的每个子交换模块与对应的数据总线相连;数据分组从输入端口输入,经过输入分发模块分发给对应的子交换模块12,数据分组在子交换模块中进行路由和传输,最后达到目的子交换模块;每行有n个输出端口13,输出端口通过数据总线与本行的每个子交换模块输出相连;数据分组从目的子交换模块输出之后,通过数据总线到达输出端口,完成本次数据传输。
61.举例来说,如图1所示,如果输入端口进来一个从0号端口输入(对应图中第一行第1列的子交换模块),从n 1端口输出(对应图中第二行第2列子交换模块),那么流程如下:从输入端口10进入(即图中输入端口10),然后输入分发模块根据输出端口号,将数据分组分发到了0行1列的行目的子交换模块(即图中第一行第2列的子交换模块),然后在行目的子交换模块中交换转发到第一行第1列的列目的子交换模块(即图中第二行第2列子交换模块),然后通过列目的子交换模块输出到输出端口,完成传输。
62.具体到子交换模块,图2表示本发明的中的子交换模块的实施方式的系统结构图。子交换模块有n个输入端口和m个输出端口,每个输入端口通过行多播分组控制模块row_ctrl 201与该子交换模块所在行的输入端口总线连接,接收来自输入分发模块的数据分组,然后将数据分组存放到对应的in_q中;每个输出端口接收列多播分组控制模块col_ctrl 204控制的来自与该子交换模块同列的其他子交换模块的数据分组,之后将接收到的数据分组存入对应的out_q;数据分组在进入in_q之后,按照“先入先出”的规则存放,每个输入端口的a个in_q的队头数据分组同时参与in_arb 203的仲裁;当某个in_q的队头数据分组被仲裁授权之后,数据分组会进入sub_xbar 207,通过sub_xbar的转发,数据分组会被分发到目的子交换模块的输出端口,并存入相应的out_q中;每个输出端口的b个out_q的队头数据分组同时参与out_arb206的仲裁;当某个out_q的队头数据分组被仲裁授权之后,数据分组输出,完成本次数据交换。
63.进一步地,上述子交换模块的行多播分组控制模块row_ctrl 201和列多播分组控制模块col_ctrl 204需要根据数据分组的目的地址信息进行数据的分发和仲裁。为节约存储资源,提升仲裁效率,本发明中单播分组和多播分组使用如图3所示的统一格式route_map来表示地址信息。该具体实施方式中,数据分组的route_map长度为n
×
m,目的端口记为0到n
×
m-1,端口状态使用1bit数据表示,1表示有效,即该端口是数据分组的目的端口,0表示无效,即该端口不是数据分组的目的端口。数据分组进入位于第i行第j列(0≤i≤m-1,0≤j≤n-1,i和j均为整数)的子交换模块之后,row_ctrl分别提取route_map[0,n,2n,

,n
×
(m-1)],[1,n 1,2n 1,

,n
×
(m-1) 1],

,[n-1,2n-1,3n-1,

,n
×
m-1]字段的端口状态,并对每段数据做按位“或”运算,得到col_route_map,col_route_map长度为n,每一位用1bit来表示,1表示有效,即该列包含目的子交换模块,0表示无效,即该列不包含目的子交
换模块。如图3中所示,row_ctrl根据col_route_map中每一位对应的状态将数据分组分发给列状态有效的对应的本行的子交换模块,row_ctrl会在分发的同时将提取的目的子交换模块所在列对应的route_map相应字段组成行路由比特位图row_route_map随数据分组一起分发到对应子交换模块,在该具体实施方式中,如果col_route_map中第c位(0≤c≤n-1,c为整数)有效,则row_ctrl将route_map[c,c n,c 2n,

,c n
×
(m-1)]字段提取出来作为row_route_map。row_route_map格式如图3中所示,row_route_map长度为m,其中每一位使用1bit来表示,1表示该行有效,即该行包含目的子交换模块,0表示无效,即该行不包含目的子模块。
[0064]
数据分组在in_q中排队申请in_arb,p_arb和col_ctrl仲裁,其中col_ctrl会根据row_route_map中各个行状态为有效的行的目的子交换模块状态来判断,如果row_route_map中所有有效行的目的子交换模块的对应out_q都处于空闲状态,则仲裁成功,否则仲裁失败。
[0065]
进一步地,上述数据分组在in_q中仲裁过程主要包含队列仲裁in_arb,sub_xbr中端口仲裁p_arb和col_ctrl仲裁,其中仲裁具体流程如图4中所示。
[0066]
步骤s1,in_arb按照优先级从高到低的顺序,依次检查a个in_q是否存在队列头部数据分组,直到检测到第一个头部数据分组,则执行步骤s2;否则继续下一轮检查;
[0067]
步骤s2,in_arb提取头部分组的row_route_map交给p_arb,执行步骤s3;
[0068]
步骤s3,p_arb比对row_route_map与sub_xbar各个输出端口状态,如果row_route_map中每一位有效的行号且与之对应的sub_xbar的输出端口处于空闲状态,则p_arb仲裁成功,执行步骤s4;否则p_arb仲裁失败,执行步骤s1;
[0069]
步骤s4,p_arb将row_route_map交给col_ctrl仲裁,执行步骤s5;
[0070]
步骤s5,col_ctrl比对row_route_map与对应行的目的子交换模块的对应out_q状态,如果row_route_map中每一位有效行号且与之对应的out_q状态空闲,则col_ctrl仲裁成功,执行步骤s6;否则执行步骤s1;
[0071]
步骤s6,队列头部分组得到仲裁授权之后,从in_q中输出到sub_xbar,执行步骤s7;
[0072]
步骤s7,sub_xbar按照数据分组的row_route_map中对应的有效行号直接分发到对应输出端口,执行步骤s8;
[0073]
步骤s8,数据分组通过sub_xbar转发到达目的子交换模块,并存入对应out_q,执行步骤s9;
[0074]
步骤s9,out_arb按照优先级从高到低的顺序,依次检查b个out_q是否存在队列头部数据分组,直到检测到第一个头部数据分组,则执行步骤s10;否则继续下一轮检查;
[0075]
步骤s10,队列头部数据分组得到out_arb仲裁,传输到输出总线,完成传输。
[0076]
以下为与上述方法实施例对应的系统实施例,本实施方式可与上述实施方式互相配合实施。上述实施方式中提到的相关技术细节在本实施方式中依然有效,为了减少重复,这里不再赘述。相应地,本实施方式中提到的相关技术细节也可应用在上述实施方式中。
[0077]
本发明还提出了一种数据分组交换系统,其中包括:
[0078]
模块1,用于构建由多个子交换模块构成的交换系统,该交换系统的子交换模块按照行列规则排布,且每行子交换模块均设有输入分发模块,该交换系统中每一列的子交换
模块两两相连;
[0079]
模块2,用于将待交换的数据分组通过输入分发模块进入该交换系统,根据该数据分组携带的目的地址,将该数据分组分发到输入分发模块所在行的子交换模块并将其作为初始交换模块,该初始交换模块将该数据分组存储到单独的一个队列中等待端口仲裁授权;
[0080]
模块3,用于在该数据分组被授权后,根据该目的地址将该数据分组分发给该交换系统中某一行的子交换模块并将其作为目的子交换模块,该目的子交换模块将该数据分组存储到另一个单独的队列,等待输出端口仲裁之后输出该数据分组。
[0081]
所述的数据分组交换系统,其中该子交换模块包括:输入缓存队列in_q、输入队列仲裁模块in_arb、子交换系统sub_xbr、子端口仲裁模块p_arb、输出队列缓存out_q、输出队列仲裁模块out_arb、行多播分组控制模块row_ctrl和列多播分组控制模块col_ctrl;
[0082]
每个该子交换模块对应一个输入端口,数据分组从输入端口进入该子交换模块后,该行多播分组控制模块根据该数据分组的分组类型,将该数据分组缓存到对应输入缓存队列,每个子交换模块共有多个输入缓存队列,每个输入缓存队列按照先入先出的方式存放数据分组;每个输入缓存队列的头部分组竞争输入队列仲裁模块的授权,其中多播分组的竞争优先级高于单播分组,输入队列仲裁模块、子端口仲裁模块和列多播分组控制模块会根据每个参与竞争的头部分组的目的端口是否空闲来授权,综合所有仲裁结果授权给对应的输入缓存队列的头部分组,授权后的数据分组根据其数据分组类型存入该输出队列缓存,每个输出队列缓存按照先入先出的方式存放数据分组;每个输出队列缓存的头部分组竞争输出队列仲裁模块的授权,输出队列缓存的头部分组被授权后输出,到达输出端口,完成传输。
[0083]
所述的数据分组交换系统,其中该行多播分组控制模块和列多播分组控制模块,用于对多播分组的分发和授权控制,当多播分组进入子交换模块后,行多播分组控制模块根据多播分组携带的地址位图,将多播分组同时分发到对应的同行的子交换模块中,同时行多播分组控制模块会从地址位图截取相应部分组成新的位图信息,位图信息会随着该多播分组进入子交换模块;该多播分组进入子交换模块后,需要子端口仲裁模块、输出队列仲裁模块和列多播分组控制模块的授权才能进入子交换系统向目的子交换模块传输,其中列多播分组控制模块根据该位图信息来判断目的子交换模块对应的端口是否空闲,从而决定该多播分组的授权结果。
[0084]
所述的数据分组交换系统,其中仲裁具体包括:
[0085]
模块s1,用于按照优先级从高到低的顺序,依次检查所有输入缓存队列是否存在队列头部数据分组,若有,则调用模块s2;否则继续下一轮检查;
[0086]
模块s2,用于提取头部分组的row_route_map交给子端口仲裁模块,调用模块s3;
[0087]
模块s3,用于比对row_route_map与子交换系统中各个输出端口状态,如果row_route_map中每一位有效的行号且与之对应的子交换系统的输出端口处于空闲状态,则仲裁成功,调用模块s4;否则仲裁失败,调用模块s1;
[0088]
模块s4,用于将row_route_map交给列多播分组控制模块仲裁,调用模块s5;
[0089]
模块s5,用于比对row_route_map与对应行的目的子交换模块的对应输出队列缓存状态,如果row_route_map中每一位有效行号且与之对应的输出队列缓存状态空闲,则仲
裁成功,调用模块s6;否则调用模块s1;
[0090]
模块s6,用于在队列头部分组得到仲裁授权后,从输入缓存队列中输出到子交换系统,调用模块s7;
[0091]
模块s7,用于使子交换系统按照数据分组的row_route_map中对应的有效行号直接分发到对应输出端口,调用模块s8;
[0092]
模块s8,用于使数据分组通过子交换系统转发到达目的子交换模块,并存入对应输出队列缓存,调用模块s9;
[0093]
模块s9,用于按照优先级从高到低的顺序,依次检查每个输出队列缓存是否存在队列头部数据分组,直到检测到第一个头部数据分组,则调用模块s10;否则继续下一轮检查;
[0094]
模块s10,用于使队列头部数据分组得到输出队列仲裁模块仲裁授权,将队列头部数据分组传输到输出总线,完成传输。
[0095]
所述的数据分组交换系统,其中该地址位图长度为n
×
m,m和n分别为该交换系统的行数和列数,目的端口记为0到n
×
m-1,端口状态使用1bit数据表示,1表示有效,0表示无效;数据分组进入位于第i行第j列的子交换模块之后,行多播分组控制模块分别提取该地址位图中各字段的端口状态,并对每段数据做按位或运算,得到该col_route_map;其中0≤i≤m-1、0≤j≤n-1,i和j均为整数。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献