CN112445484A - 一种寄存器处理方法、装置、电子设备及存储介质 - Google Patents

一种寄存器处理方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN112445484A
CN112445484A CN201910797926.0A CN201910797926A CN112445484A CN 112445484 A CN112445484 A CN 112445484A CN 201910797926 A CN201910797926 A CN 201910797926A CN 112445484 A CN112445484 A CN 112445484A
Authority
CN
China
Prior art keywords
target register
subprogram
use information
register
instruction
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
Application number
CN201910797926.0A
Other languages
English (en)
Other versions
CN112445484B (zh
Inventor
敖琪
王雪
井田
高翔
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.)
Loongson Technology Corp Ltd
Original Assignee
Loongson Technology Corp Ltd
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 Loongson Technology Corp Ltd filed Critical Loongson Technology Corp Ltd
Priority to CN201910797926.0A priority Critical patent/CN112445484B/zh
Publication of CN112445484A publication Critical patent/CN112445484A/zh
Application granted granted Critical
Publication of CN112445484B publication Critical patent/CN112445484B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/448Execution paradigms, e.g. implementations of programming paradigms
    • G06F9/4482Procedural
    • G06F9/4484Executing subprograms

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Devices For Executing Special Programs (AREA)

Abstract

本发明实施例提供了一种寄存器处理方法和装置,所述方法包括:获取需即时编译的父程序调用的已静态编译的子程序,检测所述子程序中使用目标寄存器的使用信息,根据所述使用信息,对所述目标寄存器进行保存或恢复,使得在即时编译的父程序调用静态编译的子程序的前后有针对性的保存或恢复寄存器,达到减少保存或恢复目标寄存器时的指令数量的效果,从而提高执行性能。

Description

