CN110569037B - 数据写入的方法和装置 - Google Patents

数据写入的方法和装置 Download PDF

Info

Publication number
CN110569037B
CN110569037B CN201910842078.0A CN201910842078A CN110569037B CN 110569037 B CN110569037 B CN 110569037B CN 201910842078 A CN201910842078 A CN 201910842078A CN 110569037 B CN110569037 B CN 110569037B
Authority
CN
China
Prior art keywords
kernel data
border
data
border crossing
recompiled
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
CN201910842078.0A
Other languages
English (en)
Other versions
CN110569037A (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.)
Beijing Xiaomi Mobile Software Co Ltd
Original Assignee
Beijing Xiaomi Mobile Software Co 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 Beijing Xiaomi Mobile Software Co Ltd filed Critical Beijing Xiaomi Mobile Software Co Ltd
Priority to CN201910842078.0A priority Critical patent/CN110569037B/zh
Publication of CN110569037A publication Critical patent/CN110569037A/zh
Application granted granted Critical
Publication of CN110569037B publication Critical patent/CN110569037B/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
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • G06F8/43Checking; Contextual analysis

Landscapes

  • Engineering & Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Stored Programmes (AREA)

Abstract

本公开是关于一种数据写入的方法和装置。涉及软件开发领域,解决了非必要的频繁越界检查带来的资源消耗和效率负担的问题。该方法包括:获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;根据所述越界检查信息获取目标内核数据;根据所述目标内核数据,执行文件写入操作。本公开提供的技术方案适用于内存写入操作,实现了高效实用的数据写入控制。

Description

