CN117130541A - 存储空间配置方法及相关设备 - Google Patents

存储空间配置方法及相关设备 Download PDF

Info

Publication number
CN117130541A
CN117130541A CN202310247836.0A CN202310247836A CN117130541A CN 117130541 A CN117130541 A CN 117130541A CN 202310247836 A CN202310247836 A CN 202310247836A CN 117130541 A CN117130541 A CN 117130541A
Authority
CN
China
Prior art keywords
partition
storage
determining
reserved
memory
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
CN202310247836.0A
Other languages
English (en)
Other versions
CN117130541B (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.)
Honor Device Co Ltd
Original Assignee
Honor Device 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 Honor Device Co Ltd filed Critical Honor Device Co Ltd
Priority to CN202310247836.0A priority Critical patent/CN117130541B/zh
Publication of CN117130541A publication Critical patent/CN117130541A/zh
Application granted granted Critical
Publication of CN117130541B publication Critical patent/CN117130541B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0629Configuration or reconfiguration of storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0608Saving storage space on storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/0644Management of space entities, e.g. partitions, extents, pools

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本申请提供一种存储空间配置方法及相关设备,所述方法包括:在电子设备开机进行文件***挂载时,获取电子设备的运行内存的第一存储容量;基于第一存储容量确定待分配给电子设备的存储设备预留分区的第二存储容量,并确定预留分区的地址范围;将存储设备中所述地址范围对应的存储空间分配给预留分区,预留分区用于存储完全内存数据。本申请可以适配不同存储容量的内存,避免造成存储空间的浪费,并且可以保障正常执行完全内存数据的转存,及时修复智能终端设备的故障。

Description