一种寄存器处理方法、装置、电子设备及存储介质
技术领域
本发明涉及计算机技术领域,特别是涉及一种寄存器处理方法、一种寄存器处理装置、一种电子设备以及一种可读存储介质。
背景技术
动态编译是某些程式语言在执行时用来增进效能的方法,一般指的是程序在运行时进行编译。与之相对的是事前编译,也叫静态编译。静态编译就是编译器在编译可执行文件的时候,将可执行文件需要调用的对应静态库(例如,拓展名为.a或.lib的库)中的部分提取出来,链接到可执行文件中去,使可执行文件在运行的时候不依赖于动态链接库。静态编译典型的例子是gcc(GNU Compiler Collection,GNU编译器套件)的编译方式。gcc会先将源程序编译成可执行的机器码,在部署或分发程序时,直接部署编译后的机器码即可,在程序执行时不再需要编译过程。
动态编译的典型例子是Java(一种计算机编程语言)虚拟机中的即时编译(Just-in-time compilation,简称JIT)方式。Java程序是一种字节码程序,并不能在实际的物理机上直接执行,在执行Java程序时一般先进行解释执行,其执行速度肯定比可执行的二进制机器码程序慢。为了提高执行速度,引入了JIT。在运行时,当识别到热点方法或循环时,JIT会对热点方法进行动态编译,将字节码编译成本地可执行的机器码,,然后直接运行编译后的机器码,并把翻译过来的机器码保存起来,以备下次使用。
编译的程序中会存在调用者和被调用者。在进行子程序调用时,由调用者(caller)负责保存的寄存器称为caller-saved(调用者保存)寄存器。在进行子程序调用时,由被调用者(callee)负责保存的寄存器称为callee-saved(被调用者保存)寄存器。
在编译一个程序中的调用者和被调用者时,若调用者和被调用者在同一编译器和同一时刻进行编译,在编译时编译器知道被调用子程序的信息,因此可以在编译时确定子程序所需的寄存器,在调用处只保存子程序中使用了的caller-saved寄存器即可,从而避免保存和恢复不必要的caller-saved寄存器,生成最优的代码。
但是显然这种方式无法适用于即时编译和静态编译混用的情况。在即时编译时,被调用子程序已经由其他静态编译器编译成机器码,无法进行相关的寄存器保存和恢复的优化。
现有技术中,在即时编译程序调用静态编译程序的前后,不得不对所有的caller-saved寄存器进行保存和恢复操作,有可能会产生一些不必要的保存和恢复,在caller-saved寄存器较多的体系结构中,有可能会产生较大的性能开销。
发明内容
本发明实施例所要解决的技术问题是提供一种寄存器处理方法、装置、电子设备及可读存储介质,以便解决即时编译和静态编译混用时无法对寄存器的保存与恢复进行优化的问题。
为了解决上述问题,本发明提供了一种寄存器处理方法,包括:
获取需即时编译的父程序调用的已静态编译的子程序;
检测所述子程序中使用目标寄存器的使用信息;
根据所述使用信息,对所述目标寄存器进行保存或恢复。
可选地,所述检测所述子程序中使用目标寄存器的使用信息包括:
检测在所述子程序中所有被更改的寄存器;
确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
可选地,所述根据所述使用信息,对所述目标寄存器进行保存或恢复包括:
根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令;
执行所述保存指令或恢复指令。
可选地,在所述检测所述子程序中使用目标寄存器的使用信息之前,所述方法还包括:
检测到所述子程序为首次运行。
可选地,所述方法还包括:
若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
相应的,本发明还提供了一种寄存器处理装置,包括:
子程序获取模块,用于获取需即时编译的父程序调用的已静态编译的子程序;
信息检测模块,用于检测所述子程序中使用目标寄存器的使用信息;
保存恢复模块,用于根据所述使用信息,对所述目标寄存器进行保存或恢复。
可选地,所述信息检测模块包括:
检测子模块,用于检测在所述子程序中所有被更改的寄存器;
信息确定子模块,用于确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
可选地,所述保存恢复模块包括:
指令生成子模块,用于根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令;
指令执行子模块,用于执行所述保存指令或恢复指令。
可选地,所述装置还包括:
首次检测模块,用于在所述检测所述子程序中使用目标寄存器的使用信息之前,检测到所述子程序为首次运行。
可选地,所述装置还包括:
读取模块,用于若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
相应的,本发明还提供了一种电子设备,包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于进行以下操作的指令:
获取需即时编译的父程序调用的已静态编译的子程序;
检测所述子程序中使用目标寄存器的使用信息;
根据所述使用信息,对所述目标寄存器进行保存或恢复。
可选地,所述检测所述子程序中使用目标寄存器的使用信息包括:
检测在所述子程序中所有被更改的寄存器;
确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
可选地,所述根据所述使用信息,对所述目标寄存器进行保存或恢复包括:
根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令;
执行所述保存指令或恢复指令。
可选地,在所述检测所述子程序中使用目标寄存器的使用信息之前,所述方法还包括:
检测到所述子程序为首次运行。
可选地,所述方法还包括:
若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
相应的,本发明还提供了一种可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行上述寄存器处理方法。
依据本发明实施例,通过获取需即时编译的父程序调用的已静态编译的子程序,检测所述子程序中使用目标寄存器的使用信息,根据所述使用信息,对所述目标寄存器进行保存或恢复,使得在即时编译的父程序调用静态编译的子程序的前后有针对性的保存或恢复寄存器,达到减少保存或恢复目标寄存器时的指令数量的效果,从而提高执行性能。
附图说明
图1示出了本发明实施例一的一种寄存器处理方法的步骤流程图;
图2示出了本发明实施例二的一种寄存器处理方法的步骤流程图;
图3示出了本发明实施例三的一种寄存器处理装置实施例的结构框图;
图4示出了根据一示例性实施例示出的一种用于寄存器处理的电子设备的结构框图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
参照图1,示出了本发明实施例一的一种寄存器处理方法的步骤流程图,具体可以包括如下步骤:
步骤101,获取需即时编译的父程序调用的已静态编译的子程序。
在本发明实施例中,程序需要经过编译过程才能执行,而编译过程可以分为静态编译过程和即时编译过程。例如,执行Java程序需要先将程序源代码文件编译成Java字节码文件,然后JRE(Java Runtime Environment,Java运行环境)加载Java字节码文件,载入系统分配给JVM(Java Virtual Machine,Java虚拟机)的内存区,然后执行引擎解释或编译类文件,再由即时编译器将字节码转化为本地机器码,而在程序运行前,还可以由静态编译器直接把部分程序源代码文件编译成本地机器码,这样做可以把编译的本地机器码保存磁盘,不占用内存,并可多次使用,而且不占用运行时间,做一些较耗时的优化,并可加快程序启动。
在本发明实施例中,在程序中会存在调用关系,将调用者记为父程序,将被调用者记为子程序。有的父程序是静态编译的,有的父程序是即时编译的;有的子程序是静态编译的,有的子程序是即时编译的。当子程序是静态编译的,但调用该子程序的父程序需要即时编译,此时由于父程序和子程序不是在同一编译器和同一时间进行编译的,即时编译器在编译父程序时就无法得到子程序的信息,为此本发明提出更改针对这类父程序的即时编译过程。
在本发明实施例中,即时编译器对需即时编译的父程序进行编译时,若该父程序调用了已静态编译的子程序,则获取该子程序,获取的已静态编译的子程序实际上是经静态编译生成的本地机器码。例如,JIT编译器编译的父程序中,调用了C语言库函数或由C语言编写的程序,在这种情况下,JIT编译器生成代码需要遵守目标函数的调用约定,即作为调用者,在调用前需要进行caller-saved寄存器的保存,获取该已经编译的子程序。
步骤102,检测所述子程序中使用目标寄存器的使用信息。
在本发明实施例中,子程序在执行过程中可能会修改目标寄存器的值,因此,需要在执行子程序之前保存目标寄存器的值,从而使子程序执行完毕后返回到父程序继续执行。
在本发明实施例中,获取已经编译的子程序后,对子程序进行检测,即时编译器可以确定该子程序使用目标寄存器的情况,得到使用信息。使用信息包括但不限于子程序执行会更改的目标寄存器的标识。检测所述子程序中使用目标寄存器的使用信息的实现方式可以包括:检测在所述子程序中所有被更改的寄存器,确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息,或者其他任意适用的实现方式,本发明实施例对此不做限制。例如,JIT编译器获取到已静态编译的子程序后,对子程序进行检测,得到子程序的caller-saved寄存器的使用信息。
步骤103,根据所述使用信息,对所述目标寄存器进行保存或恢复。
在本发明实施例中,在父程序调用该子程序之前,根据使用信息对目标寄存器进行保存,在父程序调用该子程序之后,根据使用信息对目标寄存器进行恢复。在即时编译过程中,根据使用信息,生成目标寄存器的编译后的保存指令或恢复指令。即时编译后得到的指令是本地机器码指令。然后进入执行阶段,在父程序调用该子程序之前,执行保存指令,在父程序调用该子程序之后,执行恢复指令。例如,JIT编译器根据使用信息,生成目标寄存器的保存指令或恢复指令,在执行阶段执行保存指令,对目标寄存器进行保存,执行恢复指令,对目标寄存器进行恢复。
依据本发明实施例,通过获取需即时编译的父程序调用的已静态编译的子程序,检测所述子程序中使用目标寄存器的使用信息,根据所述使用信息,对所述目标寄存器进行保存或恢复,使得在即时编译的父程序调用静态编译的子程序的前后有针对性的保存或恢复寄存器,达到减少保存或恢复目标寄存器时的指令数量的效果,从而提高执行性能。
参照图2,示出了本发明实施例二的一种寄存器处理方法的步骤流程图,具体可以包括如下步骤:
步骤201,获取需即时编译的父程序调用的已静态编译的子程序。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
步骤202,检测到所述子程序为首次运行。
在本发明实施例中,在检测所述子程序中使用目标寄存器的使用信息之前,可以先检测该子程序是否为首次运行,若为首次运行,则执行步骤204,若不为首次运行,则执行步骤203。
步骤203,若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
在本发明实施例中,若子程序非首次运行,由于首次运行时,即时编译器会将检测到的使用信息保存在内存中,因此之后再运行时,不必再通过检测子程序来得到使用信息,直接从内存中读取目标寄存器的使用信息即可。
步骤204,若所述子程序为首次运行,则检测在所述子程序中所有被更改的寄存器。
在本发明实施例中,提出一种已静态编译的子程序检测的机制,可以识别出子程序使用目标寄存器的情况。具体需要分为两个步骤,首先检测在子程序中所有被更改的寄存器。例如,由于在静态编译时,子程序的机器码已经确定。在JIT编译器生成的机器码调用该子程序时,通过新增的search函数遍历该子程序,可以得到该子程序中所有更改了的寄存器的标识,其中包括该子程序的caller-saved寄存器和callee-saved寄存器。
步骤205,确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
在本发明实施例中,确定了所有被更改的寄存器后,然后在所有被更改的寄存器中确定需由父程序保存的目标寄存器,得到使用信息。例如,JIT编译器可以根据寄存器的标识规范,将上一步检测到的所有寄存器中的caller-saved寄存器查找出来,最终得到search函数所要的寄存器列表(即使用信息)。
步骤206,根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令。
在本发明实施例中,得到使用信息后,即时编译器根据使用信息生成目标寄存器的编译后的保存指令或恢复指令,即时编译后得到的指令是本地机器码指令。例如,在MIPS(Microprocessor without Interlocked Pipedline Stages architecture,无内部互锁流水级的微处理器)平台下,JVM的JIT生成代码中,存在调用C语言编写的func函数的情况,在JIT编译器在生成调用func函数的代码时,通过扫描已经编译的func函数,检测到只有A1寄存器的值发生过变化,因此,JIT编译器在调用func函数前后只需生成寄存器A1的入栈指令和寄存器A1的出栈指令即可。
步骤207,执行所述保存指令或恢复指令。
在本发明实施例中,进入程序的执行阶段后,执行生成的保存指令对目标寄存器进行保存,执行生成的恢复指令对目标寄存器进行恢复。
依据本发明实施例,通过获取需即时编译的父程序调用的已静态编译的子程序,检测到所述子程序为首次运行,若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息,若子程序为首次运行,则检测在所述子程序中所有被更改的寄存器,确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息,根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令,执行所述保存指令或恢复指令,使得在即时编译的父程序调用静态编译的子程序的前后有针对性的保存或恢复寄存器,达到减少保存或恢复目标寄存器时的指令数量的效果,从而提高执行性能。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
参照图3,示出了本发明实施例三的一种寄存器处理装置实施例的结构框图,具体可以包括如下模块:
子程序获取模块301,用于获取需即时编译的父程序调用的已静态编译的子程序;
信息检测模块302,用于检测所述子程序中使用目标寄存器的使用信息;
保存恢复模块303,用于根据所述使用信息,对所述目标寄存器进行保存或恢复。
在本发明实施例中,可选地,所述信息检测模块包括:
检测子模块,用于检测在所述子程序中所有被更改的寄存器;
信息确定子模块,用于确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
在本发明实施例中,可选地,所述保存恢复模块包括:
指令生成子模块,用于根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令;
指令执行子模块,用于执行所述保存指令或恢复指令。
在本发明实施例中,可选地,所述装置还包括:
首次检测模块,用于在所述检测所述子程序中使用目标寄存器的使用信息之前,检测到所述子程序为首次运行。
在本发明实施例中,可选地,所述装置还包括:
读取模块,用于若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
依据本发明实施例,通过获取需即时编译的父程序调用的已静态编译的子程序,检测所述子程序中使用目标寄存器的使用信息,根据所述使用信息,对所述目标寄存器进行保存或恢复,使得在即时编译的父程序调用静态编译的子程序的前后有针对性的保存或恢复寄存器,达到减少保存或恢复目标寄存器时的指令数量的效果,从而提高执行性能。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
图4是根据一示例性实施例示出的一种用于寄存器处理的电子设备700的结构框图。例如,电子设备700可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图4,电子设备700可以包括以下一个或多个组件:处理组件702,存储器704,电源组件706,多媒体组件708,音频组件710,输入/输出(I/O)的接口712,传感器组件714,以及通信组件716。
处理组件702通常控制电子设备700的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理元件702可以包括一个或多个处理器720来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件702可以包括一个或多个模块,便于处理组件702和其他组件之间的交互。例如,处理部件702可以包括多媒体模块,以方便多媒体组件708和处理组件702之间的交互。
存储器704被配置为存储各种类型的数据以支持在设备700的操作。这些数据的示例包括用于在电子设备700上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器704可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电力组件704为电子设备700的各种组件提供电力。电力组件704可以包括电源管理系统,一个或多个电源,及其他与为电子设备700生成、管理和分配电力相关联的组件。
多媒体组件708包括在所述电子设备700和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件708包括一个前置摄像头和/或后置摄像头。当电子设备700处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件710被配置为输出和/或输入音频信号。例如,音频组件710包括一个麦克风(MIC),当电子设备700处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器704或经由通信组件716发送。在一些实施例中,音频组件710还包括一个扬声器,用于输出音频信号。
I/O接口712为处理组件702和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件714包括一个或多个传感器,用于为电子设备700提供各个方面的状态评估。例如,传感器组件714可以检测到设备700的打开/关闭状态,组件的相对定位,例如所述组件为电子设备700的显示器和小键盘,传感器组件714还可以检测电子设备700或电子设备700一个组件的位置改变,用户与电子设备700接触的存在或不存在,电子设备700方位或加速/减速和电子设备700的温度变化。传感器组件714可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件714还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件714还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件716被配置为便于电子设备700和其他设备之间有线或无线方式的通信。电子设备700可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信部件714经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信部件714还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备700可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器704,上述指令可由电子设备700的处理器720执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
一种非临时性计算机可读存储介质,当所述存储介质中的指令由终端的处理器执行时,使得终端能够执行一种寄存器处理方法,所述方法包括:
获取需即时编译的父程序调用的已静态编译的子程序;
检测所述子程序中使用目标寄存器的使用信息;
根据所述使用信息,对所述目标寄存器进行保存或恢复。
可选地,所述检测所述子程序中使用目标寄存器的使用信息包括:
检测在所述子程序中所有被更改的寄存器;
确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
可选地,所述根据所述使用信息,对所述目标寄存器进行保存或恢复包括:
根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令;
执行所述保存指令或恢复指令。
可选地,在所述检测所述子程序中使用目标寄存器的使用信息之前,所述方法还包括:
检测到所述子程序为首次运行。
可选地,所述方法还包括:
若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种寄存器处理方法、一种寄存器处理装置,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。