数据写入的方法和装置
技术领域
本公开涉及软件开发领域,尤其涉及一种数据写入的方法和装置。
背景技术
OpenCL是一个为异构平台编写程序的框架,异构平台包括:CPU、GPU、DSP等,目前已经在移动端GPU平台上得到广泛支持。其中,针对图像操作的图像(Image)数据结构没有针对写数据的越界自检,而编写神经网络算子的过程较为复杂,容易发生内存写越界错误,难以排查。
由于Image对象可以获取各个维度(dimension)的大小(size),可以给OpenCL内核(kernel)传入一个越界标记(flag)参数。每次写Image的时候,首先检查flag的值。如果flag设置为true,则在向Image对象写数据的时候,检查一下要写的坐标是否超出了Image对象的边界,越界就返回错误码。如果flag设置为false,则表明代码已经发布,可以直接向Image对象写数据而不做判断。
由于OpenCL本身是一个异构平台加速框架,往往会在追求更高性能的场景中使用。如果已发布的产品运行时仍然要传入flag参数,不仅占用了本就紧张的内存资源,并且每个线程的每次运行都需要判断flag是否为true,还会一定程度上增加指令执行过程的跳转,占用了部分计算资源。
发明内容
为克服相关技术中存在的问题,本公开提供一种数据写入的方法和装置。
根据本公开实施例的第一方面,提供一种数据写入的方法,包括:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
根据所述目标内核数据,执行文件写入操作。
进一步的,所述获取写入操作的越界检查信息,包括:
通过执行写入操作的程序包中内核程序,获取越界检查编译选项,所述越界检查编译选项的值指示是否进行越界检查;
根据所述越界检查编译选项获取所述越界检查信息。
进一步的,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据;
在所述越界检查信息指示进行越界检查的情况下,所述根据所述越界检查信息获取目标内核数据,包括:
若存在所述重新编译后的内核数据,则获取所述重新编译后的内核数据;
若不存在所述重新编译后的内核数据,则重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据指示进行越界检查。
进一步的,所述重新编译所述原始内核数据,得到所述重新编译后的内核数据,包括:
从写入操作的程序包中获取边界标记flag参数和所述原始内核数据,所述程序包包括:所述原始内核数据和内核程序,所述内核程序包括所述flag参数;
重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据包括所述flag参数。
进一步的,所述根据所述目标内核数据,执行文件写入操作,包括:
通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的;
在所述flag参数为真值true的情况下,对所述写入操作进行越界检查;
在所述flag参数为假值false的情况下,执行所述写入操作。
根据本公开实施例的第二方面,提供一种数据写入的的装置,包括:
功能启动判断模块,用于获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
内核数据获取模块,用于根据所述越界检查信息选择内核数据;
写入模块,用于根据所述目标内核数据,执行文件写入操作。
进一步的,所述功能启动判断模块包括:
编译选项获取子模块,用于通过执行写入操作的程序包中内核程序,获取越界检查编译选项,所述越界检查编译选项的值指示是否进行越界检查;
越界检测信息获取子模块,用于根据所述越界检查编译选项获取所述越界检查信息。
进一步的,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据;
所述内核数据获取模块包括:
直接获取子模块,用于在存在所述重新编译后的内核数据的情况下,获取所述重新编译后的内核数据;
重编译子模块,用于在不存在所述重新编译后的内核数据的情况下,重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据指示进行越界检查。
进一步的,所述重编译子模块,具体用于从写入操作的程序包中获取边界标记flag参数和所述原始内核数据,所述程序包包括:所述原始内核数据和内核程序,所述内核程序包括所述flag参数,重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据包括所述flag参数。
进一步的,所述写入模块包括:
参数读取子模块,用于通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的;
第一写入子模块,用于在所述flag参数为真值true的情况下,对文件写入操作进行越界检查;
第二写入子模块,用于在所述flag参数为假值false的情况下,直接进行文件写入。
根据本公开实施例的第三方面,提供一种计算机装置,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
根据所述目标内核数据,执行文件写入操作。
根据本公开实施例的第四方面,提供一种非临时性计算机可读存储介质,当所述存储介质中的指令由移动终端的处理器执行时,使得移动终端能够执行一种数据写入的方法,所述方法包括:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
根据所述目标内核数据,执行文件写入操作。
本公开的实施例提供的技术方案可以包括以下有益效果:在执行写入操作的程序包时,首先获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查,然后根据所述越界检查信息获取目标内核数据,再根据所述目标内核数据,执行文件写入操作。对需要和不需要进行越界检查的两种场景通过不同的内核数据分别处理,避免了非必要的频繁越界检查带来的资源消耗和效率负担,实现了高效实用的数据写入控制。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
图1是根据一示例性实施例示出的一种数据写入的方法的流程图。
图2是根据一示例性实施例示出的一种数据写入的方法的流程图。
图3是根据一示例性实施例示出的一种重新编译内核数据的流程图。
图4是根据一示例性实施例示出的一种数据写入的装置的框图。
图5是图4中功能启动判断模块401的一种示例性结构框图。
图6是图4中内核数据获取模块402的一种示例性结构框图。
图7是图4中写入模块403的一种示例性结构框图。
图8是根据一示例性实施例示出的一种装置的框图(移动终端的一般结构)。
图9是根据一示例性实施例示出的一种装置的框图(服务器的一般结构)。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
由于OpenCL本身是一个异构平台加速框架,往往会在追求更高性能的场景中使用。如果已发布的产品运行时仍然要传入flag参数,不仅占用了本就紧张的内存资源,并且每个线程的每次运行都需要判断flag是否为true,还会一定程度上增加指令执行过程的跳转,占用了部分计算资源。
综上,在每次写入时都进行flag参数的传参和越界判断消耗了大量系统资源,降低了系统运行效率。
为了解决上述问题,本公开的实施例提供了一种数据写入的方法和装置。在进行数据写入时,首先判断是否需要进行写入越界检查,并在需要进行写入越界检查的情况下,重新编译内核数据,启用flag参数,然后执行重新编译后的所述内核数据,根据所述flag参数完成文件写入。对需要和不需要进行越界检查的两种场景分别处理,避免了非必要的频繁越界检查带来的资源消耗和效率负担,实现了高效实用的数据写入控制。
本公开的一示例性实施例提供了一种数据写入方法,具体流程如图1所示,包括:
步骤101、获取写入操作的越界检查信息。
本步骤中,获取越界检查信息,所述越界检查信息指示是否进行越界检查。
步骤102、根据所述越界检查信息获取目标内核数据。
本步骤中,根据越界检查信息指示是否进行越界检查,进而选择是否具有越界检查功能的内核数据作为目标内核数据。
步骤103、根据所述目标内核数据,执行文件写入操作。
本步骤中,在目标内核数据具有越界检查功能的情况下,在执行文件写入操作时,进行越界检查;在目标内核数据不具有越界检查功能的情况下,在执行文件写入操作时,直接写入,不进行越界检查。
本实施例提供的数据写入方法,根据越界检查信息选择启动或关闭越界检查功能,并不是机械的在进行写入操作时必进行固定的越界检查,避免了非必要频繁越界检查带来的资源消耗和效率负担。
本公开的一示例性实施例还提供了一种数据写入的方法,具体如图2所示,包括:
步骤201、执行写入操作的程序包。
本公开的实施例中,在发布产品时,在写入操作的程序包中封装原始内核数据和内核程序。所述内核程序内添加有flag参数,所述flag参数指示了越界检查执行方式。而在原始内核数据中是不包含越界检查部分的代码内容的。这样,在程序运行时,由于原始内核数据中不包含越界检查部分的内容,因此在应用原始内核数据时,就不需要在每次写入时进行越界检查,提高了写入效率。
以OpenCL平台为例,内核数据(kernel)的代码是在平台上运行的过程中编译的,编译过程传入的编译选项可以在主程序的C++运行代码中决定。可在基于C++的内核程序中添加flag参数。进一步的,还可保存map数据作为内核数据的记述文件,以kernel的名称与编译选项作为键(key)标识该map数据,map数据的值(value)是kernel经OpenCL平台编译之后的二进制文件,map数据指示了所有的可执行上下文、数据运行地址以及加载地址等信息。
进一步的,在程序包中还封装有写入检查接口,如写入图像数据(write_image)的接口,在后续启动越界检查功能时,即可调用该接口完成写越界检查。
本步骤中,执行内核程序,以调用内核数据进行写入等操作。
步骤202、获取写入操作的越界检查信息。
本步骤中,所述越界检查信息指示是否进行越界检查。
进一步的,通过宏定义一个越界检查编译选项,以该越界检查编译选项或该越界检查编译选项的内容作为越界检查信息。越界检查编译选项为一环境变量,可以是常驻于内核程序中的环境变量。通过执行写入操作的程序包中内核程序,获取越界检查编译选项;然后根据所述越界检查编译选项获取所述越界检查信息。
例如,在需要开启写入越界检查功能时,传入越界检查编译选项,然后系统根据所述越界检查编译选项的内容判断是否需要进行写入越界检查。
本步骤可依越界检查功能的开启指令而启动,该开启指令可由系统自动检测运行环境后发出,也可由人工操作发出。所述开启指令可传入所述越界检查编译选项的具体值,也可不包含针对具体值的内容。在获取到不包含明确说明是否进行越界检查具体内容的越界编译选项时,认为该越界检查信息指示不进行越界检查。
仍以OpenCL平台为例。产品发布的时候,默认关闭检查的功能,即只在C++代码里做一次是否做边界检查的判断,OpenCL kernel的写数据过程不会包含任何与边界检查相关的代码。当怀疑出现写越界的情况时,OpenCL平台进行是否启动越界检查功能的判断,具体的,判断在OpenCL的kernel编译阶段是否传入一个OUT_OF_RANGE_CHECK的宏定义的编译选项(OUT_OF_RANGE_CHECK可作为一种越界检查信息),根据宏OUT_OF_RANGE_CHECK来决定是否调用数据写入时的越界检查。具体的,在OUT_OF_RANGE_CHECK
步骤203、根据所述越界检查信息获取目标内核数据。
本步骤,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据。
对于所述越界检查信息指示进行越界检查的情况,若存在所述重新编译后的内核数据,则获取所述重新编译后的内核数据;
若不存在所述重新编译后的内核数据,则重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据指示进行越界检查。
重新编译原始内核数据以得到重新编译后的内核数据的流程具体如图3所示,包括:
步骤301、从写入操作的程序包中获取边界标记flag参数和所述原始内核数据,所述程序包包括:所述原始内核数据和内核程序,所述内核程序包括所述flag参数;
步骤302、重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据包括所述flag参数。
由图3所示流程可以看出,在首次接收到指示进行越界检查的越界检查信息或本地没有保存具有越界检查功能的重新编译后的内核数据时,需要对原始内核数据进行重编译生成所述重新编译后的内核数据。
进一步的,在生成所述重新编译后的内核数据后,可将其保存于写入操作的程序包中。这样,在后续再次需要启动越界检查功能时,即可直接应用该重新编译后的内核数据。进一步的,保护所述重新编译后的内核数据对应的map数据。
仍以OpenCL平台为例,在原先缓存的原始内核数据的map数据里查找不到作为越界检查信息的OUT_OF_RANGE_CHECK的宏编译选项对应的二进制代码,因此确定需要重新编译kernel的map数据的二进制码得到重新编译后的内核数据,加入flag参数,从而在后续执行包含第二内核数据的程序包的时候,具备写image的越界检查功能。
步骤204、根据所述目标内核数据,执行文件写入操作。
本步骤中,在需要执行写入操作时,通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的。在所述flag参数为true的情况下,对文件写入操作进行越界检查;在所述flag参数为false的情况下,直接进行文件写入。
在不需要执行写入操作时,执行包含原始内核数据的写入操作的程序包,进行直接的写入操作而不进行越界检查。
本公开的一示例性实施例还提供了一种数据写入装置,其结构如图4所示,包括:
功能启动判断模块401,用于获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
内核数据获取模块402,用于根据所述越界检查信息获取目标内核数据;
写入模块403,用于根据所述目标内核数据,执行文件写入操作。
进一步的,所述功能启动判断模块401的结构如图5所示,包括:
编译选项获取子模块4011,用于通过执行写入操作的程序包中内核程序,获取越界检查编译选项,所述越界检查编译选项的值指示是否进行越界检查;
越界检测信息获取子模块4012,用于根据所述越界检查编译选项获取所述越界检查信息。
进一步的,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据;
所述内核数据获取模块402的结构如图6所示,包括:
直接获取子模块4021,用于在存在所述重新编译后的内核数据的情况下,获取所述重新编译后的内核数据;
重编译子模块4022,用于在不存在所述重新编译后的内核数据的情况下,重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据指示进行越界检查。
进一步的,所述重编译子模块4022,具体用于从写入操作的程序包中获取边界标记flag参数和所述原始内核数据,所述程序包包括:所述原始内核数据和内核程序,所述内核程序包括所述flag参数,重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据包括所述flag参数。
进一步的,所述写入模块403的结构如图7所示,包括:
参数读取子模块4031,用于通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的;
第一写入子模块4032,用于在所述flag参数为真值true的情况下,对文件写入操作进行越界检查;
第二写入子模块4033,用于在所述flag参数为假值false的情况下,直接进行文件写入。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
本公开的一实施例还提供了一种计算机装置,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
根据所述目标内核数据,执行文件写入操作。
图8是根据一示例性实施例示出的一种用于数据写入的装置800的框图。例如,装置800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图8,装置800可以包括以下一个或多个组件:处理组件802,存储器804,电力组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制装置800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在装置800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电力组件806为装置800的各种组件提供电力。电力组件806可以包括电源管理系统,一个或多个电源,及其他与为装置800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述装置800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当装置800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为装置800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为装置800的显示器和小键盘,传感器组件814还可以检测装置800或装置800一个组件的位置改变,用户与装置800接触的存在或不存在,装置800方位或加速/减速和装置800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于装置800和其他设备之间有线或无线方式的通信。装置800可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由装置800的处理器820执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
一种非临时性计算机可读存储介质,当所述存储介质中的指令由移动终端的处理器执行时,使得移动终端能够执行一种数据写入方法,所述方法包括:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
根据所述目标内核数据,执行文件写入操作。
图9是根据一示例性实施例示出的一种用于数据写入的装置900的框图。例如,装置900可以被提供为一服务器。参照图9,装置900包括处理组件922,其进一步包括一个或多个处理器,以及由存储器932所代表的存储器资源,用于存储可由处理组件922的执行的指令,例如应用程序。存储器932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件922被配置为执行指令,以执行上述方法。
装置900还可以包括一个电源组件926被配置为执行装置900的电源管理,一个有线或无线网络接口950被配置为将装置900连接到网络,和一个输入输出(I/O)接口958。装置900可以操作基于存储在存储器932的操作系统,例如Windows ServerTM,Mac OSXTM,UnixTM,LinuxTM,FreeBSDTM或类似。
本公开的实施例提供了一种数据写入的方法和装置,在执行写入操作的程序包时,首先获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查,然后根据所述越界检查信息获取目标内核数据,再根据所述目标内核数据,执行文件写入操作。对需要和不需要进行越界检查的两种场景通过不同的内核数据分别处理,避免了非必要的频繁越界检查带来的资源消耗和效率负担,实现了高效实用的数据写入控制。
在发布时,可以在原始内核数据中彻底不包含越界检查部分的代码,不对计算过程的效率有任何影响。而在运行过程中发现需要进行越界检查时,即可启动越界检查功能;在不需要进行越界检查时,还可通过选择原始内核数据来关闭越界检查功能。针对是否使用越界检查功能,编译不同的内核数据代码,以达到不影响生产效率的目的。进一步的,通过封装如write_image的越界检查功能启动判断专用的写入检查接口,使代码风格统一化,避免无关代码出错。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本发明的其它实施方案。本申请旨在涵盖本发明的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本发明的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本发明的真正范围和精神由下面的权利要求指出。
应当理解的是,本发明并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本发明的范围仅由所附的权利要求来限制。

