CN116594693A - 一种空间远距离传输数据编解码指令集系统及计算系统 - Google Patents
一种空间远距离传输数据编解码指令集系统及计算系统 Download PDFInfo
- Publication number
- CN116594693A CN116594693A CN202310809805.XA CN202310809805A CN116594693A CN 116594693 A CN116594693 A CN 116594693A CN 202310809805 A CN202310809805 A CN 202310809805A CN 116594693 A CN116594693 A CN 116594693A
- Authority
- CN
- China
- Prior art keywords
- instruction
- register
- vector
- data
- bits
- 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
- 238000004364 calculation method Methods 0.000 claims abstract description 38
- 238000012545 processing Methods 0.000 claims abstract description 32
- 238000000034 method Methods 0.000 claims abstract description 24
- 230000005540 biological transmission Effects 0.000 claims abstract description 19
- 230000008569 process Effects 0.000 claims abstract description 11
- 230000006870 function Effects 0.000 claims abstract description 10
- 230000008571 general function Effects 0.000 claims abstract description 5
- 239000000872 buffer Substances 0.000 claims description 7
- 238000013500 data storage Methods 0.000 claims description 3
- 239000012536 storage buffer Substances 0.000 claims description 3
- 238000010586 diagram Methods 0.000 description 12
- 238000004891 communication Methods 0.000 description 2
- 238000013507 mapping Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 125000004122 cyclic group Chemical group 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 238000005259 measurement Methods 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/3001—Arithmetic instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/30036—Instructions to perform operations on packed data, e.g. vector, tile or matrix operations
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30098—Register arrangements
- G06F9/30101—Special purpose registers
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Mathematical Analysis (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- Computational Mathematics (AREA)
- Mathematical Physics (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
- Complex Calculations (AREA)
Abstract
本发明公开了一种空间远距离传输数据编解码指令集系统及计算系统,指令集系统包括扩展指令集编码,用于进行编码处理指令集;扩展指令集编码为28位等长的指令集编码格式,支持8个32位通用功能寄存器,编码处理指令集gfmu指令,用于完成寄存器支架的伽罗华域乘法操作;compvec指令,用于完成内存中地址向量A和地址向量C的加、减、乘、除、与、或、非、异或、左旋转移位和右旋转移位操作,结果存入地址向量C;compvbwr指令,用于以DMA形式完成向向量B写入向量处理所需要的数据;sboxcpy指令,用于写入查询表格数据,以完成查询预置表的写入;sboxing指令,用于实现写入数据的编码操作输出功能;本发明可以降低批量数据编码中控制流程造成的计算时间开销,提高计算性能。
Description
技术领域
本发明涉及空间远距离传输关键数据处理计算机体系架构和处理器微结构技术领域,更具体的说是涉及一种空间远距离传输数据编解码指令集系统及计算系统。
背景技术
随着星链卫星的持续增加及长期发射,空间飞行器数量急遽增多,这也给星地信息传输带来了大量干扰;空间远距离传输系统需要持续对地发送数据信息,包括中继转发、延时下行、在轨处理结果等关键信息,也包括星间数据通信数据,由于空间通信交互传输的信息往往较为关键,在传输过程中一般需要进行编码、解码计算实现信息的纠检错及其它编码。
而卫星计算机在上述处理过程中常见的卷积码、RS编码、AES、SM4等计算往往需要耗费大量的计算资源;在空间远距离传输系统中,特别是深空探测领域,关键数据信息可能瞬时达到1~10Gbps量级,传统的设计方法一般采用宇航数字逻辑器件搭建编码逻辑或者通用处理器计算,G比特级每秒数据的处理往往导致占用大量资源或计算时间,降低了逻辑资源利用和星地交互效率。
目前,采用基于RISC架构的关键数据编解码处理专用加速指令集,虽然既能够满足算法灵活修改应用又能够提高测控通信的时效性,又能够实现空间远距离传输处理结果的可靠安全传输。
但是,传统的RISC架构诸如MIPS、ARM和RISC-V等依靠与、或、非等逻辑指令完成编码计算,同时依赖条件、循环指令控制流程,降低了计算效率,特别是在复杂编码计算(如SM4)时难以提高处理后数据传输的时效性;编码处理计算过程中,往往用到向量操作、伽罗华域计算等操作,这两类计算需要占用整个编码计算量的90%以上。
因此,如何充分利用逻辑资源及提高计算时效性,将常用向量计算操作、伽罗华域计算、变换查表等操作固化为一条多周期、多输入输出计算的RISC指令的形式,通过独立的逻辑硬件资源完成复杂控制和运算,提升整个关键数据编解码处理过程中的运算效率是本领域技术人员亟需解决的问题。
发明内容
有鉴于此,本发明提供了一种空间远距离传输数据编解码指令集系统及计算系统,可以降低批量数据在进行逻辑、映射计算等编码操作过程中,控制流程造成的计算时间开销,从而有够有效提高程序性能及降低开发难度。
为了实现上述目的,本发明采用如下技术方案:
一种空间远距离传输数据编解码指令集系统,包括扩展指令集编码,用于进行编码处理指令集;
扩展指令集编码为28位等长的指令集编码格式,支持8个32位通用功能寄存器,包括定长的操作码字段OpCode、第一寄存器索引字段Ra、第二寄存器索引字段Rb、第三寄存器索引字段Rc、第四寄存器索引字段Rd和立即数字段imm;
编码处理指令集包括:伽罗华域乘法指令gfmu、向量计算指令compvec、B向量写入指令compvbwr、S盒查找表写入指令sboxcpy和S盒查询指令sboxinq;
gfmu指令,用于完成遥测遥控编码处理中的伽罗华域乘法操作;
compvec指令,用于完成内存中地址向量A和地址向量C的加、减、乘、除、与、或、非、异或、左旋转移位和右旋转移位操作,结果存入地址向量C;
compvbwr指令,用于以DMA形式完成向向量B写入向量处理所需要的数据;
sboxcpy指令,用于写入查询表格数据,以完成查询预置表的写入;
sboxing指令,用于实现写入数据的编码操作输出功能。
优选的,操作码字段OpCode,用于区分各指令实现的不同功能,各个指令中只有寄存器编号的标识,各指令操作的参数由寄存器内部数值区分。
优选的,gfmu指令从寄存器Ra获得被乘数,从寄存器Rb获得被乘数,伽罗华域乘法结果存入;
compvec指令从寄存器Ra获得计算向量A的初始地址,以及结果存储向量C的初始地址;从寄存器Rb获得计算向量A和向量C数据的选取间隔和长度;从寄存器Rc获得计算类型和B向量类型;从寄存器Rd获得B向量的常数数值;
compvbwr指令从寄存器Ra获得计算向量B的初始地址;从寄存器Rb获得计算向量B的选取间隔和长度;
sboxcpy指令从寄存器Ra获得写入数据的起始地址;从寄存器Rb获得写入数据长度;从寄存器Rc获得存储类型;
sboxing指令从寄存器Ra获得写入需要查询数据的起始地址和存入目标地址;从寄存器Rb获得查询长度;从寄存器Rc获得存入数据间隔及存入数据长度;从寄存器Rd获得查询类型和输出类型。
优选的,gfmu指令,汇编格式为gfmuRa,Rb,Rc;
其中,Ra、Rb和Rc为8个寄存器中的任意三个,用于通过寄存器的低8位存放伽罗华域乘法中的被乘数、乘数以及乘法结果。
优选的,compvec指令,汇编格式为compvecRa,Rb,Rc,Rd;
其中,Ra、Rb、Rc和Rd为8个寄存器中的任意4个,Ra寄存器的高16位表示向量A在内存中的起始位置,Ra寄存器的低16位表示向量C在内存中的起始位置;
Rb寄存器的高16位表示向量中连续数据在地址上的间隔,Rb寄存器的低16位表示向量的长度;
Rc寄存器的高16位的低四位表示计算类型,Rc寄存器的最低位表示计算B向量是否为常数。
优选的,compvbwr指令,汇编格式为compvbwrRa,Rb;
其中,Ra、Rb是8个寄存器中的任意2个,Ra寄存器的高16位代表B向量的初始地址,Rb寄存器的高16位代表向量中连续数据的间隔,Rb寄存器的低16位代表B向量的长度。
优选的,sboxcpy指令,汇编格式为sboxcpyRa,Rb,Rc;
其中,寄存器Ra的低16位表示源地址起始地址,Rb的低16位表示读取存储数据的长度,Rc的低3位表示存储模式。
优选的,sboxing指令,汇编格式为sboxcpyRa,Rb,Rc,Rd;
其中,寄存器Ra的高16位表示源地址起始地址,寄存器Ra的低16位表示目的地址的起始地址;
寄存器Rb的低16位表示被查询或编码数据的长度;
寄存器Rc的高16位表示目的地址数据之间的间隔,寄存器Rc的低16位表示目的数据存储的长度;
寄存器Rd的高16位的低3位表示工作模式,寄存器Rd的低16位的最低位表示输出模式。
一种空间远距离传输数据编解码计算系统,包括计算机和一种空间远距离传输数据编解码指令集系统,所述计算机用于运行所述的一种空间远距离传输数据编解码指令集系统。
优选的,计算机包括处理器缓存及寄存器,处理器指令存储缓存,指令译码模块和编码处理指令计算分支;
指令译码模块从处理器指令存储缓存获取指令码,编码处理指令计算分支判断指令码是否为编码处理指令,如是,则运行空间远距离传输数据编解码指令集系统,通过处理器缓存及寄存器进行处理。
经由上述的技术方案可知,与现有技术相比,本发明公开提供了一种空间远距离传输数据编解码指令集系统及计算系统,提供了一种关键数据编解码处理扩展指令集,可用于为RISC处理器扩展特定功能,提高计算速度;使用该扩展指令集可以减少编写编码处理计算过程的代码量,便于提高代码有效性;扩展指令集将编码处理过程关键的伽罗华域乘法、向量计算、查表映射计算过程及其参数编进处理器的寄存器及其指令,可以适用于多数RISC协处理器扩展接口和不同架构处理器的扩展,适应性较强。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1附图为本发明提供的一种空间远距离传输数据编解码指令集系统的扩展指令集编码示意图;
图2附图为本发明提供的gfmu指令的编码方式和寄存器信息示意图;
图3附图为本发明提供的gfmu指令对应的向量计算示例示意图;
图4附图为本发明提供的compvec指令的编码方式和寄存器信息示意图;
图5附图为本发明提供的compvec指令对应的向量计算示例示意图;
图6附图为本发明提供的compvbwr指令的编码方式和寄存器信息示意图;
图7附图为本发明提供的compvbwr指令对应的向量计算示例示意图;
图8附图为本发明提供的sboxcpy指令的编码方式和寄存器信息示意图;
图9附图为本发明提供的sboxcpy指令对应的向量计算示例示意图;
图10附图为本发明提供的sboxing指令的编码方式和寄存器信息示意图;
图11附图为本发明提供的sboxing指令对应的向量计算示例示意图;
图12附图为本发明提供的一种空间远距离传输数据编解码计算系统示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本发明实施例公开了一种空间远距离传输数据编解码指令集系统,包括扩展指令集编码,用于进行编码处理指令集;
如图1,扩展指令集编码为28位等长的指令集编码格式,支持8个32位通用功能寄存器,包括定长的操作码字段OpCode、第一寄存器索引字段Ra、第二寄存器索引字段Rb、第三寄存器索引字段Rc、第四寄存器索引字段Rd和立即数字段imm;
编码处理指令集包括:伽罗华域乘法指令gfmu、向量计算指令compvec、B向量写入指令compvbwr、S盒查找表写入指令sboxcpy和S盒查询指令sboxinq;
gfmu指令,用于完成遥测遥控编码处理中的伽罗华域乘法操作;
compvec指令,用于完成内存中地址向量A和地址向量C的加、减、乘、除、与、或、非、异或、左旋转移位和右旋转移位操作,结果存入地址向量C;
compvbwr指令,用于以DMA形式完成向向量B写入向量处理所需要的数据;
sboxcpy指令,用于写入查询表格数据,以完成查询预置表的写入;
sboxing指令,用于实现写入数据的编码操作输出功能。
为了进一步实施上述技术方案,操作码字段OpCode,用于区分各指令实现的不同功能,各个指令中只有寄存器编号的标识,各指令操作的参数由寄存器内部数值区分。
为了进一步实施上述技术方案,gfmu指令从寄存器Ra获得被乘数,从寄存器Rb获得被乘数,伽罗华域乘法结果存入;
compvec指令从寄存器Ra获得计算向量A的初始地址,以及结果存储向量C的初始地址;从寄存器Rb获得计算向量A和向量C数据的选取间隔和长度;从寄存器Rc获得计算类型和B向量类型;从寄存器Rd获得B向量的常数数值;
compvbwr指令从寄存器Ra获得计算向量B的初始地址;从寄存器Rb获得计算向量B的选取间隔和长度;
sboxcpy指令从寄存器Ra获得写入数据的起始地址;从寄存器Rb获得写入数据长度;从寄存器Rc获得存储类型;
sboxing指令从寄存器Ra获得写入需要查询数据的起始地址和存入目标地址;从寄存器Rb获得查询长度;从寄存器Rc获得存入数据间隔及存入数据长度;从寄存器Rd获得查询类型和输出类型。
为了进一步实施上述技术方案,如图2和图3,gfmu指令,汇编格式为gfmuRa,Rb,Rc;
其中,Ra、Rb和Rc为8个寄存器中的任意三个,用于通过寄存器的低8位存放伽罗华域乘法中的被乘数、乘数以及乘法结果。
为了进一步实施上述技术方案,如图4和图5,compvec指令,汇编格式为compvecRa,Rb,Rc,Rd;
其中,Ra、Rb、Rc和Rd为8个寄存器中的任意4个,Ra寄存器的高16位表示向量A在内存中的起始位置,Ra寄存器的低16位表示向量C在内存中的起始位置;
Rb寄存器的高16位表示向量中连续数据在地址上的间隔,Rb寄存器的低16位表示向量的长度;
Rc寄存器的高16位的低四位表示计算类型,其中“0000”表示加法,“0001”表示减法,“0010”表示乘法,“0011”表示与操作,“0100”表示或操作,“0101”表示非操作,“0110”表示异或操作,“0111”表示左移位操作,“1000”表示右移位操作;Rc寄存器的最低位表示计算B向量是否为常数,当最低位为1时,表示B向量为常数,常数存储在寄存器Rd,如果为0则表示B向量非常数。
为了进一步实施上述技术方案,如图6和图7,compvbwr指令,汇编格式为compvbwrRa,Rb;
其中,Ra、Rb是8个寄存器中的任意2个,Ra寄存器的高16位代表B向量的初始地址,Rb寄存器的高16位代表向量中连续数据的间隔,Rb寄存器的低16位代表B向量的长度。
为了进一步实施上述技术方案,如图8和图9,sboxcpy指令,汇编格式为sboxcpyRa,Rb,Rc;
其中,寄存器Ra的低16位表示源地址起始地址,Rb的低16位表示读取存储数据的长度,Rc的低3位表示存储模式,当为“000”时存入所有通道,“001”表示存入0通道,“010”表示存入1通道,“011”表示存入2通道,“100”表示存入3通道。
为了进一步实施上述技术方案,如图10和图11,sboxing指令,汇编格式为sboxcpyRa,Rb,Rc,Rd;
其中,寄存器Ra的高16位表示源地址起始地址,寄存器Ra的低16位表示目的地址的起始地址;
寄存器Rb的低16位表示被查询或编码数据的长度;
寄存器Rc的高16位表示目的地址数据之间的间隔,寄存器Rc的低16位表示目的数据存储的长度;
寄存器Rd的高16位的低3位表示工作模式,“000”表示四个通道进行32位位异或操作再输出,“001”表示输出0通道,“010”表示输出1通道,“011”表示输出2通道,“100”表示输出3通道;寄存器Rd的低16位的最低位表示输出模式,‘0’表示四通道32位输出,‘1’表示四通道低8位输出合成32位输出。
一种空间远距离传输数据编解码计算系统,包括计算机和一种空间远距离传输数据编解码指令集系统,计算机用于运行空间远距离传输数据编解码指令集系统。
为了进一步实施上述技术方案,计算机包括处理器缓存及寄存器,处理器指令存储缓存,指令译码模块和编码处理指令计算分支;
指令译码模块从处理器指令存储缓存获取指令码,编码处理指令计算分支判断指令码是否为编码处理指令,如是,则运行空间远距离传输数据编解码指令集系统,通过处理器缓存及寄存器进行处理。
另一实施例一种遥测遥控编码处理指令集系统的一种编码方式,指令cmd的[27:24]为OpCode,用以区分指令实现的不同功能;cmd[23:21]为Ra,表示第一个寄存器编号;cmd[20:18]为Rb,表示第二个寄存器编号;cmd[17:15]为Rc,表示第三个寄存器编号;cmd[14:12]为Rd,表示第四个寄存器编号;cmd[11:0]为保留字段;gfmu、compvec、compvbwr、sboxcpy、sboxing指令均由OpCode进行区分,指令中只有寄存器编号的标识,各指令操作的参数由寄存器内部数值区分。
在本实施例中,gfmu指令的编码方式和寄存器信息如图2所示,与之对应的伽罗华域乘法操作如图3所示:伽罗华域乘法指令gfmu从寄存器Ra获得被乘数Multiplicand,从寄存器Rb获得被乘数Multiplier,伽罗华域乘法结果存入Product;
汇编格式为gfmuRa,Rb,Rc;
Ra,Rb,Rc仅低8位有效,高位数值不影响计算结果的高23位。
向量计算指令compvec,从寄存器Ra获得计算向量A的初始地址A_Address,以及结果存储向量C的初始地址C_Address,其中,A_Address=Ra[31:16],C_Address=Ra[15:0];从寄存器Rb获得计算向量A、C数据的的选取间隔Interval和长度Length,其中Interval=Rb[31:16],Length=Rb[15:0];从寄存器Rc获得计算类型Type和B向量类型B_Type,其中Type=Rc[19:16],B_Type=Rc[0];从寄存器Rd获得B向量的常数数值Constant=Rd,当B_Type=1时有效;
汇编格式为compvecRa,Rb,Rc,Rd;
Type的二进制数值代表向量的不同计算功能,如下:0000b:+;0001b:-;0010b:*;0011b:and;0100b:or;0101b:not;0110b:xor;0111b:rotl;1000b:rotr;当B_Type=0,表示B向量为向量,否则为常数Rd。
B向量写入指令compvbwr,从寄存器Ra获得计算向量B的初始地址B_Address,B_Address=Ra[31:16];从寄存器Rb获得计算向量B的选取间隔Interval和长度Length,其中Interval=Rb[31:16],Length=Rb[15:0];
汇编格式为compvbwrRa,Rb;
指令仅表示选取缓存数据放入向量计算存储,不改变寄存器数值。
S盒查找表写入指令sboxcpy,从寄存器Ra获得写入数据的起始地址Rsr_Address;从寄存器Rb获得写入数据长度Read_Length;从寄存器Rc获得存储类型Store_Type;其中,Rsr_Address=Ra[15:0],Read_Length=Rb[15:0],Store_Type=Rc[3:0];
汇编格式为sboxcpyRa,Rb,Rc;
Store_Typede数值代表数据存入方式:000b:同时存入缓存B0~B3;001b:存入B0;010b:存入B1;011b:存入B2;100b:存入B3。
S盒查询指令sboxing,从寄存器Ra获得写入需要查询数据的起始地址Rsr_Address和存入目标地址Des_Address;从寄存器Rb获得查询长度Box_Length;从寄存器Rc获得存入数据间隔Des_Interval及存入数据长度Store_Length;从寄存器Rd获得查询类型Box_Type和输出类型OT_Type;其中,Rsr_Address=Ra[31:16],Des_Address=Ra[15:0],Box_Length=Rb[15:0],Des_Interval=Rc[31:16],Store_Length=Rc[15:0],Box_Type=Rd[19:16],OT_Type=Rd[0];
汇编格式为sboxingRa,Rb,Rc,Rd;
Box_Type表示4个查询表输出数值处置方法:000b:4个查询表输出结果进行位异或;001b:输出缓存B0的查询数值;010b:输出缓存B1的查询数值;011b:输出缓存B2的查询数值;100b:输出缓存B3的查询数值;
OT_Type=0时,输出查询结果,否则输出4个查找表查询结果低8位的组合。
本实施例RISC处理器通过协处理器执行扩展指令,加速卫星遥测遥控处理任务,提升性能,提高代码密度
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
对所公开的实施例的上述说明,使本领域专业技术人员能够实现或使用本发明。对这些实施例的多种修改对本领域的专业技术人员来说将是显而易见的,本文中所定义的一般原理可以在不脱离本发明的精神或范围的情况下,在其它实施例中实现。因此,本发明将不会被限制于本文所示的这些实施例,而是要符合与本文所公开的原理和新颖特点相一致的最宽的范围。
Claims (10)
1.一种空间远距离传输数据编解码指令集系统,其特征在于,包括扩展指令集编码,用于进行编码处理指令集;
扩展指令集编码为28位等长的指令集编码格式,支持8个32位通用功能寄存器,包括定长的操作码字段OpCode、第一寄存器索引字段Ra、第二寄存器索引字段Rb、第三寄存器索引字段Rc、第四寄存器索引字段Rd和立即数字段imm;
编码处理指令集包括:伽罗华域乘法指令gfmu、向量计算指令compvec、B向量写入指令compvbwr、S盒查找表写入指令sboxcpy和S盒查询指令sboxinq;
gfmu指令,用于完成通用功能寄存器之间的伽罗华域乘法操作;
compvec指令,用于完成内存中地址向量A和地址向量C的加、减、乘、除、与、或、非、异或、左旋转移位和右旋转移位操作,结果存入地址向量C;
compvbwr指令,用于以DMA形式完成向向量B写入向量处理所需要的数据;
sboxcpy指令,用于写入查询表格数据,以完成查询预置表的写入;
sboxing指令,用于实现写入数据的编码操作输出功能。
2.根据权利要求1所述的一种空间远距离传输数据编解码指令集系统,其特征在于,操作码字段OpCode,用于区分各指令实现的不同功能,各个指令中只有寄存器编号的标识,各指令操作的参数由寄存器内部数值区分。
3.根据权利要求1所述的一种空间远距离传输数据编解码指令集系统,其特征在于,gfmu指令从寄存器Ra获得被乘数,从寄存器Rb获得被乘数,伽罗华域乘法结果存入;
compvec指令从寄存器Ra获得计算向量A的初始地址,以及结果存储向量C的初始地址;从寄存器Rb获得计算向量A和向量C数据的选取间隔和长度;从寄存器Rc获得计算类型和B向量类型;从寄存器Rd获得B向量的常数数值;
compvbwr指令从寄存器Ra获得计算向量B的初始地址;从寄存器Rb获得计算向量B的选取间隔和长度;
sboxcpy指令从寄存器Ra获得写入数据的起始地址;从寄存器Rb获得写入数据长度;从寄存器Rc获得存储类型;
sboxing指令从寄存器Ra获得写入需要查询数据的起始地址和存入目标地址;从寄存器Rb获得查询长度;从寄存器Rc获得存入数据间隔及存入数据长度;从寄存器Rd获得查询类型和输出类型。
4.根据权利要求1所述的一种空间远距离传输数据编解码指令集系统,其特征在于,gfmu指令,汇编格式为gfmuRa,Rb,Rc;
其中,Ra、Rb和Rc为8个寄存器中的任意三个,用于通过寄存器的低8位存放伽罗华域乘法中的被乘数、乘数以及乘法结果。
5.根据权利要求1所述的一种空间远距离传输数据编解码指令集系统,其特征在于,compvec指令,汇编格式为compvecRa,Rb,Rc,Rd;
其中,Ra、Rb、Rc和Rd为8个寄存器中的任意4个,Ra寄存器的高16位表示向量A在内存中的起始位置,Ra寄存器的低16位表示向量C在内存中的起始位置;
Rb寄存器的高16位表示向量中连续数据在地址上的间隔,Rb寄存器的低16位表示向量的长度;
Rc寄存器的高16位的低四位表示计算类型,Rc寄存器的最低位表示计算B向量是否为常数。
6.根据权利要求1所述的一种空间远距离传输数据编解码指令集系统,其特征在于,compvbwr指令,汇编格式为compvbwrRa,Rb;
其中,Ra、Rb是8个寄存器中的任意2个,Ra寄存器的高16位代表B向量的初始地址,Rb寄存器的高16位代表向量中连续数据的间隔,Rb寄存器的低16位代表B向量的长度。
7.根据权利要求1所述的一种空间远距离传输数据编解码指令集系统,其特征在于,sboxcpy指令,汇编格式为sboxcpyRa,Rb,Rc;
其中,寄存器Ra的低16位表示源地址起始地址,Rb的低16位表示读取存储数据的长度,Rc的低3位表示存储模式。
8.根据权利要求1所述的一种空间远距离传输数据编解码指令集系统,其特征在于,sboxing指令,汇编格式为sboxcpyRa,Rb,Rc,Rd;
其中,寄存器Ra的高16位表示源地址起始地址,寄存器Ra的低16位表示目的地址的起始地址;
寄存器Rb的低16位表示被查询或编码数据的长度;
寄存器Rc的高16位表示目的地址数据之间的间隔,寄存器Rc的低16位表示目的数据存储的长度;
寄存器Rd的高16位的低3位表示工作模式,寄存器Rd的低16位的最低位表示输出模式。
9.一种空间远距离传输数据编解码计算系统,其特征在于,包括计算机和权利要求1-8任意一项所述的一种空间远距离传输数据编解码指令集系统,所述计算机用于运行所述的一种空间远距离传输数据编解码指令集系统。
10.根据权利要求9所述的一种空间远距离传输数据编解码计算系统,其特征在于,计算机包括处理器缓存及寄存器,处理器指令存储缓存,指令译码模块和编码处理指令计算分支;
指令译码模块从处理器指令存储缓存获取指令码,编码处理指令计算分支判断指令码是否为编码处理指令,如是,则运行空间远距离传输数据编解码指令集系统,通过处理器缓存及寄存器进行处理。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310809805.XA CN116594693B (zh) | 2023-07-04 | 2023-07-04 | 一种空间远距离传输数据编解码指令集系统及计算系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310809805.XA CN116594693B (zh) | 2023-07-04 | 2023-07-04 | 一种空间远距离传输数据编解码指令集系统及计算系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN116594693A true CN116594693A (zh) | 2023-08-15 |
CN116594693B CN116594693B (zh) | 2023-09-22 |
Family
ID=87604695
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310809805.XA Active CN116594693B (zh) | 2023-07-04 | 2023-07-04 | 一种空间远距离传输数据编解码指令集系统及计算系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116594693B (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140052969A1 (en) * | 2011-12-23 | 2014-02-20 | Intel Corporation | Super multiply add (super madd) instructions with three scalar terms |
CN104011665A (zh) * | 2011-12-23 | 2014-08-27 | 英特尔公司 | 超级乘加(超级madd)指令 |
CN108959180A (zh) * | 2018-06-15 | 2018-12-07 | 北京探境科技有限公司 | 一种数据处理方法及系统 |
CN113157321A (zh) * | 2021-02-05 | 2021-07-23 | 湖南国科亿存信息科技有限公司 | Arm平台下基于neon指令加速的纠删编解码方法及装置 |
CN113656071A (zh) * | 2021-10-18 | 2021-11-16 | 深圳市智想科技有限公司 | 一种基于risc架构的cpu指令集系统及cpu系统 |
-
2023
- 2023-07-04 CN CN202310809805.XA patent/CN116594693B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140052969A1 (en) * | 2011-12-23 | 2014-02-20 | Intel Corporation | Super multiply add (super madd) instructions with three scalar terms |
CN104011665A (zh) * | 2011-12-23 | 2014-08-27 | 英特尔公司 | 超级乘加(超级madd)指令 |
CN108959180A (zh) * | 2018-06-15 | 2018-12-07 | 北京探境科技有限公司 | 一种数据处理方法及系统 |
CN113157321A (zh) * | 2021-02-05 | 2021-07-23 | 湖南国科亿存信息科技有限公司 | Arm平台下基于neon指令加速的纠删编解码方法及装置 |
CN113656071A (zh) * | 2021-10-18 | 2021-11-16 | 深圳市智想科技有限公司 | 一种基于risc架构的cpu指令集系统及cpu系统 |
Also Published As
Publication number | Publication date |
---|---|
CN116594693B (zh) | 2023-09-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI804200B (zh) | 執行複數的熔合乘-加指令的系統與方法 | |
CN100356316C (zh) | 用来解码并执行指令的处理器 | |
KR100690225B1 (ko) | 데이터 처리기 시스템 및 그룹화를 이용한 명령 시스템 | |
RU2263947C2 (ru) | Целочисленное умножение высокого порядка с округлением и сдвигом в архитектуре с одним потоком команд и множеством потоков данных | |
CN108009126B (zh) | 一种计算方法及相关产品 | |
CN104395876B (zh) | 没有算术和逻辑单元的计算机处理器和系统 | |
TW201732567A (zh) | 用於資料解壓縮的硬體設備及方法 | |
TWI599950B (zh) | 用於摩頓座標調整之處理器,方法,系統,及製造物件 | |
CN108121688B (zh) | 一种计算方法及相关产品 | |
US7814302B2 (en) | Address calculation instruction within data processing systems | |
JPH096609A (ja) | プログラム実行装置およびプログラム変換方法 | |
TWI582692B (zh) | 三維摩頓座標轉換處理器,方法,系統,及指令 | |
US20030033504A1 (en) | Micro-controller for reading out compressed instruction code and program memory for compressing instruction code and storing therein | |
CN108804137A (zh) | 用于双目的地类型转换、累加和原子存储器操作的指令 | |
CN112099762A (zh) | 快速实现sm2密码算法的协处理系统及方法 | |
CN103970508A (zh) | 一种精简的微处理器ip核 | |
CN116594693B (zh) | 一种空间远距离传输数据编解码指令集系统及计算系统 | |
Wang et al. | Customized instruction on risc-v for winograd-based convolution acceleration | |
JP2004511039A (ja) | 単一命令多数データ処理 | |
JP2002149402A (ja) | データ処理装置およびその制御方法 | |
US5390306A (en) | Pipeline processing system and microprocessor using the system | |
CN111079934B (zh) | 应用于环域上误差学习加密算法的数论变换单元和方法 | |
KR20130045276A (ko) | 명령으로서 데이터 값을 평가하기 위한 시스템 및 방법 | |
CN110058884B (zh) | 用于计算型存储指令集运算的优化方法、系统及存储介质 | |
CN107977231B (zh) | 一种计算方法及相关产品 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | 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 |