Claims (12)

1.一种寄存器处理方法,其特征在于,包括:
获取需即时编译的父程序调用的已静态编译的子程序;
检测所述子程序中使用目标寄存器的使用信息;
根据所述使用信息,对所述目标寄存器进行保存或恢复。
2.根据权利要求1所述的方法,其特征在于,所述检测所述子程序中使用目标寄存器的使用信息包括:
检测在所述子程序中所有被更改的寄存器;
确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
3.根据权利要求1所述的方法,其特征在于,所述根据所述使用信息,对所述目标寄存器进行保存或恢复包括:
根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令;
执行所述保存指令或恢复指令。
4.根据权利要求1所述的方法,其特征在于,在所述检测所述子程序中使用目标寄存器的使用信息之前,所述方法还包括:
检测到所述子程序为首次运行。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
6.一种寄存器处理装置,其特征在于,包括:
子程序获取模块,用于获取需即时编译的父程序调用的已静态编译的子程序;
信息检测模块,用于检测所述子程序中使用目标寄存器的使用信息;
保存恢复模块,用于根据所述使用信息,对所述目标寄存器进行保存或恢复。
7.根据权利要求6所述的装置,其特征在于,所述信息检测模块包括:
检测子模块,用于检测在所述子程序中所有被更改的寄存器;
信息确定子模块,用于确定所述寄存器中需由所述父程序保存的目标寄存器,得到所述使用信息。
8.根据权利要求6所述的装置,其特征在于,所述保存恢复模块包括:
指令生成子模块,用于根据所述使用信息,生成所述目标寄存器的保存指令或恢复指令;
指令执行子模块,用于执行所述保存指令或恢复指令。
9.根据权利要求6所述的装置,其特征在于,所述装置还包括:
首次检测模块,用于在所述检测所述子程序中使用目标寄存器的使用信息之前,检测到所述子程序为首次运行。
10.根据权利要求9所述的装置,其特征在于,所述装置还包括:
读取模块,用于若所述子程序非首次运行,则读取首次运行时保存在内存中的目标寄存器的使用信息。
11.一种电子设备,其特征在于,包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于进行以下操作的指令:
获取需即时编译的父程序调用的已静态编译的子程序;
检测所述子程序中使用目标寄存器的使用信息;
根据所述使用信息,对所述目标寄存器进行保存或恢复。
12.一种可读存储介质,其特征在于,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如方法权利要求1-5中一个或多个所述的寄存器处理方法。
CN201910797926.0A 2019-08-27 2019-08-27 一种寄存器处理方法、装置、电子设备及存储介质 Active CN112445484B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910797926.0A CN112445484B (zh) 2019-08-27 2019-08-27 一种寄存器处理方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910797926.0A CN112445484B (zh) 2019-08-27 2019-08-27 一种寄存器处理方法、装置、电子设备及存储介质