Claims (10)

1.一种数据写入的方法,其特征在于,包括:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
其中,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据;所述重新编译后的内核数据包括边界标记flag参数;
根据所述目标内核数据,执行文件写入操作;
所述根据所述目标内核数据,执行文件写入操作,包括:
通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的;
在所述flag参数为真值true的情况下,对所述写入操作进行越界检查;
在所述flag参数为假值false的情况下,执行所述写入操作。
2.根据权利要求1所述的方法,其特征在于,所述获取写入操作的越界检查信息,包括:
通过执行写入操作的程序包中内核程序,获取越界检查编译选项,所述越界检查编译选项的值指示是否进行越界检查;
根据所述越界检查编译选项获取所述越界检查信息。
3.根据权利要求1所述的方法,其特征在于,在所述越界检查信息指示进行越界检查的情况下,所述根据所述越界检查信息获取目标内核数据,包括:
若存在所述重新编译后的内核数据,则获取所述重新编译后的内核数据;
若不存在所述重新编译后的内核数据,则重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据指示进行越界检查。
4.根据权利要求3所述的方法,其特征在于,所述重新编译所述原始内核数据,得到所述重新编译后的内核数据,包括:
从写入操作的程序包中获取所述flag参数和所述原始内核数据,所述程序包包括:所述原始内核数据和内核程序,所述内核程序包括所述flag参数;
重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据包括所述flag参数。
5.一种数据写入的装置,其特征在于,包括:
功能启动判断模块,用于获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
内核数据获取模块,用于根据所述越界检查信息获取目标内核数据;
其中,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据;所述重新编译后的内核数据包括边界标记flag参数;
写入模块,用于根据所述目标内核数据,执行文件写入操作;
所述写入模块包括:
参数读取子模块,用于通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的;
第一写入子模块,用于在所述flag参数为真值true的情况下,对文件写入操作进行越界检查;
第二写入子模块,用于在所述flag参数为假值false的情况下,直接进行文件写入。
6.根据权利要求5所述的装置,其特征在于,所述功能启动判断模块包括:
编译选项获取子模块,用于通过执行写入操作的程序包中内核程序,获取越界检查编译选项,所述越界检查编译选项的值指示是否进行越界检查;
越界检测信息获取子模块,用于根据所述越界检查编译选项获取所述越界检查信息。
7.根据权利要求5所述的装置,其特征在于,所述内核数据获取模块包括:
直接获取子模块,用于在存在所述重新编译后的内核数据的情况下,获取所述重新编译后的内核数据;
重编译子模块,用于在不存在所述重新编译后的内核数据的情况下,重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据指示进行越界检查。
8.根据权利要求7所述的装置,其特征在于,
所述重编译子模块,具体用于从写入操作的程序包中获取所述flag参数和所述原始内核数据,所述程序包包括:所述原始内核数据和内核程序,所述内核程序包括所述flag参数,重新编译所述原始内核数据,得到所述重新编译后的内核数据,所述重新编译后的内核数据包括所述flag参数。
9.一种计算机装置,其特征在于,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
其中,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据;所述重新编译后的内核数据包括边界标记flag参数;
根据所述目标内核数据,执行文件写入操作;
所述根据所述目标内核数据,执行文件写入操作,包括:
通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的;
在所述flag参数为真值true的情况下,对所述写入操作进行越界检查;
在所述flag参数为假值false的情况下,执行所述写入操作。
10.一种非临时性计算机可读存储介质,当所述存储介质中的指令由移动终端的处理器执行时,使得移动终端能够执行一种数据写入的方法,所述方法包括:
获取写入操作的越界检查信息,所述越界检查信息指示是否进行越界检查;
根据所述越界检查信息获取目标内核数据;
其中,在所述越界检查信息指示进行越界检查的情况下,所述目标内核数据为原始内核数据经重新编译后的内核数据;在所述越界检查信息指示不进行越界检查的情况下,所述目标内核数据为所述原始内核数据;所述重新编译后的内核数据包括边界标记flag参数;
根据所述目标内核数据,执行文件写入操作;
所述根据所述目标内核数据,执行文件写入操作,包括:
通过运行可执行文件,读取所述flag参数,所述可执行文件是根据所述目标内核数据生成的;
在所述flag参数为真值true的情况下,对所述写入操作进行越界检查;在所述flag参数为假值false的情况下,执行所述写入操作。
CN201910842078.0A 2019-09-06 2019-09-06 数据写入的方法和装置 Active CN110569037B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910842078.0A CN110569037B (zh) 2019-09-06 2019-09-06 数据写入的方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910842078.0A CN110569037B (zh) 2019-09-06 2019-09-06 数据写入的方法和装置