存储空间配置方法及相关设备
技术领域
本申请涉及智能终端技术领域,尤其涉及一种存储空间配置方法及相关设备。
背景技术
当智能终端设备如智能手机、个人电脑等发生故障时,为了分析故障原因和故障定位,会获取完全内存数据,并将完全内存数据转存至存储设备。为了保证完全内存数据可以成功转存至存储设备,存储设备通常需要预留用于存储完全内存数据的存储空间,由于转存方案需要适配不同存储容量的内存,预留存储空间的存储容量设置为内存的最大存储容量。然而,若内存的实际存储容量小于预留存储空间的存储容量,会浪费存储设备的存储空间,若新设计的内存的存储容量大于预留存储空间的存储容量,转存方案无法适配新设计的内存。如此,目前的完全内存数据转存方案无法动态适配不同存储容量的内存,容易造成存储空间的浪费,或无法正常执行完全内存数据的转存,导致智能终端设备的故障无法及时修复,影响用户的使用体验。
发明内容
鉴于以上内容,有必要提供一种存储空间配置方法及相关设备,解决完全内存数据转存方案无法动态适配不同存储容量的内存,容易造成存储空间的浪费,或无法正常执行完全内存数据的转存,导致智能终端设备的故障无法及时修复的问题。
第一方面,本申请提供一种存储空间配置方法,应用于电子设备,所述方法包括:在所述电子设备开机进行文件***挂载时,获取所述电子设备的运行内存的第一存储容量;基于所述第一存储容量确定待分配给所述电子设备的存储设备预留分区的第二存储容量,并确定所述预留分区的地址范围;将所述存储设备中所述地址范围对应的存储空间分配给所述预留分区,所述预留分区用于存储完全内存数据。
基于以上方案,可以基于电子设备的运行内存容量对存储设备中用于存储完全内存数据的分区进行动态预留,使得完全内存数据的转存方案可以适配不同的运行内存规格,避免造成存储空间的浪费,并且可以保障正常执行完全内存数据的转存,使得智能终端设备的故障可以及时得到修复,从而有效提升用户体验。
在一种可能的实现方式中,所述基于所述第一存储容量确定待分配给所述电子设备的存储设备的预留分区的第二存储容量包括:确定待分配给所述预留分区的所述第二存储容量与所述第一存储容量相同。
基于以上方案,通过将待分配给所述预留分区的所述第二存储容量确定为与所述第一存储容量相同,可以保障正常执行完全内存数据的转存,使得智能终端设备的故障可以及时得到修复。
在一种可能的实现方式中,所述基于所述第一存储容量确定待分配给所述电子设备的存储设备的预留分区的第二存储容量包括:确定待分配给所述预留分区的所述第二存储容量为所述第一存储容量与预设存储容量之和。
基于以上方案,通过将待分配给所述预留分区的所述第二存储容量确定为所述第一存储容量与预设存储容量之和,使得预留分区可以具有冗余空间,在存储完全内存数据之外,还可以存储电子设备的其他运行状态信息,从而提高电子设备的故障修复效率。
在一种可能的实现方式中,所述确定所述预留分区的地址范围包括:基于所述第二存储容量和所述存储设备的末尾地址确定所述预留分区在所述存储设备中的起始地址,确定所述地址范围为从所述预留分区的起始地址到所述存储设备的末尾地址。
基于以上方案,通过将预留分区设置在存储设备的末尾,可以有效地避免完全内存数据的转存影响到存储设备中原本存储的用户数据和***数据的读取。
在一种可能的实现方式中,所述将所述存储设备中所述地址范围对应的存储空间分配给所述预留分区包括:对所述存储设备中所述地址范围之外的数据分区执行挂载命令,将所述数据分区挂载至所述文件***;在所述存储设备的末尾预留所述第二存储容量的裸分区作为所述预留分区,以存储完全内存数据。
基于以上方案,通过在所述存储设备的末尾预留所述第二存储容量的裸分区作为所述预留分区,以存储完全内存数据,可以保障正常执行完全内存数据的转存,从而及时修改故障,同时,有效地避免完全内存数据的转存影响到存储设备中原本存储的用户数据和***数据的读取,保障用户使用体验。
在一种可能的实现方式中,所述方法还包括:在所述电子设备开机执行内核加载或初始化进程加载时,判断所述存储设备是否执行分区预留;若所述存储设备执行分区预留,在所述电子设备进行所述文件***挂载时,获取所述运行内存的所述第一存储容量。
基于以上方案,通过在存储设备执行分区预留时,才进行运行内存规格的获取和分区预留,使得本申请实施例的分区预留和完全内存数据转存方案可以适应用户需求。
在一种可能的实现方式中,所述存储设备包括原始转存数据分区,用于存储完全内存数据控制信息结构体,所述完全内存数据控制信息结构体包括所述运行内存的存储容量、所述预留分区的存储容量、所述预留分区在所述存储设备中的地址范围及预留标记。
基于以上方案,通过在原始转存数据分区中存储完全内存数据转存的控制信息,使得本申请实施例提供的完全内存数据转存方案可以适配不同***或品牌的电子设备。
在一种可能的实现方式中,所述判断所述存储设备是否执行分区预留包括:在所述电子设备开机执行内核加载或初始化进程加载时,从所述原始转存数据分区的所述完全内存数据控制信息结构体获取所述预留标记并确定预留标记的值;若所述预留标记为0,确定所述存储设备不执行分区预留;或若所述预留标记为1,确定所述存储设备执行分区预留。
基于以上方案,通过在原始转存数据分区的完全内存数据控制信息结构体中存储预留标记,可以快速、方便地确定电子设备是否执行分区预留。
在一种可能的实现方式中,所述判断所述存储设备是否执行分区预留还包括:在所述电子设备开机执行内核加载或初始化进程加载时,获取所述电子设备的***版本,若所述***版本为测试版本,确定所述存储设备执行分区预留;若所述分区预留执行成功,将所述预留标记更新为1;若所述分区预留执行失败,将所述预留标记更新为0;若所述***版本为商用版本,确定所述存储设备不执行分区预留。
基于以上方案,通过确定电子设备的***版本类型可以自动确定电子设备是否执行分区预留,并且保证分区预留的判断结果的准确性。
在一种可能的实现方式中,所述方法还包括:在所述电子设备开机执行引导加载阶段,判断完全转存功能是否开启;若所述完全转存功能已开启,在所述电子设备执行内核加载或初始化进程加载时,判断所述存储设备是否执行分区预留。
基于以上方案,通过在电子设备开机执行引导加载阶段判断完全转存功能开启时,判断是否进行分区预留,使得本申请实施例提供的完全内存数据转存方案可以可以基于预先设置的标记确定是否开启,使得完全内存数据转存功能符合用户需求。
在一种可能的实现方式中,所述完全内存数据控制信息结构体还包括使能标记,所述判断完全转存功能是否开启包括:在所述电子设备开机执行引导加载阶段,从所述原始转存数据分区的所述完全内存数据控制信息结构体获取使能标记并确定所述使能标记的值;若所述使能标记为0,确定所述完全转存功能未开启,并确定不执行分区预留,分区预留执行失败;或若所述使能标记为1,确定所述完全转存功能已开启,并执行分区预留。
基于以上方案,通过在原始转存数据分区的完全内存数据控制信息结构体中存储使能标记,可以快速、方便地确定电子设备的完全转存功能是否开启。
在一种可能的实现方式中,所述判断完全转存功能是否开启还包括:若所述使能标记为0,确定所述完全转存功能未开启,开启所述完全转存功能,并将使能标记更新为1。
基于以上方案,通过在完全转存功能未开启时,开启完全转存功能并更新使能标记,从而及时开启完全转存功能,进行完全内存数据的转存。
在一种可能的实现方式中,所述方法还包括:在所述电子设备产生故障时,获取完全内存数据,并将所述完全内存数据转存至所述预留分区。
基于以上方案,通过在电子设备产生故障时,将完全内存数据转存至预留分区,使得完全内存数据可以方便地进行回收,及时用于电子设备的故障分析。
在一种可能的实现方式中,所述获取完全内存数据,并将所述完全内存数据转存至所述预留分区包括:在所述电子设备产生故障时,加载运行故障处理***;通过故障处理***获取所述运行内存的状态信息,基于所述运行内容的状态信息生成日志,得到所述完全内存数据;从所述原始转存数据分区的所述完全内存数据控制信息结构体中获取所述预留分区在所述存储设备中的地址范围,并基于所述预留分区的地址范围进行寻址,将所述完全内存数据转存至所述预留分区。
基于以上方案,通过从完全内存数据控制信息结构体获取预留分区信息,可以提高完全内存数据的转存效率。
在一种可能的实现方式中,所述获取完全内存数据,并将所述完全内存数据转存至所述预留分区还包括:从所述原始转存数据分区中获取所述预留分区当前的地址范围,若所述第一存储容量小于或等于所述预留分区当前的地址范围对应的存储空间的存储容量,基于所述预留分区当前的地址范围进行寻址,将所述完全内存数据转存至所述预留分区。
基于以上方案,在确定第一存储容量小于或等于预留分区当前的地址范围对应的存储空间的存储容量时,进行完全内存数据转存,保证完全内存数据可以成功转存。
第二方面,本申请提供一种电子设备,所述电子设备包括存储器和处理器:其中,所述存储器,用于存储程序指令;所述处理器,用于读取并执行所述存储器中存储的所述程序指令,当所述程序指令被所述处理器执行时,使得所述电子设备执行上述的存储空间配置方法。
第三方面,本申请提供一种芯片,与电子设备中的存储器耦合,所述芯片用于控制所述电子设备执行上述的存储空间配置方法。
第四方面,本申请提供一种计算机存储介质,所述计算机存储介质存储有程序指令,当所述程序指令在电子设备上运行时,使得所述电子设备执行上述的存储空间配置方法。
另外,第二方面至第四方面所带来的技术效果可参见上述方法部分各设计的方法相关的描述,此处不再赘述。
附图说明
图1A是本申请一实施例提供的运行内存和存储设备的示意图。
图1B是本申请一实施例提供的运行内存和存储设备的另一示意图。
图2是本申请一实施例提供的电子设备的软件架构图。
图3是本申请一实施例提供的存储空间配置方法的流程图。
图4是本申请一实施例提供的存储空间配置方法的框架图。
图5是本申请另一实施例提供的存储空间配置方法的流程图。
图6是本申请另一实施例提供的存储空间配置方法的框架图。
图7是本申请另一实施例提供的存储空间配置方法的流程图。
图8是本申请另一实施例提供的存储空间配置方法的框架图。
图9是本申请另一实施例提供的存储空间配置方法的流程图。
图10是本申请另一实施例提供的存储空间配置方法的框架图。
图11是本申请另一实施例提供的存储空间配置方法的流程图。
图12是本申请一实施例提供的电子设备的硬件架构图。
具体实施方式
本申请实施例中所涉及的术语“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括一个或者更多个该特征。在本申请实施例的描述中,“示例性的”或者“例如”等词用于表示作例子、例证或说明。本申请实施例中被描述为“示例性的”或者“例如”的任何实施例或设计方案不应被解释为比其它实施例或设计方案更优选或更具优势。确切而言,使用“示例性的”或者“例如”等词旨在以具体方式呈现相关概念。
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请中的技术领域的技术人员通常理解的含义相同。本申请的说明书中所使用的术语只是为了描述具体的实施例的目的,不是旨在于限制本申请。应理解,本申请中除非另有说明,“/”表示或的意思。例如,A/B可以表示A或B。本申请中的“和/或”仅仅是一种描述关联对象的关联关系,表示可以存在三种关系。例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B三种情况。“至少一个”是指一个或者多个。“多个”是指两个或多于两个。例如,a、b或c中的至少一个,可以表示:a,b,c,a和b,a和c,b和c,a、b和c七种情况。
在不冲突的情况下,下述的实施例及实施例中的特征可以相互组合。
当智能终端设备如智能手机、个人电脑等发生整机故障时,为了分析故障原因和故障定位,会执行Dump(转存)流程,包括:加载故障处理***,获取和转存dump数据(即故障诊断数据),dump数据包括内存RAM数据,完全内存数据为Fulldump数据,Fulldump数据可以是Fulldump日志,包括完整的内存信息。在Dump流程中,存在两种数据保存通路,第一种不自动转存dump数据,需要其他电子设备如电脑端使用QPST(Qualcomm Product SupportTool,针对高通芯片开发的传输软件)工具保存Fulldump数据,如此,完全内存数据的转存存在前提条件,可能导致不能及时保存Fulldump数据;第二种会将Fulldump数据自动转存到物理存储设备的rawdump(原始转存数据)分区,从而导致物理存储设备可使用的存储空间减少,而且Fulldump数据无法便捷回收,无法满足测试设备的用户需求。此外,智能终端设备的整机稳定性问题分析强依赖于Fulldump日志,因此针对Fulldump日志无法便捷提取以及测试用户使用需求的痛点问题提出一种Fulldump转存方案。
Fulldump转存方案在物理存储设备的用户可用的data(数据)分区尾部预留固定大小的存储空间,用于存储Fulldump日志。Fulldump转存方案可以应用在DDR(Double DataRate,双倍数据率)器件内存容量规格不同的终端设备上。Fulldump转存方案为适配不同DDR器件内存容量规格的终端设备,满足当时终端设备的最大DDR器件内存容量规格,设计目的为向下兼容,预留的存储空间大小为终端设备的最大DDR器件内存容量。然而,这样设计的Fulldump转存方案存在以下问题:对于DDR器件内存容量规格小于预设最大容量规格的终端设备,会造成物理存储设备上大量的存储空间浪费,导致用户可用数据分区减少且方案本身未适用,浪费资源导致影响用户体验;Fulldump转存方案开始预设了可能的最大DDR器件内存容量规格,由于预设的内存容量规格是静态不可变的,如果新产品设计新的DDR器件内存容量规格超过预设的内存容量规格,将导致方案适配问题,造成Fulldump转存方案失效,导致智能终端设备的故障无法及时修复,影响用户的使用体验。
为减少Fulldump转存方案适配过程中重复的人力工作以及方案本身存在的兼容性问题和资源浪费问题,本申请实施例提供一种存储空间配置方法,既可以适配不同存储容量的内存,避免造成存储空间的浪费,并且可以保障正常执行完全内存数据的转存,及时修复智能终端设备的故障。存储空间配置方法的详细过程可参考下文各个实施例中的描述。
为了更好地理解本申请实施例提供的存储空间配置方法,下面结合图1A、图1B对本申请实施例提供的存储空间配置方法的应用场景进行描述。
参阅图1A所示,终端设备的存储设备为通用闪存(Universal Flash Storage,UFS),存储设备的存储容量为128G。若DDR器件的预设最大内存容量为12G,则存储设备用于存储Fulldump数据的预留存储空间的容量为12G。若DDR器件内存容量为4G,DDR器件内存容量小于预设最大内存容量和存储设备的预留存储空间的容量。在终端设备产生故障时,Fulldump数据容量为4G,Fulldump数据在转存至存储设备的预留存储空间后,预留存储空间仍然存在8G容量的空闲存储空间,由于空闲存储空间无法存储其他数据,从而会造成存储设备8G容量的存储空间浪费。
参阅图1B所示,终端设备的存储设备为通用闪存,存储设备的存储容量为128G。若DDR器件的预设最大内存容量为12G,则存储设备用于存储Fulldump数据的预留存储空间的容量为12G。若新产品设计的新的DDR器件内存容量为16G,新的DDR器件内存容量大于预设最大内存容量和存储设备的预留存储空间的容量。在终端设备产生故障时,Fulldump数据容量为16G,Fulldump数据容量超出了预留存储空间的容量,而无法转存至预留存储空间,导致终端设备的故障无法及时修复,影响用户的使用体验。
参阅图2所示,为本申请实施例提供的电子设备的软件架构图。分层架构将软件分成若干个层,每一层都有清晰的角色和分工。层与层之间通过软件接口通信。例如,将安卓***分为四层,从上至下分别为应用程序层101,框架层102,安卓运行时(Androidruntime)和***库103,硬件抽象层104,内核层105。
应用程序层可以包括一系列应用程序包。例如,应用程序包可以包括相机,图库,日历,通话,地图,导航,WLAN,蓝牙,音乐,视频,短信息,设备控制服务等应用程序。
框架层为应用程序层的应用程序提供应用编程接口(Application ProgrammingInterface,API)和编程框架。应用程序框架层包括一些预先定义的函数。例如,应用程序框架层可以包括窗口管理器,内容提供器,视图***,电话管理器,资源管理器,通知管理器等。
其中,窗口管理器用于管理窗口程序。窗口管理器可以获取显示屏大小,判断是否有状态栏,锁定屏幕,截取屏幕等。内容提供器用来存放和获取数据,并使这些数据可以被应用程序访问。所述数据可以包括视频,图像,音频,拨打和接听的电话,浏览历史和书签,电话簿等。视图***包括可视控件,例如显示文字的控件,显示图片的控件等。视图***可用于构建应用程序。显示界面可以由一个或多个视图组成的。例如,包括短信通知图标的显示界面,可以包括显示文字的视图以及显示图片的视图。电话管理器用于提供电子设备的通信功能。例如通话状态的管理(包括接通,挂断等)。资源管理器为应用程序提供各种资源,比如本地化字符串,图标,图片,布局文件,视频文件等。通知管理器使应用程序可以在状态栏中显示通知信息,可以用于传达告知类型的消息,可以短暂停留后自动消失,无需用户交互。比如通知管理器被用于告知下载完成,消息提醒等。通知管理器还可以是以图表或者滚动条文本形式出现在***顶部状态栏的通知,例如后台运行的应用程序的通知,还可以是以对话窗口形式出现在屏幕上的通知。例如在状态栏提示文本信息,发出提示音,电子设备振动,指示灯闪烁等。
Android Runtime包括核心库和虚拟机。Android runtime负责安卓***的调度和管理。核心库包含两部分:一部分是java语言需要调用的功能函数,另一部分是安卓的核心库。
应用程序层和框架层运行在虚拟机中。虚拟机将应用程序层和框架层的java文件执行为二进制文件。虚拟机用于执行对象生命周期的管理,堆栈管理,线程管理,安全和异常的管理,以及垃圾回收等功能。
***库可以包括多个功能模块。例如,表面管理器(surface manager),媒体库(Media Libraries),三维图形处理库(例如:OpenGL ES),2D图形引擎(例如SGL)等。
其中,表面管理器用于对显示子***进行管理,并且为多个应用程序提供了2D和3D图层的融合。媒体库支持多种常用的音频,视频格式回放和录制,以及静态图像文件等。媒体库可以支持多种音视频编码格式,例如:MPEG4,H.264,MP3,AAC,AMR,JPG,PNG等。三维图形处理库用于实现三维图形绘图,图像渲染,合成,和图层处理等。2D图形引擎是2D绘图的绘图引擎。
硬件抽象层运行于用户空间,对内核层驱动进行封装,向上层提供调用接口。
内核层是硬件和软件之间的层。内核层至少包含显示驱动,摄像头驱动,音频驱动,传感器驱动。
内核层是电子设备的操作***的核心,是基于硬件的第一层软件扩充,提供操作***最基本的功能,是操作***工作的基础,负责管理***的进程、内存、设备驱动程序、文件和网络***,决定了***的性能和稳定性。例如,内核可以决定一个应用程序对某部分硬件的操作时间。
内核层包括与硬件紧密相关的程序,例如中断处理程序、设备驱动程序等,还包括基本的、公共的、运行频率较高的模块,例如时钟管理模块、进程调度模块等,还包括关键性的数据结构。内核层可以设置于处理器中,或固化在内部存储器。
参阅图3所示,为本申请一实施例提供的存储空间配置方法的流程图。所述方法应用于电子设备中,所述存储空间配置方法包括:
S101,在电子设备开机进行文件***挂载时,获取电子设备的运行内存的第一存储容量。
参阅图4所示,在本申请的一实施例中,在电子设备首次开机流程的内核(kernel)加载阶段或Init(Initialization,初始化)进程加载阶段,将电子设备的存储设备挂载在文件***。在挂载存储设备之前,获取电子设备的运行内存的第一存储容量。在一实施例中,运行内存的第一存储容量可以是6G。在其他实施例中,第一存储容量也可以根据需求设置为其他数值。其中,运行内存为随机存取存储器(Random Access Memory,RAM),具体地,运行内存为双倍速率(Double Data Rate,DDR)器件,例如为DDR SDRAM(SynchronousDynamic Random Access Memory,同步动态随机存取存储器)。存储设备为只读存储器(Read-Only Memory,ROM),例如,存储设备为通用闪存、硬盘等。
在本申请的一实施例中,电子设备开机流程的内核加载阶段用于加载硬件设备驱动和初始化进程管理,Init进程加载阶段用于初始化电子设备的第一个进程、挂载文件***及执行init.rc配置文件。
S102,基于第一存储容量确定待分配给存储设备的预留分区的第二存储容量,并确定预留分区的地址范围。
在本申请的一实施例中,存储设备的预留分区用于存储故障诊断文件,故障诊断文件可以为完全内存数据(Fulldump数据),例如Fulldump日志。完全内存数据包括进程运行时的所有内存信息,内存信息包括运行内存的堆栈信息、寄存器信息等,因此,完全内存数据的容量与运行内存的第一存储容量相同。
在本申请的一实施例中,基于第一存储容量确定待分配给存储设备的预留分区的第二存储容量包括:确定待分配给存储设备的预留分区的第二存储容量与第一存储容量相同。此时,完全内存数据包括运行内存的所有寄存器数据。
在本申请的另一实施例中,基于第一存储容量确定待分配给存储设备的预留分区的第二存储容量包括:确定待分配给存储设备的预留分区的第二存储容量为第一存储容量与预设存储容量之和。此时,完全内存数据包括运行内存的所有寄存器数据和片上内存的数据,片上内存设置于处理器上。在本申请的一实施例中,预设存储容量为0.5G,在本申请的其他实施例中,预设存储容量也可以根据需求设置为其他数值。
在本申请的一实施例中,确定预留分区的地址范围包括:基于第二存储容量和存储设备的末尾地址确定预留分区在存储设备中的起始地址,确定预留分区的地址范围为从预留分区的起始地址到存储设备的末尾地址,预留分区的起始地址与存储设备的末尾地址之间的存储空间的容量为第二存储容量。
S103,将存储设备中地址范围对应的存储空间分配给预留分区。
在本申请的一实施例中,将存储设备中地址范围对应的存储空间分配给预留分区包括:对存储设备中该地址范围之外的数据分区执行挂载命令,以挂载至文件***,在存储设备的末尾预留第二存储容量的裸分区作为预留分区,以存储完全内存数据。
原有Fulldump转存方案在刷机后首次开机过程和恢复出厂设置过程对数据分区进行重新分配时,按给定静态分区空间大小进行分区预留,以上实施例为解决前述问题,存储空间配置方法,即动态预留方法增加运行内存的规格信息读取流程,根据读取的规格信息重新计算出实际应分配的预留分区空间大小数据,按照动态获取的空间大小数据进行分区预留,预留成功后除原有裸分区地址,分区大小等信息外,还会将当前电子设备的运行内存的规格信息(存储容量)保存到rawdump分区的Fulldump控制信息结构体中,并落盘到存储设备上。
参阅图5所示,为本申请另一实施例提供的存储空间配置方法的流程图。所述方法应用于电子设备中,所述存储空间配置方法包括:
S201,在电子设备开机执行内核加载或初始化进程加载时,判断电子设备的存储设备是否执行分区预留。
参阅图6所示,在本申请的一实施例中,存储设备包括原始转存数据(rawdump)分区,用于存储完全内存数据控制信息结构体,完全内存数据控制信息结构体为元数据结构体,用于存储元数据。完全内存数据控制信息结构体存储的元数据包括但不限于运行内存的存储容量、预留分区的存储容量、预留分区在存储设备中的地址范围及预留标记。其中,预留标记的值为0或1,若预留标记为0,表示存储设备不执行分区预留,若预留标记为1,表示存储设备执行分区预留。
在本申请的一实施例中,在电子设备首次开机执行内核加载或初始化进程加载时,判断电子设备的存储设备是否执行分区预留。判断是否执行分区预留包括:在电子设备开机执行内核加载或初始化进程加载时,从原始转存数据分区获取预留标记并确定预留标记的值,若预留标记为0,确定存储设备不执行分区预留,若预留标记为1,确定存储设备执行分区预留。
在本申请的另一实施例中,判断是否执行分区预留包括:在电子设备开机执行内核加载或初始化进程加载时,获取电子设备的***版本,若***版本为测试版本,确定执行分区预留,若分区预留执行成功,将预留标记更新为1,若分区预留执行失败,将预留标记更新为0,若***版本为商用版本,确定不执行分区预留。
S202,若存储设备执行分区预留,在电子设备进行文件***挂载时,获取电子设备的运行内存的第一存储容量。
S203,基于第一存储容量确定待分配给存储设备的预留分区的第二存储容量,并确定预留分区的地址范围。
S204,将存储设备中地址范围对应的存储空间分配给预留分区。
S202-S204的具体实施方式与S101-S103的具体实施方式相同,在此不作赘述。
参阅图7所示,为本申请另一实施例提供的存储空间配置方法的流程图。所述方法应用于电子设备中,所述存储空间配置方法包括:
S301,在电子设备开机执行引导加载阶段,判断电子设备的完全转存功能是否开启。
参阅图8所示,在本申请的一实施例中,完全内存数据控制信息结构体存储的元数据包括但不限于运行内存的存储容量、预留分区的存储容量、预留分区在存储设备中的地址范围、使能标记及预留标记。其中,使能标记的值为0或1,若使能标记为0,表示电子设备的完全转存功能未开启,若使能标记为1,表示电子设备的完全转存功能已开启。
在本申请的一实施例中,在电子设备首次开机执行引导加载阶段,判断完全转存功能是否开启。判断完全转存功能是否开启包括:在电子设备开机执行引导加载阶段,从原始转存数据分区获取使能标记并确定使能标记的值,若使能标记为0,确定电子设备的完全转存功能未开启,确定不执行分区预留,并确定分区预留执行失败,若使能标记为1,确定电子设备的完全转存功能已开启,确定执行分区预留。
在本申请的另一实施例中,判断完全转存功能是否开启包括:在电子设备开机执行引导加载阶段,从原始转存数据分区获取使能标记并确定使能标记的值,若使能标记为0,确定电子设备的完全转存功能未开启,开启完全转存功能,将使能标记更新为1,并执行分区预留;若使能标记为1,确定电子设备的完全转存功能已开启,确定执行分区预留。在本申请的所述另一实施例中,通过统一可编程固件接口的应用引导加载程序(UnifiedExtensible Firmware Interface-Application bootloader,UEFI-ABL)使能或禁用电子设备的完全转存功能,并更新使能标记。
在本申请的一实施例中,在电子设备开机执行引导加载阶段,通过引导加载程序bootloader引导操作***启动,初始化硬件设备,创建存储设备的存储空间的映射,加载内核文件等。
S302,若电子设备的完全转存功能已开启,在电子设备执行内核加载或初始化进程加载时,判断电子设备的存储设备是否执行分区预留。
S303,若存储设备执行分区预留,在电子设备进行文件***挂载时,获取电子设备的运行内存的第一存储容量。
S304,基于第一存储容量确定待分配给存储设备的预留分区的第二存储容量,并确定预留分区的地址范围。
S305,将存储设备中地址范围对应的存储空间分配给预留分区。
S302-S305的具体实施方式与S201-S204的具体实施方式相同,在此不作赘述。
在以上实施例中,电子设备开机过程包括bootloader阶段和kernel阶段,通过bootloader引导阶段加载kernel镜像并执行,为保证Fulldump转存功能在不同平台间可以控制是否使能,在bootloader阶段增加方案使能控制逻辑,通过更新保存在存储设备上的使能标记,决定是否在当前平台开启Fulldump转存功能。
完成bootloader引导后,进入kernel阶段,在设备首次开机过程中,会进行文件***挂载,此时会对存储设备进行分区划分,供不同的文件***使用,Fulldump转存方案在数据分区(F2fs文件***)挂载时,将尾部固定大小空间预留出来,不进行文件***挂载,做为裸分区使用,同时将裸分区的地址,分区大小等信息保存到rawdump的完全内存数据控制信息结构体中。
参阅图9所示,为本申请另一实施例提供的存储空间配置方法的流程图。所述方法应用于电子设备中,所述存储空间配置方法包括:
S401,在电子设备开机执行引导加载阶段,判断完全转存功能是否开启。
S402,若电子设备的完全转存功能已开启,在电子设备执行内核加载或初始化进程加载时,判断电子设备的存储设备是否执行分区预留。
S403,若存储设备执行分区预留,在电子设备进行文件***挂载时,获取电子设备的运行内存的第一存储容量。
S404,基于第一存储容量确定待分配给存储设备的预留分区的第二存储容量,并确定预留分区的地址范围。
S405,将存储设备中地址范围对应的存储空间分配给预留分区。
S406,在电子设备产生故障时,获取完全内存数据,并将完全内存数据转存至预留分区。
参阅图10所示,在本申请的一实施例中,在电子设备产生故障时,获取完全内存数据包括:在电子设备产生内核无法处理的故障时,例如故障为蓝屏、死机、自动重启等,电子设备触发内核错误(kernel panic),加载运行故障处理***,获取整个运行内存的状态信息,基于整个运行内容的状态信息生成日志,得到完全内存数据。在本申请的一实施例中,运行内存的状态信息包括运行内存的堆栈、寄存器信息。
在本申请的一实施例中,将完全内存数据转存至预留分区包括:从原始转存数据分区的完全内存数据控制信息结构体中获取预留分区在存储设备中的地址范围,并基于该地址范围进行寻址,将完全内存数据转存至预留分区,然后重启电子设备。
在本申请的一实施例中,将完全内存数据转存至预留分区还包括:判断完全内存数据转存功能是否开启,若完全内存数据转存功能已开启,从原始转存数据分区的完全内存数据控制信息结构体中获取预留分区在存储设备中的地址范围,并基于预留分区的地址范围进行寻址,将完全内存数据转存至预留分区,然后重启电子设备。
在本申请的另一实施例中,在电子设备产生故障时,获取完全内存数据,并将完全内存数据转存至预留分区还包括:若完全内存数据转存功能已开启,从所述原始转存数据分区中获取预留分区当前的地址范围,判断第一存储容量是否小于或等于预留分区当前的地址范围对应的存储空间的存储容量,若第一存储容量小于或等于预留分区当前的地址范围对应的存储空间的存储容量,基于预留分区当前的地址范围进行寻址,将完全内存数据转存至预留分区,然后重启电子设备;若运行内存的第一存储容量大于预留分区当前的地址范围对应的存储空间的存储容量,放弃转存完全内存数据。
在本申请的所述另一实施例中,通过判断第一存储容量是否小于或等于预留分区当前的地址范围对应的存储空间的存储容量,可以判断预留分区在存储设备中的起始地址是否发生比特跳变而导致预留分区的存储容量小于运行内存的第一存储容量,若预留分区的存储容量小于运行内存的第一存储容量,表示预留分区无法存储完全内存数据,因此,放弃转存完全内存数据。
S401-S405的具体实施方式与S301-S305的具体实施方式相同,在此不作赘述。
在以上实施例中,当电子设备整机在运行状态下发生内核无法处理故障时,触发panic,进入故障处理***,进行日志抓取,保存故障发生时的完整内存状态。基于Fulldump转存功能,通过存储在rawdump分区的完全内存数据控制信息结构体上的标记状态信息,判断是否开启Fulldump日志转存,若判断结果为开启Fulldump日志转存,根据分区划分时存储的裸分区信息(预留分区的第二存储容量和地址范围)提取出来,将Fulldump日志按照提供的裸分区信息寻址并保存,完成转存后重启开机流程。
当设备发生整机故障后,进入Dump处理逻辑,读取保存在存储设备的rawdump分区上的元数据结构体,获取当前设备状态信息,将获取到的数据传入预处理模块,预处理模块判断当前设备是否具备转储能力,为保证数据转存不破坏其他文件***数据,根据运行内存信息和预留分区信息进行边界检查,边界检查通过后,根据预留分区信息进行Fulldump转存。
参阅图11所示,为本申请另一实施例提供的存储空间配置方法的流程图。所述方法应用于电子设备中,所述存储空间配置方法包括:
S501,执行ResizeF2fs命令,进入分区预留处理逻辑。
S502,执行IsNeedReserveDataForResize命令,执行Fulldump预留逻辑,判断是否需要分区预留。若需要分区预留,流程进入S503;若不需要分区预留,流程进入S508。
S503,执行GetDDRInfo命令,获取DDR器件信息。
S504,执行CalculateReserveDataSize命令,计算需要预留分区大小。
S505,执行IsFulldumpSupport命令,判断Fulldump转存方案是否开启。若Fulldump转存方案已开启,流程进入S506;若Fulldump转存方案未开启,流程进入S508。
S506,执行ProcessResizeDataReserve命令,执行裸分区预留。
S507,执行UpdateFulldumpMetadata命令,更新物理存储器件上结构体信息,即,将预留的裸分区的地址范围存储至物理存储器件的完全内存数据控制信息结构体中。
S508,取消裸分区预留。
本申请实施例还提供一种电子设备100,参阅图12所示,电子设备100可以是手机、平板电脑、桌面型计算机、膝上型计算机、手持计算机、笔记本电脑、超级移动个人计算机(Ultra-mobile Personal Computer,UMPC)、上网本,以及蜂窝电话、个人数字助理(Personal Digital Assistant,PDA)、增强现实(Augmented Reality,AR)设备、虚拟现实(Virtual Reality,VR)设备、人工智能(Artificial Intelligence,AI)设备、可穿戴式设备、车载设备、智能家居设备和/或智慧城市设备,本申请实施例对该电子设备100的具体类型不作特殊限制。
电子设备100可以包括处理器110,外部存储器接口120,内部存储器121,通用串行总线(Universal Serial Bus,USB)接口130,充电管理模块140,电源管理模块141,电池142,天线1,天线2,移动通信模块150,无线通信模块160,音频模块170,扬声器170A,受话器170B,麦克风170C,耳机接口170D,传感器模块180,按键190,马达191,指示器192,摄像头193,显示屏194,以及用户标识模块(Subscriber Identification Module,SIM)卡接口195等。其中传感器模块180可以包括压力传感器180A,陀螺仪传感器180B,气压传感器180C,磁传感器180D,加速度传感器180E,距离传感器180F,接近光传感器180G,指纹传感器180H,温度传感器180J,触摸传感器180K,环境光传感器180L,骨传导传感器180M等。
可以理解的是,本发明实施例示意的结构并不构成对电子设备100的具体限定。在本申请另一些实施例中,电子设备100可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实现。
处理器110可以包括一个或多个处理单元,例如:处理器110可以包括应用处理器(Application Processor,AP),调制解调处理器,图形处理器(Graphics ProcessingUnit,GPU),图像信号处理器(Image Signal Processor,ISP),控制器,视频编解码器,数字信号处理器(Digital Signal Processor,DSP),基带处理器,和/或神经网络处理器(Neural-network Processing Unit,NPU)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。
控制器可以根据指令操作码和时序信号,产生操作控制信号,完成取指令和执行指令的控制。
处理器110中还可以设置存储器,用于存储指令和数据。在一些实施例中,处理器110中的存储器为高速缓冲存储器。该存储器可以保存处理器110刚用过或循环使用的指令或数据。如果处理器110需要再次使用该指令或数据,可从所述存储器中直接调用。避免了重复存取,减少了处理器110的等待时间,因而提高了***的效率。
在一些实施例中,处理器110可以包括一个或多个接口。接口可以包括集成电路(Inter-integrated Circuit,I2C)接口,集成电路内置音频(Inter-integrated CircuitSound,I2S)接口,脉冲编码调制(Pulse Code Modulation,PCM)接口,通用异步收发传输器(universal asynchronous receiver/transmitter,UART)接口,移动产业处理器接口(Mobile Industry Processor Interface,MIPI),通用输入输出(General-PurposeInput/Output,GPIO)接口,用户标识模块(Subscriber Identity Module,SIM)接口,和/或通用串行总线(Universal Serial Bus,USB)接口等。
I2C接口是一种双向同步串行总线,包括一根串行数据线(Serial Data Line,SDA)和一根串行时钟线(Derail Clock Line,SCL)。在一些实施例中,处理器110可以包含多组I2C总线。处理器110可以通过不同的I2C总线接口分别耦合触摸传感器180K,充电器,闪光灯,摄像头193等。例如:处理器110可以通过I2C接口耦合触摸传感器180K,使处理器110与触摸传感器180K通过I2C总线接口通信,实现电子设备100的触摸功能。
I2S接口可以用于音频通信。在一些实施例中,处理器110可以包含多组I2S总线。处理器110可以通过I2S总线与音频模块170耦合,实现处理器110与音频模块170之间的通信。在一些实施例中,音频模块170可以通过I2S接口向无线通信模块160传递音频信号,实现通过蓝牙耳机接听电话的功能。
PCM接口也可以用于音频通信,将模拟信号抽样,量化和编码。在一些实施例中,音频模块170与无线通信模块160可以通过PCM总线接口耦合。在一些实施例中,音频模块170也可以通过PCM接口向无线通信模块160传递音频信号,实现通过蓝牙耳机接听电话的功能。所述I2S接口和所述PCM接口都可以用于音频通信。
UART接口是一种通用串行数据总线,用于异步通信。该总线可以为双向通信总线。它将要传输的数据在串行通信与并行通信之间转换。在一些实施例中,UART接口通常被用于连接处理器110与无线通信模块160。例如:处理器110通过UART接口与无线通信模块160中的蓝牙模块通信,实现蓝牙功能。在一些实施例中,音频模块170可以通过UART接口向无线通信模块160传递音频信号,实现通过蓝牙耳机播放音乐的功能。
MIPI接口可以被用于连接处理器110与显示屏194,摄像头193等***器件。MIPI接口包括摄像头串行接口(Camera Serial Interface,CSI),显示屏串行接口(DisplaySerial Interface,DSI)等。在一些实施例中,处理器110和摄像头193通过CSI接口通信,实现电子设备100的拍摄功能。处理器110和显示屏194通过DSI接口通信,实现电子设备100的显示功能。
GPIO接口可以通过软件配置。GPIO接口可以被配置为控制信号,也可被配置为数据信号。在一些实施例中,GPIO接口可以用于连接处理器110与摄像头193,显示屏194,无线通信模块160,音频模块170,传感器模块180等。GPIO接口还可以被配置为I2C接口,I2S接口,UART接口,MIPI接口等。
USB接口130是符合USB标准规范的接口,具体可以是Mini USB接口,Micro USB接口,USB Type C接口等。USB接口130可以用于连接充电器为电子设备100充电,也可以用于电子设备100与***设备之间传输数据。也可以用于连接耳机,通过耳机播放音频。该接口还可以用于连接其他电子设备100,例如AR设备等。
可以理解的是,本发明实施例示意的各模块间的接口连接关系,只是示意性说明,并不构成对电子设备100的结构限定。在本申请另一些实施例中,电子设备100也可以采用上述实施例中不同的接口连接方式,或多种接口连接方式的组合。
充电管理模块140用于从充电器接收充电输入。其中,充电器可以是无线充电器,也可以是有线充电器。在一些有线充电的实施例中,充电管理模块140可以通过USB接口130接收有线充电器的充电输入。在一些无线充电的实施例中,充电管理模块140可以通过电子设备100的无线充电线圈接收无线充电输入。充电管理模块140为电池142充电的同时,还可以通过电源管理模块141为电子设备100供电。
电源管理模块141用于连接电池142,充电管理模块140与处理器110。电源管理模块141接收电池142和/或充电管理模块140的输入,为处理器110,内部存储器121,显示屏194,摄像头193,和无线通信模块160等供电。电源管理模块141还可以用于监测电池容量,电池循环次数,电池健康状态(漏电,阻抗)等参数。在其他一些实施例中,电源管理模块141也可以设置于处理器110中。在另一些实施例中,电源管理模块141和充电管理模块140也可以设置于同一个器件中。
电子设备100的无线通信功能可以通过天线1,天线2,移动通信模块150,无线通信模块160,调制解调处理器以及基带处理器等实现。
天线1和天线2用于发射和接收电磁波信号。电子设备100中的每个天线可用于覆盖单个或多个通信频带。不同的天线还可以复用,以提高天线的利用率。例如:可以将天线1复用为无线局域网的分集天线。在另外一些实施例中,天线可以和调谐开关结合使用。
移动通信模块150可以提供应用在电子设备100上的包括2G/3G/4G/5G等无线通信的解决方案。移动通信模块150可以包括至少一个滤波器,开关,功率放大器,低噪声放大器(Low Noise Amplifier,LNA)等。移动通信模块150可以由天线1接收电磁波,并对接收的电磁波进行滤波,放大等处理,传送至调制解调处理器进行解调。移动通信模块150还可以对经调制解调处理器调制后的信号放大,经天线1转为电磁波辐射出去。在一些实施例中,移动通信模块150的至少部分功能模块可以被设置于处理器110中。在一些实施例中,移动通信模块150的至少部分功能模块可以与处理器110的至少部分模块被设置在同一个器件中。
调制解调处理器可以包括调制器和解调器。其中,调制器用于将待发送的低频基带信号调制成中高频信号。解调器用于将接收的电磁波信号解调为低频基带信号。随后解调器将解调得到的低频基带信号传送至基带处理器处理。低频基带信号经基带处理器处理后,被传递给应用处理器。应用处理器通过音频设备(不限于扬声器170A,受话器170B等)输出声音信号,或通过显示屏194显示图像或视频。在一些实施例中,调制解调处理器可以是独立的器件。在另一些实施例中,调制解调处理器可以独立于处理器110,与移动通信模块150或其他功能模块设置在同一个器件中。
无线通信模块160可以提供应用在电子设备100上的包括无线局域网(WirelessLocal Area Networks,WLAN)(如无线保真(Wireless Fidelity,Wi-Fi)网络),蓝牙(Bluetooth,BT),全球导航卫星***(Global Navigation Satellite System,GNSS),调频(Frequency Modulation,FM),近距离无线通信技术(Near Field Communication,NFC),红外技术(Infrared,IR)等无线通信的解决方案。无线通信模块160可以是集成至少一个通信处理模块的一个或多个器件。无线通信模块160经由天线2接收电磁波,将电磁波信号调频以及滤波处理,将处理后的信号发送到处理器110。无线通信模块160还可以从处理器110接收待发送的信号,对其进行调频,放大,经天线2转为电磁波辐射出去。
在一些实施例中,电子设备100的天线1和移动通信模块150耦合,天线2和无线通信模块160耦合,使得电子设备100可以通过无线通信技术与网络以及其他设备通信。所述无线通信技术可以包括全球移动通讯***(Global System For Mobile Communications,GSM),通用分组无线服务(General Packet Radio Service,GPRS),码分多址接入(CodeDivision Multiple Access,CDMA),宽带码分多址(Wideband Code Division MultipleAccess,WCDMA),时分码分多址(Time-Division Code Division Multiple Access,TD-SCDMA),长期演进(Long Term Evolution,LTE),BT,GNSS,WLAN,NFC,FM,和/或IR技术等。所述GNSS可以包括全球卫星定位***(Global Positioning System,GPS),全球导航卫星***(Global Navigation Satellite System,GLONASS),北斗卫星导航***(BeidouNavigation Satellite System,BDS),准天顶卫星***(Quasi-Zenith SatelliteSystem,QZSS)和/或星基增强***(Satellite Based Augmentation Systems,SBAS)。
电子设备100通过GPU,显示屏194,以及应用处理器等实现显示功能。GPU为图像处理的微处理器,连接显示屏194和应用处理器。GPU用于执行数学和几何计算,用于图形渲染。处理器110可包括一个或多个GPU,其执行程序指令以生成或改变显示信息。
显示屏194用于显示图像,视频等。显示屏194包括显示面板。显示面板可以采用液晶显示屏(Liquid Crystal Display,LCD),有机发光二极管(Organic Light-EmittingDiode,OLED),有源矩阵有机发光二极体或主动矩阵有机发光二极体(Active-MatrixOrganic Light Emitting Diode的,AMOLED),柔性发光二极管(Flex Light-EmittingDiode,FLED),Miniled,Microled,Micro-OLED,量子点发光二极管(Quantum Dot LightEmitting Diodes,QLED)等。在一些实施例中,电子设备100可以包括1个或N个显示屏194,N为大于1的正整数。
电子设备100可以通过ISP,摄像头193,视频编解码器,GPU,显示屏194以及应用处理器等实现拍摄功能。
ISP用于处理摄像头193反馈的数据。例如,拍照时,打开快门,光线通过镜头被传递到摄像头感光元件上,光信号转换为电信号,摄像头感光元件将所述电信号传递给ISP处理,转化为肉眼可见的图像。ISP还可以对图像的噪点,亮度,肤色进行算法优化。ISP还可以对拍摄场景的曝光,色温等参数优化。在一些实施例中,ISP可以设置在摄像头193中。
摄像头193用于捕获静态图像或视频。物体通过镜头生成光学图像投射到感光元件。感光元件可以是电荷耦合器件(Charge Coupled Device,CCD)或互补金属氧化物半导体(Complementary Metal-Oxide-Semiconductor,CMOS)光电晶体管。感光元件把光信号转换成电信号,之后将电信号传递给ISP转换成数字图像信号。ISP将数字图像信号输出到DSP加工处理。DSP将数字图像信号转换成标准的RGB,YUV等格式的图像信号。在一些实施例中,电子设备100可以包括1个或N个摄像头193,N为大于1的正整数。
数字信号处理器用于处理数字信号,除了可以处理数字图像信号,还可以处理其他数字信号。例如,当电子设备100在频点选择时,数字信号处理器用于对频点能量进行傅里叶变换等。
视频编解码器用于对数字视频压缩或解压缩。电子设备100可以支持一种或多种视频编解码器。这样,电子设备100可以播放或录制多种编码格式的视频,例如:动态图像专家组(Moving Picture Experts Group,MPEG)1,MPEG2,MPEG3,MPEG4等。
NPU为神经网络(Neural-Network,NN)计算处理器,通过借鉴生物神经网络结构,例如借鉴人脑神经元之间传递模式,对输入信息快速处理,还可以不断的自学习。通过NPU可以实现电子设备100的智能认知等应用,例如:图像识别,人脸识别,语音识别,文本理解等。
内部存储器121可以包括一个或多个随机存取存储器(Random Access Memory,RAM)和一个或多个非易失性存储器(Non-Volatile Memory,NVM)。
随机存取存储器可以包括静态随机存储器(Static Random-Access Memory,SRAM)、动态随机存储器(Dynamic Random Access Memory,DRAM)、同步动态随机存储器(Synchronous Dynamic Random Access Memory,SDRAM)、双倍资料率同步动态随机存取存储器(Double Data Rate Synchronous Dynamic Random Access Memory,DDR SDRAM,例如第五代DDR SDRAM一般称为DDR5 SDRAM)等;
非易失性存储器可以包括磁盘存储器件、快闪存储器(flash memory)。
快闪存储器按照运作原理划分可以包括NOR FLASH、NAND FLASH、3DNAND FLASH等,按照存储单元电位阶数划分可以包括单阶存储单元(Single-Level Cell,SLC)、多阶存储单元(Multi-Level Cell,MLC)、三阶储存单元(Triple-Level Cell,TLC)、四阶储存单元(Quad-Level Cell,QLC)等,按照存储规范划分可以包括通用闪存存储(Universal FlashStorage,UFS)、嵌入式多媒体存储卡(embedded Multi Media Card,eMMC)等。
随机存取存储器可以由处理器110直接进行读写,可以用于存储操作***或其他正在运行中的程序的可执行程序(例如机器指令),还可以用于存储用户及应用程序的数据等。
非易失性存储器也可以存储可执行程序和存储用户及应用程序的数据等,可以提前加载到随机存取存储器中,用于处理器110直接进行读写。
外部存储器接口120可以用于连接外部的非易失性存储器,实现扩展电子设备100的存储能力。外部的非易失性存储器通过外部存储器接口120与处理器110通信,实现数据存储功能。例如将音乐,视频等文件保存在外部的非易失性存储器中。
内部存储器121或外部存储器接口120用于存储一个或多个计算机程序。一个或多个计算机程序被配置为被该处理器110执行。该一个或多个计算机程序包括多个指令,多个指令被处理器110执行时,可实现上述实施例中在电子设备100上执行的屏幕显示检测方法,以实现电子设备100的屏幕显示检测功能。
电子设备100可以通过音频模块170,扬声器170A,受话器170B,麦克风170C,耳机接口170D,以及应用处理器等实现音频功能。例如音乐播放,录音等。
音频模块170用于将数字音频信息转换成模拟音频信号输出,也用于将模拟音频输入转换为数字音频信号。音频模块170还可以用于对音频信号编码和解码。在一些实施例中,音频模块170可以设置于处理器110中,或将音频模块170的部分功能模块设置于处理器110中。
扬声器170A,也称“喇叭”,用于将音频电信号转换为声音信号。电子设备100可以通过扬声器170A收听音乐,或收听免提通话。
受话器170B,也称“听筒”,用于将音频电信号转换成声音信号。当电子设备100接听电话或语音信息时,可以通过将受话器170B靠近人耳接听语音。
麦克风170C,也称“话筒”,“传声器”,用于将声音信号转换为电信号。当拨打电话或发送语音信息时,用户可以通过人嘴靠近麦克风170C发声,将声音信号输入到麦克风170C。电子设备100可以设置至少一个麦克风170C。在另一些实施例中,电子设备100可以设置两个麦克风170C,除了采集声音信号,还可以实现降噪功能。在另一些实施例中,电子设备100还可以设置三个,四个或更多麦克风170C,实现采集声音信号,降噪,还可以识别声音来源,实现定向录音功能等。
耳机接口170D用于连接有线耳机。耳机接口170D可以是USB接口130,也可以是3.5mm的开放移动电子设备100平台(Open Mobile Terminal Platform,OMTP)标准接口,美国蜂窝电信工业协会(Cellular Telecommunications Industry Association of theUSA,CTIA)标准接口。
按键190包括开机键,音量键等。按键190可以是机械按键。也可以是触摸式按键。电子设备100可以接收按键输入,产生与电子设备100的用户设置以及功能控制有关的键信号输入。
马达191可以产生振动提示。马达191可以用于来电振动提示,也可以用于触摸振动反馈。例如,作用于不同应用(例如拍照,音频播放等)的触摸操作,可以对应不同的振动反馈效果。作用于显示屏194不同区域的触摸操作,马达191也可对应不同的振动反馈效果。不同的应用场景(例如:时间提醒,接收信息,闹钟,游戏等)也可以对应不同的振动反馈效果。触摸振动反馈效果还可以支持自定义。
指示器192可以是指示灯,可以用于指示充电状态,电量变化,也可以用于指示消息,未接来电,通知等。
SIM卡接口195用于连接SIM卡。SIM卡可以通过***SIM卡接口195,或从SIM卡接口195拔出,实现和电子设备100的接触和分离。电子设备100可以支持1个或N个SIM卡接口,N为大于1的正整数。SIM卡接口195可以支持Nano SIM卡,Micro SIM卡,SIM卡等。同一个SIM卡接口195可以同时***多张卡。所述多张卡的类型可以相同,也可以不同。SIM卡接口195也可以兼容不同类型的SIM卡。SIM卡接口195也可以兼容外部存储卡。电子设备100通过SIM卡和网络交互,实现通话以及数据通信等功能。在一些实施例中,电子设备100采用eSIM,即:嵌入式SIM卡。eSIM卡可以嵌在电子设备100中,不能和电子设备100分离。本申请实施例还提供一种计算机存储介质,该计算机存储介质中存储有计算机指令,当该计算机指令在电子设备100上运行时,使得电子设备100执行上述相关方法步骤实现上述实施例中的存储空间配置方法。
本申请实施例还提供了一种计算机程序产品,当该计算机程序产品在计算机上运行时,使得计算机执行上述相关步骤,以实现上述实施例中的存储空间配置方法。
另外,本申请的实施例还提供一种装置,这个装置具体可以是芯片,组件或模块,该装置可包括相连的处理器和存储器;其中,存储器用于存储计算机执行指令,当装置运行时,处理器可执行存储器存储的计算机执行指令,以使芯片执行上述各方法实施例中的存储空间配置方法。
其中,本实施例提供的电子设备、计算机存储介质、计算机程序产品或芯片均用于执行上文所提供的对应的方法,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
通过以上的实施方式的描述,所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,该模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个装置,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
该作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是一个物理单元或多个物理单元,即可以位于一个地方,或者也可以分布到多个不同地方。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
该集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个可读取存储介质中。基于这样的理解,本申请实施例的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该软件产品存储在一个存储介质中,包括若干指令用以使得一个设备(可以是单片机,芯片等)或处理器(processor)执行本申请各个实施例方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
最后应说明的是,以上实施例仅用以说明本申请的技术方案而非限制,尽管参照较佳实施例对本申请进行了详细说明,本领域的普通技术人员应当理解,可以对本申请的技术方案进行修改或等同替换,而不脱离本申请技术方案的精神和范围。

