处理器以及指令并行发射的处理方法与流程
未命名
08-25
阅读:129
评论:0
1.本技术涉及计算机技术领域,特别是涉及一种处理器以及指令并行发射的处理方法。
背景技术:
2.随着计算机设备的发展,计算机设备中的处理器的处理能力越来越重要。例如,在通用图形处理器中,计算单元是整个处理器中最核心的模块,线程控制模块是合理调度并控制计算单元有效工作的关键。在绘制平台上,可编程的各种着色器是图形渲染中最重要且最耗时的环节,这些着色器包括顶点着色器(vs,vertex shader)、像素着色器(ps,pixel shader)、外壳着色器(hs,hull shader)以及区域着色器(ds,domain shader)。在这些着色器中,除了纹理采样指令以及内存读写指令之外,占比最多的就是计算指令,因此计算指令的执行效率在通用图形处理器中显得格外重要。
3.目前,同一个线程控制模块所管理的所有线程都是串行执行,如果同一个线程控制模块同时管理的线程数目过多,会导致处理器整体的并行性比较差,导致处理效率低。
技术实现要素:
4.基于此,有必要针对上述技术问题,提供一种处理器以及指令并行发射的处理方法。
5.第一方面,本技术提供了一种处理器,其特征在于,所述处理器包括线程控制模块以及所述线程控制模块对应的n个算术逻辑组,所述n≥2,其中,所述线程控制模块,用于根据算术逻辑组的数量对所述线程控制模块所控制的线程集合进行分组,得到每个所述算术逻辑组分别对应的线程组;所述线程控制模块,从各个所述线程组中分别选取目标线程,获取所述目标线程对应的目标执行指令的目标指令地址,根据所述目标指令地址获取各个所述线程组对应的目标执行指令;所述线程控制模块,用于将所述线程组对应的目标执行指令发送至对应的算术逻辑组;所述算术逻辑组,用于执行接收到的所述目标执行指令,得到所述目标线程对应的指令执行结果。
6.第二方面,本技术还提供了一种指令并行发射的处理方法,所述指令并行发射的处理方法通过处理器执行,所述处理器包括线程控制模块以及所述线程控制模块对应的n个算术逻辑组,所述n≥2,所述方法包括:根据算术逻辑组的数量对所述线程控制模块所控制的线程集合进行分组,得到每个所述算术逻辑组分别对应的线程组;从各个所述线程组中分别选取目标线程,获取所述目标线程对应的目标执行指令的目标指令地址,根据所述目标指令地址获取各个所述线程组对应的目标执行指令;将所述线程组对应的目标执行指令发送至对应的算术逻辑组;以通过所述算术逻辑组执行接收到的所述目标执行指令,得到所述目标线程对应的指令执行结果。
7.第三方面,本技术还提供了一种计算机设备。所述计算机设备包括存储器和处理器,所述存储器存储有计算机程序,所述处理器执行所述计算机程序时实现上述指令处理
方法的步骤。
8.第四方面,本技术还提供了一种计算机可读存储介质。所述计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现指令处理方法的步骤。
9.第五方面,本技术还提供了一种计算机程序产品。所述计算机程序产品,包括计算机程序,该计算机程序被处理器执行时实现指令处理方法的步骤。
10.上述处理器以及指令并行发射的处理方法,处理器包括线程控制模块以及线程控制模块对应的多个算术逻辑组,由于有多个算术逻辑组,且根据算术逻辑组的数量对线程集合进行分组,得到每个算术逻辑组分别对应的线程组。对于一个线程控制模块所控制的线程集合,可以分为多个线程组分别获取执行指令,并可以分别发送至该线程组所对应的算术逻辑组进行处理,因此线程控制模块所控制的线程集合中线程对应的目标执行指令可以并行处理,即线程控制模块可以同时发射多条指令,提高了线程的并行性以及指令的执行效率。
附图说明
11.图1是本发明一实施例的处理器的示意图;
12.图2是本发明一实施例的处理器的示意图;
13.图3是本发明一实施例的处理器的示意图;
14.图4是本发明一实施例的处理器的示意图;
15.图5是本发明一实施例的指令并行发射处理方法的流程示意图。
具体实施方式
16.为了使本技术的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本技术进行进一步详细说明。应当理解,此处描述的具体实施例仅仅用以解释本技术,并不用于限定本技术。
17.图1是本发明一实施例的处理器的示意图。该处理器可以是通用图形处理器。如图1所示,处理器包括线程控制模块(thc,thread control),每个thc可以连接n组算术逻辑组(pair0,pair1,
…
,pair
n-1
),n≥2,其中n取值可以为2、4、8、16等2的幂次方。处理器还可以包括m个指令缓冲单元(ic,instruction cache)ic0,ic1,
…
,ic
m-1
,m≥1。
18.每个算术逻辑组中可以包括一个或者多个算术逻辑单元(alu,algorithm logic unit)以及一个或者多个通用寄存器(crf,common register file)。其中一个pair中alu的数量可以与crf的数量相同,例如:如果一个pair中只有一个alu,就配置一个crf;如果一个pair中有两个alu,就配置两个crf,便于两个alu自由读写crf。如图1所示,pair0包括两个算术逻辑单元主算术逻辑单元(major alu)和副算术逻辑单元(vice alu),两个通用寄存器crf0和crf1。一个算术逻辑组中可以包括一个或者多个算术逻辑单元。多个是指至少两个。
19.举个例子,每个pair中可以只有一个alu,所有指令都在这个alu中执行,也可以为每个pair配置两个alu:major alu(主算术逻辑单元)和vice alu(副算术逻辑单元)。major alu可以只执行浮点类型的指令,vice alu可以只执行整型类型的指令;或者major alu可以执行所有指令,vice alu可以只执行整型类型的指令。major alu和vice alu可以同时工
作,互不影响。alu用于执行指令的具体操作,如乘法、加法、比较、与或非逻辑运算等等中的至少一个。可以理解,本技术实施例对每个算术逻辑组中alu的数量不做限定,例如还可以是3个,具体可以根据实际确定。其中,图1的alu与crf之间的连接线中,虚线代表alu在crf中写数据,实线代表alu从crf中读数据。
20.线程控制模块,用于根据算术逻辑组的数量对线程控制模块所控制的线程集合进行分组,使得每个算术逻辑组得到分别对应的线程组。
21.其中,线程控制模块是管理多个线程同时运行的机制,每个thc可以同时管理a*n个线程,a的数量根据实际可以不同,例如可以为16。在a*n个线程被执行之前,线程控制模块会将a*n个线程分成n组,每组a个线程,n组线程分别对应n个pair,即一个pair可以对应一个线程组,所以每个pair中需要执行a个线程。
22.当每个pair中的crf为多个时,该算术逻辑组对应的线程组可以进一步切分为每个crf分别对应的子线程组。例如,以b表示每个pair中crf的数目,则可以将每个pair对应的线程组再分为b个子线程组,每个子线程组的线程个数为a/b个。例如以a为16,每个pair中包括2个crf为例,则可以将16个线程进一步分成偶数组线程和奇数组线程,每组8个线程,偶数组线程可以始终读写crf0,奇数组线程可以始终读写crf1。一个线程组中可以包括多个线程。
23.子线程组与pair中的crf可以是一一对应关系,但每个alu可以与所在pair中的每个crf都有连接,根据指令的类型每个线程中的指令可能在对应的pair中的任意一个alu中执行。例如一个线程有多条指令,可能一部分在major alu中执行,一部分在vice alu中执行。
24.线程控制模块,用于从各个线程组中分别选取目标线程,获取目标线程对应的目标执行指令的目标指令地址,根据目标指令地址获取各个线程组对应的目标执行指令。
25.其中,一个算术逻辑组可以对应一个线程组,当一个算术逻辑组包括多个crf时,则该算术逻辑组对应的线程组可以进一步切分为每个crf分别对应的子线程组。线程控制模块在每个指令发送周期中,从线程组中获取一个线程作为目标线程。一个指令发送周期可以包括多个时钟周期,为了减轻指令读取压力以及使得每个时钟周期处理器尽可能负载平衡,可以平均分配每个时钟周期所要读取的指令的线程组。例如,假设一个pair中有两个算术逻辑单元,且指令发送周期所对应的时钟周期为两个,即每两个时钟周期向算术逻辑组发送一次指令,则可以是设置在偶数时钟周期,从每个pair对应的偶数线程组中各选一个线程,作为目标线程,总共n个线程;线程控制模块在奇数时钟周期,从每个pair对应的奇数线程组中各选一个线程,作为目标线程,总共n个线程。当然也可以是在偶数时钟周期,从pair0~pair(n/2-1)中每个pair对应的偶数线程组以及奇数线程组各选一个线程,作为目标线程,总共n个线程;在偶数时钟周期,从pair(n/2-2)~pair(n-1)中每个pair对应的偶数线程组以及奇数线程组各选一个线程,作为目标线程,总共n个线程。
26.线程控制模块在每个时钟周期,将读取得到的指令地址发送给指令缓冲单元,指令缓冲单元用于存储待执行的指令,指令缓冲单元收到线程控制模块发送过来的指令请求信号,指令缓冲单元根据指令请求信号中的指令地址从cache(缓存)或内存中取回指令,发送给线程控制模块。
27.一个线程控制模块所对应的指令缓冲单元的数量可以根据其工作频率以及线程
控制模块的工作频率限定,例如,假设thc、alu、crf和ic工作在同频率下,thc的指令发送周期对应的时钟周期数量为2,每个pair中有两个alu,则thc每两个时钟周期最多可以发射2n条指令,为了保证thc有充足的待发射指令,ic每个时钟周期需要提供至少n条指令给thc,也就意味着,每个thc需要连接n个ic,如果ic的工作频率是thc的两倍,就只要n/2个ic。ic的工作频率可以根据需求而定,ic的数量可以为一个或者多个。
28.线程控制模块,用于将线程组对应的目标执行指令发送至对应的算术逻辑组。
29.其中,指令发送周期对应的时钟周期的数量可以为多个,即一个指令发送周期可以包括多个时钟周期,指令发送时钟周期是指线程控制模块发送指令给算术逻辑组时所在的时钟周期。线程控制模块在每个指令发送周期向算术逻辑组发送一次目标执行指令。例如一个指令发送周期对应两个时钟周期,即线程控制模块每两个时钟周期发送一次指令。线程控制模块可以在每个指令发送周期中,从线程组中获取一个线程作为目标线程。因此每个算术逻辑组中的算术逻辑单元可以接收到一个目标执行指令。例如以b表示每个pair中alu的数目,则线程控制模向每个算术逻辑组发送b个目标执行指令。例如,如果一个pair中有两个alu,则线程控制模块每两个时钟周期,将取回来的2n条指令同时并行发射到n个pair中,每个pair接收2条指令。
30.由于建立了算术逻辑组与线程组的对应关系,因此可以确定发送该目标执行指令的目标线程所在的线程组,将目标执行指令发送至该线程组对应的算术逻辑组。
31.在一个实施例中,将线程组对应的目标执行指令发送至对应的算术逻辑组包括:将从上一个指令发送时钟周期后到当前指令发送时钟周期之间的多个时钟周期获取的目标执行指令进行存储,得到指令集合,上一个指令发送时钟周期与当前指令发送时钟周期之间至少间隔一个时钟周期;当到达当前指令发送时钟周期,将指令集合中的线程组对应的目标执行指令发送至算术逻辑组。
32.其中,由于上一个指令发送时钟周期与当前指令发送时钟周期之间至少间隔一个时钟周期,因此一个指令发送周期可以包括多个时钟周期。如上所述,为了减轻指令读取压力以及尽量保证每个时钟周期处理器的负载平衡,可以平均分配每个时钟周期所要读取指令的线程组。线程控制模块存储在每个时钟周期读取到的指令,当到达当前指令发送时钟周期时,再将指令集合中的线程组对应的目标执行指令发送至算术逻辑组。例如,假设每3个时钟周期发送一次指令,即指令发送周期为3个时钟周期,在第4个时钟周期,线程控制模块发送第1个时钟周期、第2个时钟周期以及第3个时钟周期所读取到的指令。线程控制模块将在第4个时钟周期读取的指令进行存储,将在第5个时钟周期读取的指令进行存储,读取到第6个时钟周期读取到指令后,在第7个时钟周期发送第4个时钟周期、第5个时钟周期以及第6个时钟周期所读取到的指令。由于可以将需要读取的指令分配到多个时钟周期进行读取,因此可以减轻指令读取压力。
33.在一个实施例中,一个算术逻辑组中可以包括多个算术逻辑单元以及与算术逻辑单元的数量相同的crf,从每个crf对应的线程组中选取目标线程;将指令集合中的线程组对应的目标执行指令发送至对应的算术逻辑组包括:当算术逻辑组对应的目标执行指令中存在相同类型的指令时,且算术逻辑组中的算术逻辑单元对应的执行指令类型互斥时,将算术逻辑组对应的相同类型的h-1个目标执行指令延迟到下一个指令发送周期进行发送,并将指令集合中剩余的目标执行指令发送至对应的算术逻辑组,h为相同类型的目标执行
指令的数量。
34.在每个指令发送周期中,从线程组中选取各个crf分别对应的目标线程可以是指:每个指令发送周期中,从每个crf对应的线程组中选取一个目标线程,从而每个算术逻辑单元在每个指令发送周期可以对应有需要执行的目标执行指令。
35.当一个算术逻辑组中有多个算术逻辑单元时,则若算术逻辑组中的算术逻辑单元对应的执行指令类型互斥,则说明该算术逻辑组中并不能同时执行相同类型的两个目标执行指令,因此在该指令发送周期,对于相同类型的指令,只发送其中一个指令至算术逻辑组,剩下的h-1个目标执行指令留到下一个指令发送周期再发。可以理解,在下一个指令发送周期,则会相应减少要读取的指令的数量。例如,若有h-1个指令需要延迟到下一个指令发送周期,则下一个指令周期,对于这h-1个指令所对应的线程组,则不再取其对应的指令。
36.在一个实施例中,算术逻辑组中包括第一算术逻辑单元以及第二算术逻辑单元,第一算术逻辑单元用于处理浮点类型的指令,第二算术逻辑单元用于处理整型类型的指令。
37.具体地,在人工智能训练和推理的应用场景中,会存在大量计算内存地址的整型计算,同时也会存在大量涉及浮点运算的卷积算法,因此将每个pair里的alu分隔成fp alu和int alu,fp alu和int alu可以独立并行执行指令,但fp alu只能处理浮点(fp,floating point)类型的指令,int alu只能处理整型(in,integer)类型的指令。从而使得在人工智能训练和推理的应用场景中,指令的执行效率更高。
38.算术逻辑组,用于执行接收到的目标执行指令,得到目标线程对应的指令执行结果。
39.算术逻辑组包括算术逻辑单元以及寄存器,算术逻辑单元接收到目标执行指令,向对应的寄存器发送读取目标执行指令的操作数的请求,寄存器向算术逻辑单元返回操作数。以图1为例,每个pair里的major alu和vice alu分别收到目标执行指令,可以根据指令所对应的线程组确定读写的crf,例如假设major alu所接收到的目标执行指令来自于crf0对应的子线程组,vice alu所接收到的目标执行指令来自于crf1对应的子线程组,则major alu给crf0发送读请求,vice alu给crf1发送读请求,crf0和crf1收到读请求之后,crf0会将操作数发送给major alu,crf1会将操作数发送给vice alu。major alu和vice alu收到寄存器返回的操作数,根据指令信息,执行具体的操作,如乘法、加法或者比较等中的至少一个。major alu和vice alu执行完指令,major alu将结果写回到crf0,vice alu将结果写回到crf1中。
40.在一个实施例中,目标执行指令对应有多个操作数;执行接收到的目标执行指令,得到目标线程对应的指令执行结果包括:在指令发送周期中循环执行目标执行指令p次,每次获取目标执行指令对应的不同的操作数进行处理,得到每次处理得到的目标线程对应的指令执行结果;p≥2;p≤k;k为指令发送周期对应的时钟周期数量。
41.目标执行指令可以是simd方式(single instruction multiple data,单指令多数据),每次alu收到一条指令,可以将指令循环执行多次,但是每次所获取的操作数不同,例如每个alu中有16组(不局限于16,也可以是32等其他数字)乘法、加法或者比较等操作处理的单元,可以同时处理16组数据,从而实现单指令多数据的执行方式。
42.例如,p可以与k相同,即可以根据指令发送周期对应的时钟周期的数量,将目标执
行指令所对应的操作数切分为k个集合,每个时钟周期获取一个集合的操作数进行操作。由于指令发送周期对应的时钟周期数量有多个,循环执行多次目标执行指令,即在每个时钟周期执行一次指令,每次对部分操作数进行操作,相对于在一个时钟周期将全部操作数操作完毕,能够减少处理器的处理压力。
43.在一个实施例中,算术逻辑组包括算术逻辑单元以及算术逻辑单元对应的寄存器;寄存器切分为至少p份子寄存器,在指令发送周期中循环执行目标执行指令p次,每次获取目标执行指令对应的不同的操作数进行处理,得到每次处理得到的目标线程对应的指令执行结果包括:在每次执行目标执行指令时,向当前子寄存器发送操作数读取请求,以读取得到目标执行指令对应的当前操作数;当前子寄存器是从未读取过目标执行指令的操作数的子寄存器中确定的;对当前操作数进行处理,将处理得到的指令执行结果写入当前子寄存器。
44.其中,一份子寄存器可以称为一个bank,寄存器切分的数量可以与指令发送周期对应的时钟周期的数量相同。在每次执行指令时,是从没有读取过目标执行指令的操作数的子寄存器中确定的当前子寄存器中读取当前操作数,在处理得到结果时,再将处理得到的指令执行结果写入当前子寄存器。切分为多个子寄存器一方面能够减轻寄存器读取一个目标执行指令的操作数的读取压力,有利于解决crf的读写冲突。另一方面在前后指令存在依赖的情景中,可以减少因依赖关系导致的指令等待时间。例如,假设指令发送周期对应2个时钟周期,则一个crf会分low和high两个bank去管理,因此同一个时钟周期,crf的low和high两个bank可以同时被读写。alu收到一条指令,循环执行两次,第一次读写crf的low bank,第二次读写crf的high bank,因此在每个时钟周期,alu占用crf的一个bank,另一个bank可以留给处理器的其他模块,譬如纹理采样模块、内存读写模块、像素采样模块等。而在第二个指令发送周期,执行下一个执行指令时,由于下一个执行指令也是分为两个bank分别执行,则若目标执行指令与下一个执行指令之间的数据存在依赖关系,例如目标执行指令得到的结果,会用于下一个执行指令,则在下一个执行指令执行时第一次读写crf的low bank,与执行目标执行指令时第一次读写crf的low bank之间,相隔执行目标执行指令时第二次读写crf的high bank这一次指令执行的过程,从而提高了下一个执行指令执行时第一次读写crf的low bank时,可以利用执行目标执行指令时第一次读写crf的low bank得到的处理结果的概率。其中,low和high用于区分子寄存器的读写顺序,是一个相对概念,例如第一次读取时,可以读取low bank中的数据,第二次读取时,可以读取high bank中的数据。
45.由于一个thc可以管理多个pair单元,算术逻辑单元之间独立运行。也就意味着,每个thc管理的线程数目也相应的变多,这样能实现更多线程之间的同步,例如可以在通用图形处理器中实现多指令并行发射(multi-instruction transmission)。而且由于每个pair能容纳的线程数目越多,同一个线程的先后指令可能存在一些依赖关系,这样就会引入一些等待时间,但如果每个pair能容纳的线程数目比较多,可以通过插入其他线程的时间来隐藏这些等待时间。
46.上述处理器包括线程控制模块以及线程控制模块对应的多个算术逻辑组,由于有多个算术逻辑组,且根据算术逻辑组的数量对线程集合进行分组,得到每个算术逻辑组分别对应的线程组。对于一个线程控制模块所控制的线程集合,可以分为多个线程组分别获
取执行指令,并可以分别发送至该线程组所对应的算术逻辑组进行处理,因此线程控制模块所控制的线程集合中线程对应的目标执行指令可以并行处理,即线程控制模块可以同时发射多条指令,提高了线程的并行性以及指令的执行效率。
47.以下以每个thc都连接到4个pair上,thc、alu和crf的工作频率相同,但ic的工作频率是thc的两倍、每两个时钟周期发送一次指令为例,列举处理器处理指令的三个实施例,可以理解,thc并不仅限于连接到4个pair上,也可以是3个或者更多时钟周期发送一次指令。
48.如图2所示,为一个实施例中处理器的示意图。每个pair只有一个alu和一个crf,一个算术逻辑组的所有计算指令在这一个alu中执行,因此每个alu在同一个时钟周期,接受一条指令。一个thc连接到4个pair,因此每个thc在同一个时钟周期可以并行发射4条指令。thc每两个时钟周期发射一次指令,因此ic每个时钟周期需返回2条指令给thc,thc连接一个ic,因此ic的工作频率为thc工作频率的2倍。alu、crf和thc的工作频率相同。
49.每个pair中有一个crf,这个crf会分low和high两个bank去管理,因此同一个时钟周期,crf的low和high两个bank可以同时被读写。alu收到一条指令,循环执行两次,第一次读写crf的low bank,第二次读写crf的high bank,因此在每个时钟周期,alu占用crf的一个bank,另一个bank可以留给处理器的其他模块,譬如纹理采样模块、内存读写模块或者像素采样模块等。
50.假设每个thc最多可以同时管理32个线程,在32个线程被执行之前,thc会将32个线程分成4组,每组8个线程,每组固定对应一个pair,每组的线程也只能被发往同一个pair。
51.在偶数时钟周期上,thc会从pair0和pair1所对应的那两组线程中各选择一个线程的一条指令地址发送给ic;在奇数时钟周期上,thc会从pair2和pair3所对应的那两组线程中各选择一条指令地址发送给ic。因为ic的工作频率是thc的两倍,所以ic每个时钟可以返回两条指令信息给thc。在thc收到ic发回的4条指令之后,在需要发送指令的时钟周期,thc可以并行将这4条指令分别发射给pair0、pair1、pair2和pair3。每个pair里的alu每两个时钟周期收到一条指令,根据指令信息,alu在第一个时钟周期向crf的low bank发送读请求,在第二个时钟周期向crf的high bank发送读请求。crf送到读请求之后,将操作数送回给alu。每个pair的alu在拿到crf返回的操作数后,根据指令信息,依次执行具体的操作,如乘法、加法或者比较等等。这4条指令在各自pair中独立读写crf,独立并行执行,从而实现了thc并行发射多指令的目的。每个pair的alu在若干个时钟周期后会将计算结果写回给crf的low bank,在若干个时钟周期后会将计算结果写回给crf的high bank。
52.在人工智能训练和推理的应用场景中,会存在大量计算内存地址的整型计算,同时也会存在大量涉及浮点运算的卷积算法,因此,在多指令并行发射的实例二中,将每个pair里的alu分隔成fp alu和int alu,fp alu和int alu可以独立并行执行指令,但fp alu只能处理浮点类型的指令,int alu只能处理整型类型的指令。每个pair里的每个crf也被分成了crf0和crf1两份,类似于fp alu和int alu,crf0和crf1也是分开管理。
53.如图3所示,为一个在人工智能训练和推理的应用场景中处理器的示意图,每个thc连接4个pair,连接2个ic。thc、alu和crf的工作频率相同,ic的工作频率依然为thc工作频率的两倍。每个thc可以同时管理64个线程,64个线程被分成4组,分别对应4个pair,所以
每个pair中需要执行32个线程。将32个线程进一步分成偶数组和奇数组,每组有16个线程,偶数组线程始终读写crf0,奇数组线程始终读写crf1。其中,图3的alu与crf之间的连接线中,虚线代表alu在crf中写数据,实线代表alu从crf中读数据。
54.thc在偶数时钟周期,从pair0对应的偶数线程组和奇数线程组中各选择一个线程,同理从pair1对应的偶数线程组和奇数线程组中各选择一个线程,总共四个线程。
55.thc将来自于偶数线程组的两条指令地址发往ic0,将来自于奇数线程组的两条指令地址发往ic1,由于ic的工作频率是thc的两倍,所以在同一个时钟周期,ic可以将这4条指令送回thc。类似于偶数时钟周期,thc在奇数时钟周期会从pair2和pair3中以同样的方式取回另4条指令。thc每两个时钟周期可以从ic收到8条指令,8条指令中每两条指令属于同一个pair,并且属于同一个pair的两条指令,必定一个是偶数线程组的,一个是奇数线程组的。thc在同一个时钟周期将这8条指令同时送往4个pair中,每个pair收到两条指令,其中一条会被发往fp alu,另一条会被发往int alu。假设发往同一个pair的两条指令是相同类型的指令,此时thc只能往这个pair发送其中一条指令,另一条指令等到下一次指令发射周期再发射。
56.每个pair里的fp alu和int alu每两个时钟周期收到一条指令,假设发往fp alu的指令来自偶数线程组,则根据指令信息,fp alu在第一个时钟周期向crf0的low bank发送读请求,在第二个时钟周期向crf0的high bank发送读请求。crf0收到读请求之后,会依次将操作数送回给fp alu。假设发往int alu的指令来自奇数线程组,int alu在第一个时钟周期向crf1的low bank发送读请求,在第二个时钟周期向crf1的high bank发送读请求。crf1收到读请求之后,会依次将操作数送回给int alu。每个pair的fp alu和int alu在收到crf0和crf1返回的操作数,根据指令信息,依次执行具体的操作,如乘法、加法或者比较等等。这8条指令在各自pair的fp alu和int alu中独立读写crf,独立并行执行,从而实现了thc并行发射多指令的目的。每个pair的fp alu和int alu在若干个时钟周期后会将计算结果写回给其对应的寄存器中的low bank,在若干个时钟周期后会将计算结果写回给其对应的寄存器中的的high bank。
57.图3与图2的处理器之间相比,由于一个pair包括2个算术逻辑单元,因此同样4个pair,thc在同一个时钟周期并行发射的指令数目从4条最多可变成8条,实现了更多的并行性,同时也提高了指令执行效率。
58.图4所示,为一个实施例中处理器的示意图,图4和图3相似,每个pair中有两个alu,但这两个alu不再是互斥关系,fp alu只能运行浮点类型指令,但major alu既可以运行浮点类型指令,也可以运行整型类型指令。每个pair依然可以同时执行两条指令,但两条指令中至少有一条浮点类型的指令,图3的其他运行机制同图2相同,这里不再赘述。其中,图4的alu与crf之间的连接线中,虚线代表alu在crf中写数据,实线代表alu从crf中读数据。图2的处理器可以适应整型类型指令和浮点类型指令在线程中同时出现概率比较大的情况,但在d3d(direct3d)的绘制平台上,浮点型的指令篇幅更大,图3的处理器会比图2的处理器在指令运行上更高效一些。图2与图3中每个pair中alu的多样化,可以使处理器使用的场景更加灵活,在相同数目的pair中,实现更多的并行性,提高指令执行效率
59.在一个实施例中,如图5所示,提供了一种指令并行发射的处理方法,以该方法应用于计算机设备的处理器为例进行说明,处理器包括线程控制模块以及线程控制模块对应
的n个算术逻辑组,n≥2,方法包括以下步骤:
60.步骤s502,根据算术逻辑组的数量对线程控制模块所控制的线程集合进行分组,得到每个算术逻辑组分别对应的线程组。
61.步骤s504,从各个线程组中分别选取目标线程,获取目标线程对应的目标执行指令的目标指令地址,根据目标指令地址获取各个线程组对应的目标执行指令。
62.步骤s506,将线程组对应的目标执行指令发送至对应的算术逻辑组;以通过算术逻辑组执行接收到的目标执行指令,得到目标线程对应的指令执行结果。
63.在一个实施例中,将线程组对应的目标执行指令发送至对应的算术逻辑组包括:将从上一个指令发送时钟周期后到当前指令发送时钟周期之间的多个时钟周期获取的目标执行指令进行存储,得到指令集合,上一个指令发送时钟周期与当前指令发送时钟周期之间至少间隔一个时钟周期;当到达当前指令发送时钟周期,将指令集合中的线程组对应的目标执行指令发送至对应的算术逻辑组。
64.在一个实施例中,算术逻辑组中包括多个算术逻辑单元,在每个指令发送周期中,从线程组中选取各个寄存器分别对应的目标线程;将指令集合中的线程组对应的目标执行指令发送至对应的算术逻辑组包括:当算术逻辑组对应的目标执行指令中存在相同类型的指令时,且算术逻辑组中的算术逻辑单元对应的执行指令类型互斥时,将算术逻辑组对应的相同类型的h-1目标执行指令的延迟到下一个指令发送周期进行发送,并将指令集合中剩余的目标执行指令发送至对应的算术逻辑组,h为相同类型的目标执行指令的数量。
65.在一个实施例中,算术逻辑组中包括第一算术逻辑单元以及第二算术逻辑单元,第一算术逻辑单元用于处理浮点类型的指令,第二算术逻辑单元用于处理整型类型的指令。
66.在一个实施例中,目标执行指令对应有多个操作数;执行接收到的目标执行指令,得到目标线程对应的指令执行结果包括:在指令发送周期中循环执行目标执行指令p次,每次获取目标执行指令对应的不同的操作数进行处理,得到每次处理得到的目标线程对应的指令执行结果;p≥2;p≤k;k为指令发送周期对应的时钟周期数量。
67.在一个实施例中,算术逻辑组包括算术逻辑单元以及算术逻辑单元对应的寄存器;寄存器切分为至少p份子寄存器,循环执行目标执行指令p次,每次获取目标执行指令对应的不同的操作数进行处理,得到每次处理得到的目标线程对应的指令执行结果包括:在每次执行目标执行指令时,向当前子寄存器发送操作数读取请求,以读取得到目标执行指令对应的当前操作数;当前子寄存器是从未读取过目标执行指令的操作数的子寄存器中确定的;对当前操作数进行处理,将处理得到的指令执行结果写入当前子寄存器。
68.应该理解的是,虽然如上所述的各实施例所涉及的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,这些步骤可以以其它的顺序执行。而且,如上所述的各实施例所涉及的流程图中的至少一部分步骤可以包括多个步骤或者多个阶段,这些步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,这些步骤或者阶段的执行顺序也不必然是依次进行,而是可以与其它步骤或者其它步骤中的步骤或者阶段的至少一部分轮流或者交替地执行。
69.故所提供的一个指令并行发射的处理方法实施例中的具体描述可以参见上文中
对于处理器的描述,在此不再赘述。
70.以上实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
71.以上所述实施例仅表达了本技术的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对本技术专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本技术构思的前提下,还可以做出若干变形和改进,这些都属于本技术的保护范围。因此,本技术的保护范围应以所附权利要求为准。
技术特征:
1.一种处理器,其特征在于,所述处理器包括线程控制模块以及所述线程控制模块对应的n个算术逻辑组,所述n≥2,其中,所述线程控制模块,用于根据算术逻辑组的数量对所述线程控制模块所控制的线程集合进行分组,得到每个所述算术逻辑组分别对应的线程组;所述线程控制模块,从各个所述线程组中分别选取目标线程,获取所述目标线程对应的目标执行指令的目标指令地址,根据所述目标指令地址获取各个所述线程组对应的目标执行指令;所述线程控制模块,用于将所述线程组对应的目标执行指令发送至对应的算术逻辑组;所述算术逻辑组,用于执行接收到的所述目标执行指令,得到所述目标线程对应的指令执行结果。2.根据权利要求1所述的处理器,其特征在于,所述将所述线程组对应的目标执行指令发送至对应的算术逻辑组包括:将从上一个指令发送时钟周期后到当前指令发送时钟周期之间的多个时钟周期获取的目标执行指令进行存储,得到指令集合,上一个指令发送时钟周期与当前指令发送时钟周期之间至少间隔一个时钟周期;当到达当前指令发送时钟周期,将所述指令集合中的所述线程组对应的目标执行指令发送至对应的算术逻辑组。3.根据权利要求2所述的处理器,其特征在于,所述算术逻辑组中包括多个算术逻辑单元;所述将所述指令集合中的所述线程组对应的目标执行指令发送至对应的算术逻辑组包括:当所述算术逻辑组对应的目标执行指令中存在相同类型的指令时,且所述算术逻辑组中的算术逻辑单元对应的执行指令类型互斥时,将所述算术逻辑组对应的相同类型的h-1个目标执行指令延迟到下一个指令发送周期进行发送,并将所述指令集合中剩余的目标执行指令发送至对应的算术逻辑组,h为相同类型的目标执行指令的数量。4.根据权利要求3所述的处理器,其特征在于,所述算术逻辑组中包括第一算术逻辑单元以及第二算术逻辑单元,所述第一算术逻辑单元用于处理浮点类型的指令,所述第二算术逻辑单元用于处理整型类型的指令。5.根据权利要求1所述的处理器,其特征在于,所述目标执行指令对应有多个操作数;所述执行接收到的所述目标执行指令,得到所述目标线程对应的指令执行结果包括:在指令发送周期中循环执行所述目标执行指令p次,每次获取所述目标执行指令对应的不同的操作数进行处理,得到每次处理得到的所述目标线程对应的指令执行结果;所述p≥2;所述p≤k;所述k为指令发送周期对应的时钟周期数量。6.根据权利要求5所述的处理器,其特征在于,所述算术逻辑组包括算术逻辑单元以及所述算术逻辑单元对应的寄存器;所述寄存器切分为至少p份子寄存器,所述在指令发送周期中循环执行所述目标执行指令p次,每次获取所述目标执行指令对应的不同的操作数进行处理,得到每次处理得到的所述目标线程对应的指令执行结果包括:在每次执行所述目标执行指令时,向当前子寄存器发送操作数读取请求,以读取得到所述目标执行指令对应的当前操作数;所述当前子寄存器是从未读取过所述目标执行指令
的操作数的子寄存器中确定的;对所述当前操作数进行处理,将处理得到的指令执行结果写入所述当前子寄存器。7.一种指令并行发射的处理方法,其特征在于,所述指令并行发射的处理方法通过处理器执行,所述处理器包括线程控制模块以及所述线程控制模块对应的n个算术逻辑组,所述n≥2,所述方法包括:根据算术逻辑组的数量对所述线程控制模块所控制的线程集合进行分组,得到每个所述算术逻辑组分别对应的线程组;从各个所述线程组中分别选取目标线程,获取所述目标线程对应的目标执行指令的目标指令地址,根据所述目标指令地址获取各个所述线程组对应的目标执行指令;将所述线程组对应的目标执行指令发送至对应的算术逻辑组;以通过所述算术逻辑组执行接收到的所述目标执行指令,得到所述目标线程对应的指令执行结果。8.根据权利要求7所述的指令并行发射的处理方法,其特征在于,所述将所述线程组对应的目标执行指令发送至对应的算术逻辑组包括:将从上一个指令发送时钟周期后到当前指令发送时钟周期之间的多个时钟周期获取的目标执行指令进行存储,得到指令集合,上一个指令发送时钟周期与当前指令发送时钟周期之间至少间隔一个时钟周期;当到达当前指令发送时钟周期,将所述指令集合中的所述线程组对应的目标执行指令发送至对应的算术逻辑组。9.根据权利要求8所述的指令并行发射的处理方法,其特征在于,所述算术逻辑组中包括多个算术逻辑单元,所述将所述指令集合中的所述线程组对应的目标执行指令发送至对应的算术逻辑组包括:当所述算术逻辑组对应的目标执行指令中存在相同类型的指令时,且所述算术逻辑组中的算术逻辑单元对应的执行指令类型互斥时,将所述算术逻辑组对应的相同类型的h-1个目标执行指令延迟到下一个指令发送周期进行发送,并将所述指令集合中剩余的目标执行指令发送至对应的算术逻辑组,h为相同类型的目标执行指令的数量。10.根据权利要求9所述的指令并行发射的处理方法,其特征在于,所述算术逻辑组中包括第一算术逻辑单元以及第二算术逻辑单元,所述第一算术逻辑单元用于处理浮点类型的指令,所述第二算术逻辑单元用于处理整型类型的指令。11.根据权利要求7所述的指令并行发射的处理方法,其特征在于,所述目标执行指令对应有多个操作数;所述执行接收到的所述目标执行指令,得到所述目标线程对应的指令执行结果包括:在指令发送周期中循环执行所述目标执行指令p次,每次获取所述目标执行指令对应的不同的操作数进行处理,得到每次处理得到的所述目标线程对应的指令执行结果;所述p≥2;所述p≤k;所述k为指令发送周期对应的时钟周期数量。12.根据权利要求11所述的指令并行发射的处理方法,其特征在于,所述算术逻辑组包括算术逻辑单元以及所述算术逻辑单元对应的寄存器;所述寄存器切分为至少m份子寄存器,所述在指令发送周期中循环执行所述目标执行指令p次,每次获取所述目标执行指令对应的不同的操作数进行处理,得到每次处理得到的所述目标线程对应的指令执行结果包括:
在每次执行所述目标执行指令时,向当前子寄存器发送操作数读取请求,以读取得到所述目标执行指令对应的当前操作数;所述当前子寄存器是从未读取过所述目标执行指令的操作数的子寄存器中确定的;对所述当前操作数进行处理,将处理得到的指令执行结果写入所述当前子寄存器。
技术总结
本申请涉及一种处理器以及指令并行发射的处理方法。处理器包括线程控制模块以及线程控制模块对应的n个算术逻辑组,n≥2,线程控制模块,用于根据算术逻辑组的数量对线程控制模块所控制的线程集合进行分组,得到每个算术逻辑组分别对应的线程组;线程控制模块,从各个线程组中分别选取目标线程,获取目标线程对应的目标执行指令的目标指令地址,根据目标指令地址获取各个线程组对应的目标执行指令;线程控制模块,用于将线程组对应的目标执行指令发送至对应的算术逻辑组;算术逻辑组,用于执行接收到的目标执行指令,得到目标线程对应的指令执行结果。通过本申请的处理器,可以提高指令处理效率。令处理效率。令处理效率。
技术研发人员:卞仁玉 张淮声 王渊峰
受保护的技术使用者:格兰菲智能科技有限公司
技术研发日:2022.02.10
技术公布日:2023/8/24
版权声明
本文仅代表作者观点,不代表航空之家立场。
本文系作者授权航家号发表,未经原创作者书面授权,任何单位或个人不得引用、复制、转载、摘编、链接或以其他任何方式复制发表。任何单位或个人在获得书面授权使用航空之家内容时,须注明作者及来源 “航空之家”。如非法使用航空之家的部分或全部内容的,航空之家将依法追究其法律责任。(航空之家官方QQ:2926969996)
飞行汽车 https://www.autovtol.com/