Publications (2)

Publication Number Publication Date
CN110569037A CN110569037A (zh) 2019-12-13
CN110569037B true CN110569037B (zh) 2023-03-31

Family

ID=68778200

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910842078.0A Active CN110569037B (zh) 2019-09-06 2019-09-06 数据写入的方法和装置

Country Status (1)

Country Link
CN (1) CN110569037B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112114964A (zh) * 2020-08-17 2020-12-22 上海睿赛德电子科技有限公司 一种适用于嵌入式系统的应用安全访问内核方法

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101110042A (zh) * 2006-07-20 2008-01-23 中兴通讯股份有限公司 一种检测内存访问越界的方法
CN101145129A (zh) * 2007-07-18 2008-03-19 中兴通讯股份有限公司 一种嵌入式系统内存写越界的检测方法及系统
CN104461676A (zh) * 2014-10-27 2015-03-25 杭州中天微系统有限公司 二进制转译堆栈操作加速处理方法及其处理器
WO2016123908A1 (zh) * 2015-02-06 2016-08-11 中兴通讯股份有限公司 一种内存越界的检测方法及装置

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20160048376A1 (en) * 2014-08-12 2016-02-18 Advanced Micro Devices, Inc. Portable binary image format (pbif) for pre-compiled kernels
US10296313B2 (en) * 2014-11-18 2019-05-21 Roger James Poon Safely consuming dynamically-typed code from a statically-typed programming language

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101110042A (zh) * 2006-07-20 2008-01-23 中兴通讯股份有限公司 一种检测内存访问越界的方法
CN101145129A (zh) * 2007-07-18 2008-03-19 中兴通讯股份有限公司 一种嵌入式系统内存写越界的检测方法及系统
CN104461676A (zh) * 2014-10-27 2015-03-25 杭州中天微系统有限公司 二进制转译堆栈操作加速处理方法及其处理器
WO2016123908A1 (zh) * 2015-02-06 2016-08-11 中兴通讯股份有限公司 一种内存越界的检测方法及装置

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
ABCE:Java冗余数组越界检查消除;黄锃等;《小型微型计算机系统》;20101115(第11期);第28-34页 *
Encrypting video streams using OpenCL code on-demand;Juan P. D’Amato 等;《ResearchGate》;20140528;第1-13页 *
基于小差异分类的移动目标越界检测系统设计;何伟娜等;《计算机仿真》;20160315(第03期);第411-414页 *