Claims (18)

1.一种存储空间配置方法,应用于电子设备,其特征在于,所述方法包括:
在所述电子设备开机进行文件***挂载时,获取所述电子设备的运行内存的第一存储容量;
基于所述第一存储容量确定待分配给所述电子设备的存储设备中预留分区的第二存储容量,并确定所述预留分区的地址范围;
将所述存储设备中所述地址范围对应的存储空间分配给所述预留分区,所述预留分区用于存储完全内存数据。
2.如权利要求1所述的存储空间配置方法,其特征在于,所述基于所述第一存储容量确定待分配给所述电子设备的存储设备的预留分区的第二存储容量包括:
确定待分配给所述预留分区的所述第二存储容量与所述第一存储容量相同。
3.如权利要求1所述的存储空间配置方法,其特征在于,所述基于所述第一存储容量确定待分配给所述电子设备的存储设备的预留分区的第二存储容量包括:
确定待分配给所述预留分区的所述第二存储容量为所述第一存储容量与预设存储容量之和。
4.如权利要求1所述的存储空间配置方法,其特征在于,所述确定所述预留分区的地址范围包括:
基于所述第二存储容量和所述存储设备的末尾地址确定所述预留分区在所述存储设备中的起始地址,确定所述地址范围为从所述预留分区的起始地址到所述存储设备的末尾地址。
5.如权利要求2所述的存储空间配置方法,其特征在于,所述将所述存储设备中所述地址范围对应的存储空间分配给所述预留分区包括:
对所述存储设备中所述地址范围之外的数据分区执行挂载命令,将所述数据分区挂载至所述文件***;
在所述存储设备的末尾预留所述第二存储容量的裸分区作为所述预留分区,以存储完全内存数据。
6.如权利要求1所述的存储空间配置方法,其特征在于,所述方法还包括:
在所述电子设备开机执行内核加载或初始化进程加载时,判断所述存储设备是否执行分区预留;
若所述存储设备执行分区预留,在所述电子设备挂载所述文件***时,获取所述运行内存的所述第一存储容量。
7.如权利要求6所述的存储空间配置方法,其特征在于,所述存储设备包括原始转存数据分区,用于存储完全内存数据控制信息结构体,所述完全内存数据控制信息结构体包括所述运行内存的存储容量、所述预留分区的存储容量、所述预留分区在所述存储设备中的地址范围及预留标记。
8.如权利要求7所述的存储空间配置方法,其特征在于,所述判断所述存储设备是否执行分区预留包括:
在所述电子设备开机执行内核加载或初始化进程加载时,从所述原始转存数据分区的所述完全内存数据控制信息结构体获取所述预留标记并确定所述预留标记的值;
若所述预留标记为0,确定所述存储设备不执行分区预留;或
若所述预留标记为1,确定所述存储设备执行分区预留。
9.如权利要求7所述的存储空间配置方法,其特征在于,所述判断所述存储设备是否执行分区预留还包括:
在所述电子设备开机执行内核加载或初始化进程加载时,获取所述电子设备的***版本;
若所述***版本为测试版本,确定所述存储设备执行分区预留;
若所述分区预留执行成功,将所述预留标记更新为1;
若所述分区预留执行失败,将所述预留标记更新为0;
若所述***版本为商用版本,确定所述存储设备不执行分区预留。
10.如权利要求7所述的存储空间配置方法,其特征在于,所述方法还包括:
在所述电子设备开机执行引导加载阶段时,判断完全转存功能是否开启;
若所述完全转存功能已开启,在所述电子设备执行内核加载或初始化进程加载时,判断所述存储设备是否执行分区预留。
11.如权利要求10所述的存储空间配置方法,其特征在于,所述完全内存数据控制信息结构体还包括使能标记,所述判断完全转存功能是否开启包括:
在所述电子设备开机执行引导加载阶段时,从所述原始转存数据分区的所述完全内存数据控制信息结构体获取所述使能标记并确定所述使能标记的值;
若所述使能标记为0,确定所述完全转存功能未开启,确定不执行分区预留,并确定分区预留执行失败;或
若所述使能标记为1,确定所述完全转存功能已开启,并确定执行分区预留。
12.如权利要求11所述的存储空间配置方法,其特征在于,所述判断完全转存功能是否开启还包括:
若所述使能标记为0,确定所述完全转存功能未开启,开启所述完全转存功能,并将使能标记更新为1。
13.如权利要求7所述的存储空间配置方法,其特征在于,所述方法还包括:
在所述电子设备产生故障时,获取完全内存数据,并将所述完全内存数据转存至所述预留分区。
14.如权利要求13所述的存储空间配置方法,其特征在于,所述获取完全内存数据,并将所述完全内存数据转存至所述预留分区包括:
在所述电子设备产生故障时,加载运行故障处理***;
通过故障处理***获取所述运行内存的状态信息,基于所述运行内容的状态信息生成日志,得到所述完全内存数据;
从所述原始转存数据分区的所述完全内存数据控制信息结构体中获取所述预留分区在所述存储设备中的地址范围,并基于所述地址范围进行寻址,将所述完全内存数据转存至所述预留分区。
15.如权利要求13所述的存储空间配置方法,其特征在于,所述获取完全内存数据,并将所述完全内存数据转存至所述预留分区还包括:
从所述原始转存数据分区中获取所述预留分区当前的地址范围;
若所述第一存储容量小于或等于所述预留分区当前的地址范围对应的存储空间的存储容量,基于所述预留分区当前的地址范围进行寻址,将所述完全内存数据转存至所述预留分区。
16.一种电子设备,其特征在于,所述电子设备包括存储器和处理器:
其中,所述存储器,用于存储程序指令;
所述处理器,用于读取并执行所述存储器中存储的所述程序指令,当所述程序指令被所述处理器执行时,使得所述电子设备执行如权利要求1至15中任一项所述的存储空间配置方法。
17.一种芯片,与电子设备中的存储器耦合,其特征在于,所述芯片用于控制所述电子设备执行权利要求1至15中任一项所述的存储空间配置方法。
18.一种计算机存储介质,其特征在于,所述计算机存储介质存储有程序指令,当所述程序指令在电子设备上运行时,使得所述电子设备执行如权利要求1至15中任一项所述的存储空间配置方法。
CN202310247836.0A 2023-03-02 2023-03-02 存储空间配置方法及相关设备 Active CN117130541B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310247836.0A CN117130541B (zh) 2023-03-02 2023-03-02 存储空间配置方法及相关设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310247836.0A CN117130541B (zh) 2023-03-02 2023-03-02 存储空间配置方法及相关设备