Publications (2)

Publication Number Publication Date
CN112445484A true CN112445484A (zh) 2021-03-05
CN112445484B CN112445484B (zh) 2023-11-24

Family

ID=74741673

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910797926.0A Active CN112445484B (zh) 2019-08-27 2019-08-27 一种寄存器处理方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN112445484B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114816532A (zh) * 2022-04-20 2022-07-29 湖南卡姆派乐信息科技有限公司 一种提高risc-v二进制代码密度的寄存器分配方法

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH02170235A (ja) * 1988-12-23 1990-07-02 Nec Corp サブルーチン呼び出し時のレジスタの退避/復旧方式
JPH0421028A (ja) * 1990-05-15 1992-01-24 Oki Electric Ind Co Ltd レジスタ管理方法
US6983459B1 (en) * 1999-04-06 2006-01-03 International Business Machines Corporation Incorporating register pressure into an inlining compiler
US20080141216A1 (en) * 2001-05-29 2008-06-12 International Business Machines Corporation Compiling method and storage medium therefor
JP2010122820A (ja) * 2008-11-18 2010-06-03 Hitachi Ltd コンパイル装置及びコンパイル方法
US20180196669A1 (en) * 2017-01-10 2018-07-12 International Business Machines Corporation Reduced save and restore instructions for call-clobbered registers
CN109426504A (zh) * 2017-08-29 2019-03-05 龙芯中科技术有限公司 程序的处理方法、装置、电子设备及存储介质
CN109725943A (zh) * 2018-12-27 2019-05-07 龙芯中科技术有限公司 一种程序跳转方法、装置、电子设备及存储介质

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH02170235A (ja) * 1988-12-23 1990-07-02 Nec Corp サブルーチン呼び出し時のレジスタの退避/復旧方式
JPH0421028A (ja) * 1990-05-15 1992-01-24 Oki Electric Ind Co Ltd レジスタ管理方法
US6983459B1 (en) * 1999-04-06 2006-01-03 International Business Machines Corporation Incorporating register pressure into an inlining compiler
US20080141216A1 (en) * 2001-05-29 2008-06-12 International Business Machines Corporation Compiling method and storage medium therefor
JP2010122820A (ja) * 2008-11-18 2010-06-03 Hitachi Ltd コンパイル装置及びコンパイル方法
US20180196669A1 (en) * 2017-01-10 2018-07-12 International Business Machines Corporation Reduced save and restore instructions for call-clobbered registers
CN109426504A (zh) * 2017-08-29 2019-03-05 龙芯中科技术有限公司 程序的处理方法、装置、电子设备及存储介质
CN109725943A (zh) * 2018-12-27 2019-05-07 龙芯中科技术有限公司 一种程序跳转方法、装置、电子设备及存储介质

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
吴笔迅: "基于ARM 的PLC 指令编译与并行运算数据配置的设计", 广西工学院硕士学位论文, vol. 2013, no. 4, pages 11 - 12 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114816532A (zh) * 2022-04-20 2022-07-29 湖南卡姆派乐信息科技有限公司 一种提高risc-v二进制代码密度的寄存器分配方法
CN114816532B (zh) * 2022-04-20 2023-04-04 湖南卡姆派乐信息科技有限公司 一种提高risc-v二进制代码密度的寄存器分配方法