Also Published As

Publication number Publication date
CN110569037A (zh) 2019-12-13

Similar Documents

Publication Publication Date Title
CN111221559B (zh) 应用更新方法、装置、存储介质、终端及服务器
CN111736916A (zh) 基于Java语言的动态扩展方法、装置、电子设备及存储介质
CN110781080A (zh) 程序调试方法及装置、存储介质
CN109344051B (zh) 数据处理的方法、装置、电子设备及存储介质
CN110569037B (zh) 数据写入的方法和装置
EP3118729A1 (en) Method and device for presenting tasks
CN113377370A (zh) 一种文件处理方法、装置、电子设备及存储介质
CN107402756B (zh) 用于绘制页面的方法、装置及终端
CN114510342A (zh) 缓存处理方法、装置及存储介质
CN110851370B (zh) 程序测试方法及装置、存储介质
CN113778687B (zh) 内存分配信息处理方法、装置、电子设备及存储介质
CN116257706A (zh) 应用加载方法、装置及存储介质
CN112631695A (zh) 一种数据校验方法、装置、电子设备及存储介质
CN110648272B (zh) 图形资源转换方法、装置、电子设备及存储介质
CN112083981A (zh) 一种页面视图组件的创建方法和装置
CN108563487B (zh) 用户界面的更新方法及装置
CN111459494A (zh) 一种代码处理方法及装置
CN111104110A (zh) 全局样式共享方法、全局样式共享装置及电子装置
CN112181406A (zh) 一种渲染引擎的共享方法和装置
CN112445484A (zh) 一种寄存器处理方法、装置、电子设备及存储介质
CN110659081B (zh) 用于程序对象的文件处理方法、装置及电子设备
CN111596949B (zh) 一种开发应用程序的方法及装置
CN114531493B (zh) 一种请求处理方法、装置、电子设备及存储介质
CN117555605B (zh) 操作系统启动方法、装置、电子设备及可读存储介质
CN113535183B (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