Publications (2)

Publication Number Publication Date
CN117130541A true CN117130541A (zh) 2023-11-28
CN117130541B CN117130541B (zh) 2024-06-04

Family

ID=88853367

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310247836.0A Active CN117130541B (zh) 2023-03-02 2023-03-02 存储空间配置方法及相关设备

Country Status (1)

Country Link
CN (1) CN117130541B (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117874843A (zh) * 2024-03-08 2024-04-12 荣耀终端有限公司 扩展受保护存储空间的方法、设备和计算机可读存储介质

Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102831033A (zh) * 2012-07-26 2012-12-19 深圳市同洲电子股份有限公司 文件***数据的恢复方法及恢复装置
CN105469001A (zh) * 2014-08-15 2016-04-06 中兴通讯股份有限公司 磁盘数据保护方法及装置
CN106294019A (zh) * 2016-08-11 2017-01-04 浪潮(北京)电子信息产业有限公司 一种操作***镜像保存和恢复方法及装置
CN109343956A (zh) * 2018-09-20 2019-02-15 阿里巴巴集团控股有限公司 一种操作***配置方法及装置
CN109522147A (zh) * 2018-11-15 2019-03-26 Oppo广东移动通信有限公司 一种记录开机异常信息的方法、装置、存储介质及终端
CN109710317A (zh) * 2018-11-16 2019-05-03 华为技术有限公司 ***启动方法、装置、电子设备及存储介质
CN113485858A (zh) * 2021-06-15 2021-10-08 荣耀终端有限公司 一种电子设备的***故障处理方法及电子设备
CN113495799A (zh) * 2020-03-20 2021-10-12 华为技术有限公司 一种内存故障处理方法及相关设备
CN113505014A (zh) * 2021-06-09 2021-10-15 荣耀终端有限公司 一种故障诊断文件获取方法及装置
CN113704205A (zh) * 2021-07-29 2021-11-26 荣耀终端有限公司 日志存储的方法、芯片、电子设备和可读存储介质
CN114153642A (zh) * 2021-11-29 2022-03-08 联想(北京)有限公司 一种***检测方法及电子设备
CN114185494A (zh) * 2022-02-16 2022-03-15 荣耀终端有限公司 内存匿名页的处理方法、电子设备及可读存储介质

Patent Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102831033A (zh) * 2012-07-26 2012-12-19 深圳市同洲电子股份有限公司 文件***数据的恢复方法及恢复装置
CN105469001A (zh) * 2014-08-15 2016-04-06 中兴通讯股份有限公司 磁盘数据保护方法及装置
CN106294019A (zh) * 2016-08-11 2017-01-04 浪潮(北京)电子信息产业有限公司 一种操作***镜像保存和恢复方法及装置
CN109343956A (zh) * 2018-09-20 2019-02-15 阿里巴巴集团控股有限公司 一种操作***配置方法及装置
CN109522147A (zh) * 2018-11-15 2019-03-26 Oppo广东移动通信有限公司 一种记录开机异常信息的方法、装置、存储介质及终端
CN109710317A (zh) * 2018-11-16 2019-05-03 华为技术有限公司 ***启动方法、装置、电子设备及存储介质
CN113495799A (zh) * 2020-03-20 2021-10-12 华为技术有限公司 一种内存故障处理方法及相关设备
CN113505014A (zh) * 2021-06-09 2021-10-15 荣耀终端有限公司 一种故障诊断文件获取方法及装置
CN113485858A (zh) * 2021-06-15 2021-10-08 荣耀终端有限公司 一种电子设备的***故障处理方法及电子设备
CN113704205A (zh) * 2021-07-29 2021-11-26 荣耀终端有限公司 日志存储的方法、芯片、电子设备和可读存储介质
CN114153642A (zh) * 2021-11-29 2022-03-08 联想(北京)有限公司 一种***检测方法及电子设备
CN114185494A (zh) * 2022-02-16 2022-03-15 荣耀终端有限公司 内存匿名页的处理方法、电子设备及可读存储介质

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117874843A (zh) * 2024-03-08 2024-04-12 荣耀终端有限公司 扩展受保护存储空间的方法、设备和计算机可读存储介质

Also Published As

Publication number Publication date
CN117130541B (zh) 2024-06-04

Similar Documents

Publication Publication Date Title
CN112783564A (zh) 一种加速应用程序启动的方法及电子设备
CN113704014A (zh) 日志获取***、方法、电子设备及存储介质
CN113553130B (zh) 应用执行绘制操作的方法及电子设备
CN113704205B (zh) 日志存储的方法、芯片、电子设备和可读存储介质
CN117130541B (zh) 存储空间配置方法及相关设备
CN116665751B (zh) 测试方法及电子设备
CN114443109B (zh) 补丁修复方法、电子设备及存储介质
CN115482143B (zh) 应用的图像数据调用方法、***、电子设备及存储介质
CN114461589B (zh) 读取压缩文件的方法、文件***及电子设备
CN113885928B (zh) 程序更新方法和电子设备
CN112783418B (zh) 一种存储应用程序数据的方法及移动终端
CN116627855B (zh) 内存处理方法及相关装置
CN116795476B (zh) 一种删除壁纸的方法及电子设备
CN116841575B (zh) 生成镜像文件的方法及相关装置
CN117312055B (zh) 数据备份的方法及相关装置
CN116703689B (zh) 一种着色器程序的生成方法、装置和电子设备
CN116662150B (zh) 应用启动耗时检测方法及相关装置
CN115952564B (zh) 数据写入方法和终端设备
CN116709609B (zh) 消息传递方法、电子设备及存储介质
CN117009023B (zh) 显示通知信息的方法及相关装置
CN117707563A (zh) 应用资源处理方法及相关设备
CN115840528A (zh) 存储盘的水线设置方法、电子设备及存储介质
CN117707405A (zh) 显示屏控制方法及相关设备
CN117666937A (zh) 存储的方法、装置和电子设备
CN118277120A (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