Also Published As

Publication number Publication date
CN112445484B (zh) 2023-11-24

Similar Documents

Publication Publication Date Title
CN109032606B (zh) 原生应用程序的编译处理方法、装置及终端
JP6189000B2 (ja) アプリケーションのインストールパッケージの処理方法、装置、プログラム及び記録媒体
CN111736916A (zh) 基于Java语言的动态扩展方法、装置、电子设备及存储介质
CN105468410A (zh) 系统升级方法及装置
CN109426504B (zh) 程序的处理方法、装置、电子设备及存储介质
CN109725943B (zh) 一种程序跳转方法、装置、电子设备及存储介质
CN113377370A (zh) 一种文件处理方法、装置、电子设备及存储介质
CN109344051B (zh) 数据处理的方法、装置、电子设备及存储介质
CN111913756B (zh) 应用程序的优化方法、装置、系统、电子设备及存储介质
CN112445484B (zh) 一种寄存器处理方法、装置、电子设备及存储介质
CN112114814A (zh) 编译文件确定方法及装置、应用程序生成方法及装置
CN106293683B (zh) 一种项目的编译方法及装置
CN110874259A (zh) 程序执行方法、装置、设备和存储介质
CN112631695B (zh) 一种数据校验方法、装置、电子设备及存储介质
CN112445483B (zh) 一种指令生成方法、装置、电子设备及存储介质
CN109918132B (zh) 一种指令安装方法、装置、电子设备及存储介质
CN110569037B (zh) 数据写入的方法和装置
CN107193622B (zh) 代码编译的处理方法、装置及终端
CN111596949B (zh) 一种开发应用程序的方法及装置
CN114020694B (zh) 一种头文件地址的获取方法、装置、电子设备及存储介质
CN112083981A (zh) 一种页面视图组件的创建方法和装置
CN110659081B (zh) 用于程序对象的文件处理方法、装置及电子设备
CN111273910B (zh) 获取资源号码标识符的方法、装置及存储介质
CN116954713A (zh) 组件生成方法、装置、电子设备和存储介质
CN114528200A (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