CN117130952B - 预读方法和预读装置 - Google Patents

预读方法和预读装置 Download PDF

Info

Publication number
CN117130952B
CN117130952B CN202310032749.3A CN202310032749A CN117130952B CN 117130952 B CN117130952 B CN 117130952B CN 202310032749 A CN202310032749 A CN 202310032749A CN 117130952 B CN117130952 B CN 117130952B
Authority
CN
China
Prior art keywords
pressure
read
reading
size
threshold
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
CN202310032749.3A
Other languages
English (en)
Other versions
CN117130952A (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 CN202310032749.3A priority Critical patent/CN117130952B/zh
Publication of CN117130952A publication Critical patent/CN117130952A/zh
Application granted granted Critical
Publication of CN117130952B publication Critical patent/CN117130952B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0862Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches with prefetch
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Stored Programmes (AREA)

Abstract

本申请提供一种预读方法和预读装置,该方法包括:通过遍历的方式设置第一挂载设备的第一预读参数阈值,第一挂载设备为预读操作对应的挂载设备;监控第一挂载设备的第一预读参数阈值,使得第一挂载设备的第一预读参数阈值不被修改;获取并根据压力阻塞信息,确定***资源压力;根据***资源压力和第一挂载设备的第一预读参数阈值,确定目标预读窗口大小。该方案由于增加了第一预读参数阈值这一门限值的约束,并且保证该门限值不被修改,使得整个预读过程中,所有参数的设置更加合理,不会超出电子设备的实际能力,而通过压力阻塞信息来确定***资源压力则更加准确,使得确定的预读窗口的目标大小更加合理,从而整体上有效提高了预读性能。

Description

预读方法和预读装置
技术领域
本申请涉及电子设备技术领域,尤其涉及一种预读方法和预读装置。
背景技术
预读(read_ahead)是指***内核为应用程序一次读出比预期更多的文件内容并缓存在内存中,使得下一次该应用程序再次读请求时,读请求的部分页面或全部页面可以直接从内存读取。目前有很多针对预读窗口设置的方法来提高文件加载速度和应用程序的启动速度。最常见的方案是根据预读页面的缺页还是命中来动态调整预读窗口的大小,当发生缺页时增大窗口大小,当命中时保持预读窗口大小,但是这样的方案由于没有考虑电子设备的自身性能,导致反而劣化了预读过程的准确性和影响电子设备的***性能。
为了解决这一问题,虽然出现了考虑电子设备的内存状态和输入输出性能的状态来确定预读窗口的方案,但由于这类方案只是利用电子设备的内存状态和输入输出性能的状态简单计算一下***性能等级,然后基于性能等级进行预读窗口大小的调整,准确性虽然有一定的提高,却依然较低。
因此如何有效提高预读性能,是亟待解决的技术问题。
发明内容
本申请提供一种预读方法和预读装置,能够有效提高预读性能。
第一方面,提供了一种预读方法,该方法包括:通过遍历的方式设置第一挂载设备的第一预读参数阈值,第一挂载设备为预读操作对应的挂载设备;监控第一挂载设备的第一预读参数阈值,使得第一挂载设备的第一预读参数阈值不被修改;获取***的压力阻塞信息;根据压力阻塞信息,确定***的***资源压力;根据***资源压力和第一挂载设备第一预读参数阈值,确定第一挂载设备的目标预读窗口大小。
在本申请技术方案中,主要通过遍历的方式设置第一预读参数阈值,也就是门限值,并监控该门限值不被修改,之后通过获取压力阻塞信息来确定***资源压力,以及基于***资源压力和上述门限值确定目标预读窗口大小。由于增加了门限值的约束,并且保证该门限值不被修改,使得整个预读过程中,所有参数的设置更加合理,不会超出电子设备的实际能力,而通过压力阻塞信息来确定***资源压力则更加准确,使得确定的预读窗口的目标大小更加合理,从而整体上有效提高了预读性能。
相比于只是利用电子设备的内存状态和输入输出性能的状态简单计算一下***性能等级,然后基于性能等级进行预读窗口大小的调整的传统方案而言,由于***资源压力是根据压力阻塞信息得到的,更加准确,所以预读窗口大小的调整会更加合理,且由于引入了第一预读参数阈值这一门限值,相当于进一步增加了一层约束,使得确定的目标预读窗口大小更合理。此外增加了实时监控该门限值的步骤,进一步确保该门限值能够一直发挥约束作用,所以使得本申请实施例的方案相比于上述传统方案,对于预读性能的提升更加明显和有效。
影响预读窗口设置的相关参数可以包括当前设备的内存(total memory)、挂载设备(dmdevice)、预读窗口大小(read_ahead_kb)和挂载设备的标签(sysfs_dm:*)。挂载设备可以理解为需要在电子设备上进行挂载的设备。也就是说,上述影响到预读窗口设置的参数可以称之为预读参数。
在传统方案中,在电子设备开机之后,给挂载设备设置通用的默认参数,例如设置上述挂载设备的标签和预读窗口大小的默认值,之后就不再进行其他处理了。而本申请实施例的方案,则通过遍历的方式为第一挂载设备设置不同的预读参数阈值。
第一预读参数阈值,可以理解为是为通过遍历所有挂载设备中每个挂载设备找到第一挂载设备之后为第一挂载设备设置的预读参数的门限值。该门限值可以基于电子设备的实际性能来确定。
第一预读参数阈值可以包括第一内存压力阈值、第一IO压力阈值或第一预读窗口大小阈值中的至少一项。
如上所述,在传统方案中,在电子设备开机之后,给挂载设备设置通用的默认参数之后就不再进行其他处理了。但是在实际使用时发现,当电子设备升级时,挂载设备的上述参数可能会发生变化,也就是不再是默认参数,而如果依然根据传统方案不进行其他处理,会导致无法再读取到正确的挂载设备的参数。针对该问题,本本申请实施例的方案,通过步骤S102的实时监控来确保该门限值不被修改。
应理解,此处的不被修改的意思是如果发现被修改了就改回去,如果没有被修改就保持不变,而不是修改这件事不发生。
结合第一方面,在第一方面的某些实现方式中,在监控第一挂载设备的第一预读参数阈值,使得第一挂载设备的第一预读参数阈值不被修改时,可以包括:
周期性读取第一挂载设备的第二预读参数阈值,第二预读参数阈值用于表示周期性读取到的第一挂载设备的预读参数阈值;
判断第一挂载设备的第二预读参数阈值与第一挂载设备的第一预读参数阈值是否一致;
当判断结果为不一致时,将第一挂载设备的第二预读参数阈值修改为与第一预读参数阈值相同。
对于传统方案,虽然设置了默认参数,但是在后续调整预读窗口的时候,并没有基于所设置的默认参数来进一步调整,而且,如果后续有其他任务导致了默认参数的修改,也无从获知和调整,使得该预读参数阈值的设置只起到了不让该值空缺的作用,却不能发挥其他作用。与之不同的是,本申请实施例的方案则会针对第一挂载设备去设置相应的预读参数阈值,这样的设置更精细,并且还会通过监控操作来防止设置的值被修改,以及所设置的预读参数阈值还会用于后续确定预读窗口时的一个约束条件,使得预读窗口的调整更加准确合理。
第一挂载设备为预读操作对应的挂载设备。也就是说,在监控时可以只考虑对于第一挂载设备的阈值的监控,而对于其他挂载设备的阈值不存在限定。预读操作对应的挂载设备可以理解为数据分区的挂载设备,参数被修改的可能性较高,而***分区等其他分区的挂载设备的参数被修改的可能性相对较小,所以可以不进行监控,以减少占用的资源。此外,本申请主要针对的就是预读这一场景,所以可以只考虑会影响到预读效果的挂载设备,或者说可以只考虑对预读效果影响较大的挂载设备,而对于对预读效果几乎不会产生影响的挂载设备可以不考虑其阈值的监控。也因此,第一挂载设备也可以理解为是会对预读过程产生影响的挂载设备,或者理解为对于预读的影响不能忽略的挂载设备。
结合第一方面,在第一方面的某些实现方式中,***资源压力包括内存压力和输入输出(IO)压力中的至少一项;第一预读参数阈值包括第一内存压力阈值或第一IO压力阈值中的至少一项;在根据***资源压力和第一挂载设备的第一预读参数阈值,确定第一挂载设备的目标预读窗口大小时,可以包括:
当IO压力小于IO压力阈值时,确定目标预读窗口大小为原预读窗口大小,IO压力阈值小于或等于第一IO压力阈值;或者,
当IO压力大于或等于IO压力阈值且内存压力小于内存压力阈值时,根据预读窗口的需求大小(req_size)和挂载设备的最大IO大小(io_size),确定目标预读窗口大小,内存压力阈值小于或等于第一内存压力阈值,IO压力阈值小于或等于第一IO压力阈值;或者,
当IO压力大于或等于IO压力阈值且内存压力大于或等于内存压力阈值时,确定目标预读窗口大小小于原预读窗口大小,内存压力阈值小于或等于第一内存压力阈值,IO压力阈值小于或等于第一IO压力阈值。
由于内存压力阈值和IO压力阈值在设置的时候引入了预读参数阈值的约束,所以使得确定的目标预读窗口大小更加准确。
结合第一方面,在第一方面的某些实现方式中,预读窗口的req_size是根据按需预读策略确定的;按需预读策略包括根据缺失(miss)值和命中(hit)值确定req_size为原预读窗口大小的2的N次幂倍,N为大于或等于零的整数。
按需预读策略可以理解为是目前所有预读机制中的原生预读方案。而本申请实施例的方案是在原有的调整预读窗口大小的方案的基础上,增加了通过***资源压力来进一步确定最终的目标预读窗口大小的方案。
结合第一方面,在第一方面的某些实现方式中,在当IO压力大于或等于IO压力阈值且内存压力小于内存压力阈值时,根据预读窗口的需求大小req_size和挂载设备的最大IO大小,确定目标预读窗口大小,内存压力阈值小于或等于第一内存压力阈值,IO压力阈值小于或等于第一IO压力阈值时,可以包括:
当预读窗口的req_size小于io_size时,确定目标预读窗口大小为原预读窗口大小和io_size中的较小值;或者,
当预读窗口的req_size大于或等于io_size时,确定目标预读窗口大小大于原预读窗口大小。
结合第一方面,在第一方面的某些实现方式中,在根据压力阻塞信息,确定***的***资源压力时,可以包括:
根据压力阻塞信息,确定任务阻塞时间在整个统计时间周期内的占比,任务阻塞时间包括部分任务阻塞的时间和所有任务同时阻塞的时间;
根据任务阻塞时间在整个统计时间周期内的占比与占比阈值之间的关系,确定***资源压力。
结合第一方面,在第一方面的某些实现方式中,第一预读参数阈值包括第一预读窗口大小阈值,目标预读窗口大小小于或等于第一预读窗口大小阈值。
第二方面,提供了一种预读装置,该装置包括由软件和/或硬件组成的用于执行第一方面的任意一种方法的单元。
第三方面,提供了一种电子设备,包括存储器、处理器以及存储在存储器中并可在处理器上运行的计算机程序,当处理器执行计算机程序时能够实现第一方面的任意一种方法。
第四方面,提供了一种芯片,包括处理器,该处理器用于读取并执行存储在存储器中的计算机程序,当计算机程序被处理器执行时能够实现第一方面的任意一种方法。
可选地,该芯片还包括存储器,存储器与处理器电连接。
可选地,该芯片还可以包括通信接口。
第五方面,提供了一种计算机可读存储介质,该计算机可读存储介质存储有计算机程序,当计算机程序被处理器执行时能够实现第一方面的任意一种方法。
第六方面,提供了一种计算机程序产品,该计算机程序产品包括计算机程序,当计算机程序被处理器执行时能够实现第一方面的任意一种方法。
附图说明
图1是本申请实施例的一种预读方法的示意性流程图。
图2是设置预读参数阈值的执行流程比较图。
图3是本申请实施例的设置预读参数阈值的执行流程的框架图。
图4是本申请实施例的监控预读参数的执行过程的示意图。
图5是按需预读的执行过程的示意图。
图6是本申请实施例的一种预读方法的执行过程的示意图。
图7是本申请实施例的一种预读装置的示意图。
图8是本申请实施例的一种电子设备的硬件结构示意图。
图9是本申请实施例的另一种电子设备的硬件结构示意图。
具体实施方式
下面结合附图对本申请实施例的方案进行介绍。本申请提供的预读方法能够应用于各类需要在电子设备上进行预读的场景。本申请中的电子设备可以是手机终端、平板电脑、计算机、虚拟现实/增强现实等智能穿戴设备等,只要具备预读功能即可。
图1是本申请实施例的一种预读方法的示意性流程图。该方法能够应用于可以进行文件页预读的电子设备中。下面对图1各步骤进行介绍。
S101、通过遍历的方式设置第一挂载设备的第一预读参数阈值。
影响预读窗口设置的相关参数可以包括当前设备的内存(total memory)、挂载设备(dmdevice)、预读窗口大小(read_ahead_kb)和挂载设备的标签(sysfs_dm:*)。挂载设备可以理解为需要在电子设备上进行挂载的设备。也就是说,上述影响到预读窗口设置的参数可以称之为预读参数。
在传统方案中,在电子设备开机之后,给挂载设备设置通用的默认参数,例如设置上述挂载设备的标签和预读窗口大小的默认值,之后就不再进行其他处理了。而本本申请实施例的方案,则通过遍历的方式为第一挂载设备设置不同的预读参数阈值。
第一预读参数阈值,可以理解为是为通过遍历所有挂载设备中每个挂载设备找到第一挂载设备之后为第一挂载设备设置的预读参数的门限值。该门限值可以基于电子设备的实际性能来确定。
第一预读参数阈值可以包括第一内存压力阈值、第一IO压力阈值或第一预读窗口大小阈值中的至少一项。
S102、监控第一挂载设备的第一预读参数阈值,使得第一挂载设备的第一预读参数阈值不被修改。
第一挂载设备为预读操作对应的挂载设备。也就是说,在步骤S102中,可以只考虑对于第一挂载设备的阈值的监控,而对于其他挂载设备的阈值不存在限定。预读操作对应的挂载设备可以理解为数据(data)分区的挂载设备,参数被修改的可能性较高,而***(system)分区等其他分区的挂载设备的参数被修改的可能性相对较小,所以可以不进行监控,以减少占用的资源。此外,本申请主要针对的就是预读这一场景,所以可以只考虑会影响到预读效果的挂载设备,或者说可以只考虑对预读效果影响较大的挂载设备,而对于对预读效果几乎不会产生影响的挂载设备可以不考虑其阈值的监控。也因此,第一挂载设备也可以理解为是会对预读过程产生影响的挂载设备,或者理解为对于预读的影响不能忽略的挂载设备。
如上所述,在传统方案中,在电子设备开机之后,给挂载设备设置通用的默认参数之后就不再进行其他处理了。但是在实际使用时发现,当电子设备升级时,挂载设备的上述参数可能会发生变化,也就是不再是默认参数,而如果依然根据传统方案不进行其他处理,会导致无法再读取到正确的挂载设备的参数。针对该问题,本本申请实施例的方案,通过步骤S102的实时监控来确保该门限值不被修改。
应理解,此处的不被修改的意思是如果发现被修改了就改回去,如果没有被修改就保持不变,而不是修改这件事不发生。
在一种实现方式中,步骤S102包括:
周期性读取第一挂载设备的第二预读参数阈值,第二预读参数阈值用于表示周期性读取到的第一挂载设备的预读参数阈值;
判断第一挂载设备的第二预读参数阈值与第一挂载设备的第一预读参数阈值是否一致;
当判断结果为不一致时,将第一挂载设备的第二预读参数阈值修改为与其第一预读参数阈值相同。
在一个例子中,每n秒(s)周期性读取,n为正实数。n可以根据电子设备在实际使用过程中可能会修改该值的操作发生频率来确定。周期时长例如可以为3s、4s或5s等,不再逐一列举。
S103、获取***的压力阻塞信息。
压力阻塞信息(pressure stall information,PSI)提供了一种评估***资源压力的方法。***有三个基础资源:中央处理单元(central processing unit,CPU)、内存(memory)和输入输出(inputoutput,IO),无论这些资源配置如何增加,但依然会出现无法满足软件的需求。一旦产生资源竞争,就有可能带来延迟增大,使用户体验到卡顿。PSI量化了由于硬件资源紧张造成的任务执行中断,统计了***中任务等待硬件资源的时间。因此可以用PSI作为指标,来衡量硬件资源的压力情况。阻塞的时间越长,说明资源面临的压力越大。
为了便于理解,下面以一个具体例子对PSI中各个参数进行说明。
PSI中提供的***资源压力值如下面一段代码所示。
HNANB:/#cat/proc/pressure/io
some avg10=2661.47avg60=2660.79avg300=2649.56total=944945199
full avg10=255.76avg60=2543.40avg300=2534.86total=818923311
HNANB:/#cat/proc/pressure/cpu
some avg10=106.05avg60=119.62avg300=120.36total=4175621498
HNANB:/#cat/proc/pressure/memory
some avg10=0.00avg60=0.00avg300=0.00total=17161249
full avg10=0.00avg60=0.00avg300=0.00total=2159335
在上述代码中,avg10、avg60、avg300分别代表10s、60s、300s的时间周期内的阻塞时间百分比。total是总累计时间,以毫秒为单位。上述百分比是统计意义上的,一般认为进程的生存时间服从参数为1的指数分布,avg300不是avg10、avg60简单累加,而是一个在300s时间上重新计算的阻塞时间,所以avg300是可以小于avg60的,它表征在60s-300s上比0-60s这个时间上是不忙的。some表示至少有一个任务在某个资源上阻塞的时间占比;full表示所有的任务同时被阻塞的时间占比;在阻塞期间cpu被完全浪费,会带来严重的性能问题。
也就是说,可以根据PSI,来得到任务阻塞时间在整个统计时间周期内的占比情况,从而确定***资源压力是大还是小。
S104、根据压力阻塞信息,确定***的***资源压力。
如上所述,可以根据PSI中的阻塞时间的占比来推断***资源压力的大小。
在一种实现方式中,可以根据PSI,确定任务阻塞时间在整个统计时间周期内的占比,任务阻塞时间包括部分任务阻塞的时间和所有任务同时阻塞的时间;根据任务阻塞时间在整个统计时间周期内的占比与占比阈值之间的关系,确定***资源压力。
在一个例子中,***压力值的判断可以如表1所示。
表1
在表1中,内存(memory)和IO的压力等级是综合了部分任务阻塞时间占比some和所有任务同时阻塞时间占比full来设置的。ms表示毫秒,Threadhol表示阻塞发生的时间长度,也就是任务阻塞时间,Windo表示电子设备的运行时间。假设当统计发现每1000ms的Windo运行时长内,内存some的Threadhol时长超过了70ms,就认为内存的压力等级为中等(medium)。假设当统计发现每1000ms的Windo运行时长内,内存full的Threadhol时长超过了40ms,就认为内存的压力等级为紧张(critical)。表1中的每个Threadhol可以看成每个资源的压力等级对应的阈值,例如内存的some为70ms就可以看成是内存压力阈值的一个示例。表1可以看成是,内存和IO分别设置了两个阈值的情况的示例,在实际应用中还可以每种资源只设置一个阈值,或者每种资源都设置多个阈值,不存在限定。设置的阈值更多说明更细化,比较结果更准确,但相应的处理时长会有所增加,处理效率相对降低。
应理解,PSI和***资源压力都是对于电子设备的整个***的整体而言的参数,而对于到底挂载了多少挂载设备不存在限定。例如当只有一个挂载设备时,此时***的PSI和***资源压力只受这一个挂载设备和电子设备本身的影响;而当有多个挂载设备时,此时***的PSI和***资源压力就会受这多个挂载设备和电子设备本身的影响。
S105、根据***资源压力和第一挂载设备的第一预读参数阈值,确定第一挂载设备的目标预读窗口大小。
***资源压力包括内存压力或IO压力中的至少一项。
可以在获取到PSI之后,通过S104的操作确定内存压力和/或IO压力,然后将确定的***资源压力与分别对应的阈值进行比较来确定不同的预读策略,也就是确定目标预读窗口大小。
在一种实现方式中,步骤S105包括:
当IO压力小于IO压力阈值时,确定目标预读窗口大小为原预读窗口大小,IO压力阈值小于或等于第一IO压力阈值;或者,
当IO压力大于或等于IO压力阈值且内存压力小于内存压力阈值时,根据预读窗口的需求大小(req_size)和挂载设备的最大IO大小(io_size),确定目标预读窗口大小,内存压力阈值小于或等于第一内存压力阈值,IO压力阈值小于或等于第一IO压力阈值;或者,
当IO压力大于或等于IO压力阈值且内存压力大于或等于内存压力阈值时,确定目标预读窗口大小小于原预读窗口大小,内存压力阈值小于或等于第一内存压力阈值,IO压力阈值小于或等于第一IO压力阈值。
在一个例子中,预读窗口的req_size是根据按需预读策略确定的;按需预读策略包括根据缺失miss值和命中hit值确定req_size为原预读窗口大小的2的N次幂倍,N为大于或等于零的整数。
按需预读策略可以理解为是目前所有预读机制中的原生预读方案。在按需预读策略中,会执行图5所示的流程来确定上述req_size的值。为了简洁,此处暂不展开,会在下文详细描述。
在另一个例子中,在执行上述当IO压力大于或等于IO压力阈值且内存压力小于内存压力阈值时,根据预读窗口的需求大小req_size和挂载设备的最大IO大小,确定目标预读窗口大小,内存压力阈值小于或等于第一内存压力阈值,IO压力阈值小于或等于第一IO压力阈值的操作时,可以包括:
当预读窗口的req_size小于io_size时,确定目标预读窗口大小为原预读窗口大小和io_size中的较小值;或者,
当预读窗口的req_size大于或等于io_size时,确定目标预读窗口大小大于原预读窗口大小。
原预读窗口大小可以理解为如果不进行调整,在执行步骤S105时***会默认采用的预读窗口大小。
在一个例子中,步骤S105可以包括:
当内存压力(mempress)小于内存压力阈值(mem_critical),且IO压力(iopress)小于IO压力阈值(io_critical),调整策略为不改变原预读窗口大小(nochange),也就是目标预读窗口大小为原预读窗口大小;或者,
当mempress小于mem_critical,且iopress大于或等于io_critical,且req_size小于io_size时,调整策略为取nesize和io_size中的最小值,nesize就是原预读窗口大小,也就是确定目标预读窗口大小为原预读窗口大小和io_size中的较小值;或者,
当mempress小于mem_critical,且iopress大于或等于io_critical,且req_size大于或等于io_size时,调整策略为增大预读窗口大小,也就是确定目标预读窗口大小大于原预读窗口大小,例如目标预读窗口大小可以为newsize*2;或者,
当mempress大于或等于mem_critical,且iopress小于io_critical,调整策略为不改变原预读窗口大小(nochange),也就是目标预读窗口大小为原预读窗口大小;或者,
当mempress大于或等于mem_critical,且iopress大于或等于io_critical,调整策略为减小预读窗口大小,也就是确定目标预读窗口大小小于原预读窗口大小,例如目标预读窗口大小可以为newsize/2。
图1所示方法,主要通过遍历的方式设置第一预读参数阈值,也就是门限值,并监控该门限值不被修改,之后通过获取压力阻塞信息来确定***资源压力,以及基于***资源压力和上述门限值确定目标预读窗口大小。由于增加了门限值的约束,并且保证该门限值不被修改,使得整个预读过程中,所有参数的设置更加合理,不会超出电子设备的实际能力,而通过压力阻塞信息来确定***资源压力则更加准确,使得确定的预读窗口的目标大小更加合理,从而整体上有效提高了预读性能。
相比于只是利用电子设备的内存状态和输入输出性能的状态简单计算一下***性能等级,然后基于性能等级进行预读窗口大小的调整的传统方案而言,由于***资源压力是根据压力阻塞信息得到的,更加准确,所以预读窗口大小的调整会更加合理,且由于引入了第一预读参数阈值这一门限值,相当于进一步增加了一层约束,使得确定的目标预读窗口大小更合理。此外增加了实时监控该门限值的步骤,进一步确保该门限值能够一直发挥约束作用,所以使得本申请实施例的方案相比于上述传统方案,对于预读性能的提升更加明显和有效。
图2是设置预读参数阈值的执行流程比较图。图2中(a)所示为本申请实施例的预读参数阈值的设置流程,该流程包括在设置阶段(ondata_ready)对挂载设备进行遍历,为挂载设备分别设置阈值;以及在内存信息storage_info读取时周期性读取这个阈值,判断是否被修改。其中,对挂载设备进行遍历,为挂载设备分别设置阈值的步骤可以看成是步骤S101的一个示例,周期性读取这个阈值,判断是否被修改的步骤可以看成是步骤S102的一个示例。此处的阈值例如可以是上述第一挂载设备的第一预读参数阈值。
图2中(b)所示为传统方案中设置预读参数阈值的流程,该流程只包括在按照预设信息on post-fs-data开机后为挂载设备设置默认参数。
对于传统方案,虽然设置了默认参数,但是在后续调整预读窗口的时候,并没有基于所设置的默认参数来进一步调整,而且,如果后续有其他任务导致了默认参数的修改,也无从获知和调整,使得该预读参数阈值的设置只起到了不让该值空缺的作用,却不能发挥其他作用。与之不同的是,本申请实施例的方案则会针对第一挂载设备设置相应的预读参数阈值,这样的设置更精细,并且还会通过监控操作来防止设置的值被修改,以及所设置的预读参数阈值还会用于后续确定预读窗口时的一个约束条件,使得预读窗口的调整更加准确合理。
图3是本申请实施例的设置预读参数阈值的执行流程的框架图。如图3所示,执行S301读取***内存(get_memtotal)。之后执行S302判断读取到的***内存值mem_total与第一预设内存阈值之间的关系,此处第一预设内存阈值以3吉(G)为例。当判断结果为“是”执行步骤S303,设置第一预设预读窗口大小阈值为RA_value=512。当判断结果为“否”执行步骤S304,设置第一预设预读窗口大小阈值为RA_value=128。执行步骤S305获取挂载设备信息,即getdm_devices。之后执行步骤S306,设置第一预设预读窗口大小阈值,即setRA_value。
可以看出,第一预读参数阈值可以包括第一内存压力阈值、第一IO压力阈值或第一预读窗口大小阈值中的至少一项。图3是以第一预读参数阈值包括第一预读窗口大小阈值(也就是第一预设预读窗口大小阈值)为例的。
图3可以看成是步骤S101的一个示例。
图4是本申请实施例的监控预读参数的执行过程的示意图。图4可以看成是步骤S102的一个示例。
S401、获取数据路径getuserdatapath。
S402、读取第二预读参数阈值read_RA_value。
可以是周期性读取。
S403、参数阈值比较。
也就是将读取的第二预读参数阈值与上述第一预读参数阈值进行比较,看二者是否一致。当比较结果为一致时,也就是结果为“是”时,执行步骤S404;当比较结果为不一致时,也就是结果为“否”时,执行步骤S405。
S404、不输出警示信息,从而不进行修改。
输出noworing,指示不需要修改。
S405、输出错误警示信息,从而指示修改回原值。
输出错误警示信息outputerrlog,然后基于该警示信息,将数据路径中存储的数值修改会第一预读参数阈值。
图4可以看成是,步骤S102中如何通过周期性读取第二预读参数阈值并与第一预预读参数阈值进行比较和判断是否修改的操作的一个示例。
图5是按需预读的执行过程的示意图。图5可以看成是步骤S105中确定上述req_size的值的执行过程的示意图。
S501、当预读窗口大小小于第一阈值时,增大预读窗口大小。
在一个例子中,可以通过下面代码实现:
if newsize<max/32
newsize=newsize*4;
在这个例子中,预读窗口大小用newsize表示,第一阈值可以是max/32,其中max表示预读窗口大小的最大值,可以根据文件总页数确定。此处以增大预读窗口大小到newsize*4为例,但应理解,实际操作时也可以采用其他倍数来增大,只要是2的整数次幂即可。如果执行了步骤S501,则req_size就是增大后的预读窗口大小,例如上述例子中的newsize*4。
S502、当预读窗口大小大于或等于第一阈值且小于第二阈值时,增大预读窗口大小。
在一个例子中,可以通过下面代码并结合步骤S501中例子的代码实现步骤S502:
elseif newsize<=max/4
newsize=newsize*2;
在这个例子中,第二阈值是max/32,其中max表示预读窗口大小的最大值,可以根据文件总页数确定。此处以增大预读窗口大小到newsize*2为例,但应理解,实际操作时也可以采用其他倍数来增大,只要是2的整数次幂即可。如果执行了步骤S502,则req_size就是增大后的预读窗口大小,例如上述例子中的newsize*2。
S503、当预读窗口大小大于或等于第二阈值时,不改变预读窗口大小。
图5可以看成是按需预读这一原生方案的示例。也就是说,本申请实施例的方案是在原有的调整预读窗口大小的方案的基础上,增加了通过***资源压力来进一步确定最终的目标预读窗口大小的方案。
图6是本申请实施例的一种预读方法的执行过程的示意图。图6可以看成是图1所示方法的一个示例,具体而言可以看成是步骤S103-S105的一个示例。
S601、当发生读操作缺页异常时发起预读。
例如可以通过filemap_fault来确定是否发生读操作缺页异常。
可以通过pagecahe中是否有find_get_page来确定是否发起预读。当判断结果为否时,同步预读do_sync_mmap_readahead。
S602、根据按需预读确定预读窗口的需求大小。
步骤S601中当判断结果为否时,同步预读do_sync_mmap_readahead,并调整预读窗口为pagecahe中的值page_cahe_sync_ra。
S603、读取PSI,并根据PSI和上述预读窗口的需求大小,确定目标预读窗口大小。
例如通过get_psi_info和get_newsize来执行步骤S603。
S604、根据目标预读窗口大小进行预读。
例如可以通过page_cahe_ra执行。
上文主要结合附图对本申请实施例的方法进行了介绍。应理解,虽然如上所述的各实施例所涉及的流程图中的各个步骤依次显示,但是这些步骤并不是必然按照图中所示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,这些步骤可以以其它的顺序执行。而且,如上所述的各实施例所涉及的流程图中的至少一部分步骤可以包括多个步骤或者多个阶段,这些步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,这些步骤或者阶段的执行顺序也不必然是依次进行,而是可以与其它步骤或者其它步骤中的步骤或者阶段的至少一部分轮流或者交替地执行。下面结合附图对本申请实施例的装置进行介绍。
图7是本申请实施例的一种预读装置的示意图。如图7所示,该装置1000包括设置单元1001、获取单元1002和处理单元1003。该装置1000可以是集成在终端、计算机等电子设备中。
该装置1000能够用于执行上文任意一种预读方法。例如,设置单元1001可用于执行步骤S101和S102,获取单元1002可用于执行步骤S103,处理单元1003可用于执行步骤S104和S105。又例如,设置单元1001可用于执行图2中(a)、图3、图4所示过程。又例如,处理单元1003可用于执行图5、图6所示过程。
在一种实现方式中,装置1000还可以包括存储单元,用于存储预读窗口相关数据。该存储单元可以是集成在上述任意一个单元中,也可以是独立于上述所有单元之外的单元。
图8是本申请实施例的一种电子设备的硬件结构示意图。如图8所示,该电子设备3000包括:至少一个处理器3001(图8中仅示出一个)处理器、存储器3002以及存储在所述存储器3002中并可在所述至少一个处理器3001上运行的计算机程序3003,所述处理器3001执行所述计算机程序3003时实现上述任意一种方法中的步骤。
本领域技术人员可以理解,图8仅仅是电子设备的举例,并不构成对电子设备限定,实际中电子设备可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如还可以包括输入输出设备、网络接入设备等。
处理器3001可以是中央处理单元(central processing unit,CPU),其他通用处理器、数字信号处理器(digital signal processor,DSP)、专用集成电路(applicationspecific integrated circuit,ASIC)、现成可编程门阵列(field-programmable gatearray,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
存储器3002在一些实施例中可以是电子设备3000的内部存储单元,例如电子设备3000的硬盘或内存。存储器3002在另一些实施例中也可以是电子设备3000的外部存储设备,例如电子设备3000上配备的插接式硬盘,智能存储卡(smart media card,SMC),安全数字(secure digital,SD)卡,闪存卡(flash card)等。可选地,存储器3002还可以既包括电子设备3000的内部存储单元也包括外部存储设备。存储器3002用于存储操作***、应用程序、引导装载程序、数据以及其他程序等,例如所述计算机程序的程序代码等。存储器3002还可以用于暂时地存储已经输出或者将要输出的数据。
图9是本申请实施例的另一种电子设备的硬件结构示意图。如图9所示,电子设备900可以包括处理器910,外部存储器接口920,内部存储器921,通用串行总线(universalserial bus,USB)接口930,充电管理模块940,电源管理模块941,电池942,天线1,天线2,移动通信模块950,无线通信模块960,音频模块970,扬声器970A,受话器970B,麦克风970C,耳机接口970D,传感器模块980,按键990,马达991,指示器992,摄像头993,显示屏994,以及用户标识模块(subscriber identification module,SIM)卡接口995等。其中,传感器模块980可以包括压力传感器980A,陀螺仪传感器980B,气压传感980C,磁传感器980D,加速度传感器980E,距离传感器980F,接近光传感器980G,指纹传感器980H,温度传感器980J,触摸传感器980K,环境光传感器980L,骨传导传感器980M等。
可以理解的是,本申请实施例示意的结构并不构成对电子设备900的具体限定。在本申请另一些实施例中,电子设备900可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实现。
示例性地,图9所示的处理器910可以包括一个或多个处理单元,例如:处理器910可以包括应用处理器(application processor,AP),调制解调处理器,图形处理器(graphics processing unit,GPU),图像信号处理器(image signal processor,ISP),控制器,存储器,视频编解码器,数字信号处理器(digital signal processor,DSP),基带处理器,和/或神经网络处理器(neural-network processing unit,NPU)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。
其中,控制器可以是电子设备900的神经中枢和指挥中心。控制器可以根据指令操作码和时序信号,产生操作控制信号,完成取指令和执行指令的控制。
处理器910中还可以设置存储器,用于存储指令和数据。在一些实施例中,处理器910中的存储器为高速缓冲存储器。该存储器可以保存处理器910刚用过或循环使用的指令或数据。如果处理器910需要再次使用该指令或数据,可从所述存储器中直接调用。避免了重复存取,减少了处理器910的等待时间,因而提高了***的效率。
在一些实施例中,处理器910可以包括一个或多个接口。接口可以包括集成电路(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)。处理器910可以包含多组I2C总线。处理器910可以通过不同的I2C总线接口分别耦合触摸传感器980K,充电器,闪光灯,摄像头993等。例如,处理器910可以通过I2C接口耦合触摸传感器980K,使处理器910与触摸传感器980K通过I2C总线接口通信,实现电子设备900的触摸功能。
在一些实施例中,I2S接口可以用于音频通信。处理器910可以包含多组I2S总线。处理器910可以通过I2S总线与音频模块970耦合,实现处理器910与音频模块970之间的通信。
在一些实施例中,音频模块970可以通过I2S接口向无线通信模块960传递音频信号,实现通过蓝牙耳机接听电话的功能。
在一些实施例中,PCM接口也可以用于音频通信,将模拟信号抽样,量化和编码。音频模块970与无线通信模块960可以通过PCM总线接口耦合。
在一些实施例中,音频模块970也可以通过PCM接口向无线通信模块960传递音频信号,实现通过蓝牙耳机接听电话的功能。应理解,I2S接口和PCM接口都可以用于音频通信。
在一些实施例中,UART接口是一种通用串行数据总线,用于异步通信。该总线可以为双向通信总线。它将要传输的数据在串行通信与并行通信之间转换。UART接口通常被用于连接处理器910与无线通信模块960。例如,处理器910通过UART接口与无线通信模块960中的蓝牙模块通信,实现蓝牙功能。在一些实施例中,音频模块970可以通过UART接口向无线通信模块960传递音频信号,实现通过蓝牙耳机播放音乐的功能。
在一些实施例中,MIPI接口可以被用于连接处理器910与显示屏994,摄像头993等***器件。MIPI接口包括摄像头串行接口(camera serial interface,CSI),显示屏串行接口(display serial interface,DSI)等。处理器910和摄像头993通过CSI接口通信,实现电子设备900的拍摄功能。处理器910和显示屏994通过DSI接口通信,实现电子设备900的显示功能。
在一些实施例中,GPIO接口可以通过软件配置。GPIO接口可以被配置为控制信号,也可被配置为数据信号。GPIO接口可以用于连接处理器910与摄像头993,显示屏994,无线通信模块960,音频模块970,传感器模块980等。GPIO接口还可以被配置为I2C接口,I2S接口,UART接口,MIPI接口等。
示例性地,USB接口930是符合USB标准规范的接口,具体可以是Mini USB接口,Micro USB接口,USB Type C接口等。USB接口130可以用于连接充电器为电子设备900充电,也可以用于电子设备900与***设备之间传输数据。也可以用于连接耳机,通过耳机播放音频。该接口还可以用于连接其他电子设备,例如AR设备等。
可以理解的是,本申请实施例示意的各模块间的接口连接关系,只是示意性说明,并不构成对电子设备900的结构限定。在本申请另一些实施例中,电子设备900也可以采用上述实施例中不同的接口连接方式,或多种接口连接方式的组合。
充电管理模块940用于从充电器接收充电输入。其中,充电器可以是无线充电器,也可以是有线充电器。在一些有线充电的实施例中,充电管理模块940可以通过USB接口930接收有线充电器的充电输入。在一些无线充电的实施例中,充电管理模块940可以通过电子设备900的无线充电线圈接收无线充电输入。充电管理模块940为电池942充电的同时,还可以通过电源管理模块941为电子设备供电。
电源管理模块941用于连接电池942,充电管理模块940与处理器910。电源管理模块941接收电池942和/或充电管理模块940的输入,为处理器910,内部存储器921,外部存储器,显示屏994,摄像头993,和无线通信模块960等供电。电源管理模块941还可以用于监测电池容量,电池循环次数,电池健康状态(漏电,阻抗)等参数。在其他一些实施例中,电源管理模块941也可以设置于处理器910中。在另一些实施例中,电源管理模块941和充电管理模块940也可以设置于同一个器件中。
电子设备900的无线通信功能可以通过天线1,天线2,移动通信模块950,无线通信模块960,调制解调处理器以及基带处理器等实现。
天线1和天线2用于发射和接收电磁波信号。电子设备900中的每个天线可用于覆盖单个或多个通信频带。不同的天线还可以复用,以提高天线的利用率。例如,可以将天线1复用为无线局域网的分集天线。在另外一些实施例中,天线可以和调谐开关结合使用。
移动通信模块950可以提供应用在电子设备900上的无线通信的解决方案,例如下列方案中的至少一个:第二代(2th generation,2G)移动通信解决方案、第三代(3thgeneration,3G)移动通信解决方案、***(4th generation,5G)移动通信解决方案、第五代(5th generation,5G)移动通信解决方案。移动通信模块150可以包括至少一个滤波器,开关,功率放大器,低噪声放大器(low noise amplifier,LNA)等。移动通信模块950可以由天线1接收电磁波,并对接收的电磁波进行滤波和放大等处理,随后传送至调制解调处理器进行解调。移动通信模块950还可以放大经调制解调处理器调制后的信号,放大后的该信号经天线1转变为电磁波辐射出去。在一些实施例中,移动通信模块150的至少部分功能模块可以被设置于处理器910中。在一些实施例中,移动通信模块950的至少部分功能模块可以与处理器910的至少部分模块被设置在同一个器件中。
调制解调处理器可以包括调制器和解调器。其中,调制器用于将待发送的低频基带信号调制成中高频信号。解调器用于将接收的电磁波信号解调为低频基带信号。随后解调器将解调得到的低频基带信号传送至基带处理器处理。低频基带信号经基带处理器处理后,被传递给应用处理器。应用处理器通过音频设备(不限于扬声器970A,受话器970B等)输出声音信号,或通过显示屏994显示图像或视频。在一些实施例中,调制解调处理器可以是独立的器件。在另一些实施例中,调制解调处理器可以独立于处理器910,与移动通信模块950或其他功能模块设置在同一个器件中。
无线通信模块960可以提供应用在电子设备900上的包括无线局域网(wirelesslocal area networks,WLAN)(如无线保真(wireless fidelity,Wi-Fi)网络),蓝牙(bluetooth,BT),全球导航卫星***(global navigation satellite system,GNSS),调频(frequency modulation,FM),近距离无线通信技术(near field communication,NFC),红外技术(infrared,IR)等无线通信的解决方案。无线通信模块960可以是集成至少一个通信处理模块的一个或多个器件。无线通信模块960经由天线2接收电磁波,将电磁波信号调频以及滤波处理,将处理后的信号发送到处理器910。无线通信模块960还可以从处理器910接收待发送的信号,对其进行调频,放大,经天线2转为电磁波辐射出去。
在一些实施例中,电子设备900的天线1和移动通信模块950耦合,电子设备900的天线2和无线通信模块960耦合,使得电子设备900可以通过无线通信技术与网络和其他电子设备通信。该无线通信技术可以包括以下通信技术中的至少一个:全球移动通讯***(global system for mobile communications,GSM),通用分组无线服务(general packetradio service,GPRS),码分多址接入(code division multiple access,CDMA),宽带码分多址(wideband code division multiple access,WCDMA),时分码分多址(time-divisioncode division multiple access,TD-SCDMA),长期演进(long term evolution,LTE),BT,GNSS,WLAN,NFC,FM,IR技术。该GNSS可以包括以下定位技术中的至少一个:全球卫星定位***(global positioning system,GPS),全球导航卫星***(global navigationsatellite system,GLONASS),北斗卫星导航***(beidou navigation satellitesystem,BDS),准天顶卫星***(quasi-zenith satellite system,QZSS),星基增强***(satellite based augmentation systems,SBAS)。
电子设备900通过GPU,显示屏994,以及应用处理器等实现显示功能。GPU为图像处理的微处理器,连接显示屏994和应用处理器。GPU用于执行数学和几何计算,用于图形渲染。处理器910可包括一个或多个GPU,其执行程序指令以生成或改变显示信息。
显示屏994用于显示图像,视频等。显示屏994包括显示面板。显示面板可以采用液晶显示屏(liquid crystal display,LCD),有机发光二极管(organic light-emittingdiode,OLED),有源矩阵有机发光二极体或主动矩阵有机发光二极体(active-matrixorganic light emitting diode的,AMOLED),柔性发光二极管(flex light-emittingdiode,FLED),Mini-led,Micro-Led,Micro-oLed,量子点发光二极管(quantum dot light-emitting diodes,QLED)等。在一些实施例中,电子设备900可以包括1个或N个显示屏994,N为大于1的正整数。
电子设备900可以通过ISP,摄像头993,视频编解码器,GPU,显示屏994以及应用处理器等实现拍摄功能。
ISP用于处理摄像头993反馈的数据。例如,拍照时,打开快门,光线通过镜头被传递到摄像头感光元件上,光信号转换为电信号,摄像头感光元件将所述电信号传递给ISP处理,转化为肉眼可见的图像。ISP还可以对图像的噪点,亮度,肤色进行算法优化。ISP还可以对拍摄场景的曝光,色温等参数优化。在一些实施例中,ISP可以设置在摄像头993中。
摄像头993用于捕获静态图像或视频。物体通过镜头生成光学图像投射到感光元件。感光元件可以是电荷耦合器件(charge coupled device,CCD)或互补金属氧化物半导体(complementary metal-oxide-semiconductor,CMOS)光电晶体管。感光元件把光信号转换成电信号,之后将电信号传递给ISP转换成数字图像信号。ISP将数字图像信号输出到DSP加工处理。DSP将数字图像信号转换成标准的RGB,YUV等格式的图像信号。在一些实施例中,电子设备900可以包括1个或N个摄像头993,N为大于1的正整数。
数字信号处理器用于处理数字信号,除了可以处理数字图像信号,还可以处理其他数字信号。例如,当电子设备900在频点选择时,数字信号处理器用于对频点能量进行傅里叶变换等。
视频编解码器用于对数字视频压缩或解压缩。电子设备900可以支持一种或多种视频编解码器。这样,电子设备900可以播放或录制多种编码格式的视频,例如:动态图像专家组(moving picture experts group,MPEG)1,MPEG2,MPEG3,MPEG4等。
NPU为神经网络(neural-network,NN)计算处理器,通过借鉴生物神经网络结构,例如借鉴人脑神经元之间传递模式,对输入信息快速处理,还可以不断的自学习。通过NPU可以实现电子设备900的智能认知等应用,例如:图像识别,人脸识别,语音识别,文本理解等。
外部存储器接口920可以用于连接外部存储卡,例如安全数码(secure digital,SD)卡,实现扩展电子设备900的存储能力。外部存储卡通过外部存储器接口120与处理器910通信,实现数据存储功能。例如将音乐,视频等文件保存在外部存储卡中。
内部存储器921可以用于存储计算机可执行程序代码,所述可执行程序代码包括指令。处理器910通过运行存储在内部存储器921的指令,从而执行电子设备900的各种功能应用以及数据处理。内部存储器921可以包括存储程序区和存储数据区。其中,存储程序区可存储操作***,至少一个功能所需的应用程序(比如声音播放功能,图像播放功能等)等。存储数据区可存储电子设备900使用过程中所创建的数据(比如音频数据,电话本等)等。此外,内部存储器921可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件,闪存器件,通用闪存存储器(universal flash storage,UFS)等。
电子设备900可以通过音频模块970,扬声器970A,受话器970B,麦克风970C,耳机接口970D,以及应用处理器等实现音频功能。例如,音乐播放,录音等。
音频模块970用于将数字音频信息转换成模拟音频信号输出,也用于将模拟音频输入转换为数字音频信号。音频模块970还可以用于对音频信号编码和解码。在一些实施例中,音频模块970可以设置于处理器910中,或将音频模块970的部分功能模块设置于处理器910中。
扬声器970A,也称“喇叭”,用于将音频电信号转换为声音信号。电子设备900可以通过扬声器970A收听音乐,或收听免提通话。
受话器970B,也称“听筒”,用于将音频电信号转换成声音信号。当电子设备900接听电话或语音信息时,可以通过将受话器970B靠近人耳接听语音。
麦克风970C,也称“话筒”,“传声器”,用于将声音信号转换为电信号。当拨打电话或发送语音信息时,用户可以通过人嘴靠近麦克风970C发声,将声音信号输入到麦克风970C。电子设备900可以设置至少一个麦克风970C。在另一些实施例中,电子设备900可以设置两个麦克风970C,除了采集声音信号,还可以实现降噪功能。在另一些实施例中,电子设备900还可以设置三个,四个或更多麦克风970C,实现采集声音信号,降噪,还可以识别声音来源,实现定向录音功能等。
耳机接口970D用于连接有线耳机。耳机接口970D可以是USB接口930,也可以是3.5mm的开放移动电子设备平台(open mobile terminal platform,OMTP)标准接口,美国蜂窝电信工业协会(cellular telecommunications industry association of the USA,CTIA)标准接口。
压力传感器980A用于感受压力信号,可以将压力信号转换成电信号。在一些实施例中,压力传感器980A可以设置于显示屏994。压力传感器980A的种类很多,如电阻式压力传感器,电感式压力传感器,电容式压力传感器等。电容式压力传感器可以是包括至少两个具有导电材料的平行板。当有力作用于压力传感器980A,电极之间的电容改变。电子设备900根据电容的变化确定压力的强度。当有触摸操作作用于显示屏994,电子设备900根据压力传感器980A检测所述触摸操作强度。电子设备900也可以根据压力传感器980A的检测信号计算触摸的位置。在一些实施例中,作用于相同触摸位置,但不同触摸操作强度的触摸操作,可以对应不同的操作指令。例如,当有触摸操作强度小于第一压力阈值的触摸操作作用于短消息应用图标时,执行查看短消息的指令。当有触摸操作强度大于或等于第一压力阈值的触摸操作作用于短消息应用图标时,执行新建短消息的指令。
陀螺仪传感980B可以用于确定电子设备900的运动姿态。在一些实施例中,可以通过陀螺仪传感器980B确定电子设备900围绕三个轴(即x,y和z轴)的角速度。陀螺仪传感器980B可以用于拍摄防抖。示例性地,当按下快门,陀螺仪传感器980B检测电子设备900抖动的角度,根据角度计算出镜头模组需要补偿的距离,让镜头通过反向运动抵消电子设备900的抖动,实现防抖。陀螺仪传感器980B还可以用于导航,体感游戏场景。
气压传感器980C用于测量气压。在一些实施例中,电子设备900通过气压传感器980C测得的气压值计算海拔高度,辅助定位和导航。
磁传感器980D包括霍尔传感器。电子设备900可以利用磁传感器980D检测翻盖皮套的开合。在一些实施例中,当电子设备900是翻盖机时,电子设备900可以根据磁传感器980D检测翻盖的开合;根据检测到的皮套的开合状态或翻盖的开合状态,设置翻盖自动解锁等特性。
加速度传感器980E可检测电子设备900在各个方向上(一般为三轴)加速度的大小。当电子设备900静止时可检测出重力的大小及方向。还可以用于识别电子设备姿态,应用于横竖屏切换,计步器等应用。
距离传感器980F用于测量距离。电子设备900可以通过红外或激光测量距离。在一些实施例中,拍摄场景,电子设备900可以利用距离传感器980F测距以实现快速对焦。
接近光传感器980G可以包括例如发光二极管(light-emitting diode,LED)和光检测器,例如光电二极管。发光二极管可以是红外发光二极管。电子设备900通过发光二极管向外发射红外光。电子设备900使用光电二极管检测来自附近物体的红外反射光。当检测到充分的反射光时,可以确定电子设备900附近有物体。当检测到不充分的反射光时,电子设备900可以确定电子设备900附近没有物体。电子设备900可以利用接近光传感器980G检测用户手持电子设备900贴近耳朵通话,以便自动熄灭屏幕达到省电的目的。接近光传感器980G也可用于皮套模式,口袋模式自动解锁与锁屏。
环境光传感器980L用于感知环境光亮度。电子设备900可以根据感知的环境光亮度自适应调节显示屏994亮度。环境光传感器980L也可用于拍照时自动调节白平衡。环境光传感器980L还可以与接近光传感器980G配合,检测电子设备900是否在口袋里,以防误触。
指纹传感器980H用于采集指纹。电子设备900可以利用采集的指纹特性实现指纹解锁,访问应用锁,指纹拍照,指纹接听来电等。
温度传感器980J用于检测温度。在一些实施例中,电子设备900利用温度传感器980J检测的温度,执行温度处理策略。例如,当温度传感器980J上报的温度超过阈值,电子设备900执行降低位于温度传感器980J附近的处理器的性能,以便降低功耗实施热保护。在另一些实施例中,当温度低于另一阈值时,电子设备900对电池942加热,以避免低温导致电子设备900异常关机。在其他一些实施例中,当温度低于又一阈值时,电子设备900对电池942的输出电压执行升压,以避免低温导致的异常关机。
触摸传感器980K,也称“触控面板”。触摸传感器980K可以设置于显示屏994,由触摸传感器980K与显示屏994组成触摸屏,也称“触控屏”。触摸传感器980K用于检测作用于其上或附近的触摸操作。触摸传感器可以将检测到的触摸操作传递给应用处理器,以确定触摸事件类型。可以通过显示屏994提供与触摸操作相关的视觉输出。在另一些实施例中,触摸传感器980K也可以设置于电子设备900的表面,与显示屏994所处的位置不同。
骨传导传感器980M可以获取振动信号。在一些实施例中,骨传导传感器980M可以获取人体声部振动骨块的振动信号。骨传导传感器980M也可以接触人体脉搏,接收血压跳动信号。在一些实施例中,骨传导传感器980M也可以设置于耳机中,结合成骨传导耳机。音频模块970可以基于所述骨传导传感器980M获取的声部振动骨块的振动信号,解析出语音信号,实现语音功能。应用处理器可以基于所述骨传导传感器980M获取的血压跳动信号解析心率信息,实现心率检测功能。
按键990包括开机键,音量键等。按键990可以是机械按键。也可以是触摸式按键。电子设备900可以接收按键输入,产生与电子设备900的用户设置以及功能控制有关的键信号输入。
马达991可以产生振动提示。马达991可以用于来电振动提示,也可以用于触摸振动反馈。例如,作用于不同应用(例如拍照,音频播放等)的触摸操作,可以对应不同的振动反馈效果。作用于显示屏994不同区域的触摸操作,马达991也可对应不同的振动反馈效果。不同的应用场景(例如:时间提醒,接收信息,闹钟,游戏等)也可以对应不同的振动反馈效果。触摸振动反馈效果还可以支持自定义。
指示器992可以是指示灯,可以用于指示充电状态,电量变化,也可以用于指示消息,未接来电,通知等。
SIM卡接口995用于连接SIM卡。SIM卡可以通过***SIM卡接口995,或从SIM卡接口995拔出,实现和电子设备900的接触和分离。电子设备900可以支持1个或N个SIM卡接口,N为大于1的正整数。SIM卡接口995可以支持Nano SIM卡,Micro SIM卡,SIM卡等。同一个SIM卡接口995可以同时***多张卡。所述多张卡的类型可以相同,也可以不同。SIM卡接口995也可以兼容不同类型的SIM卡。SIM卡接口995也可以兼容外部存储卡。电子设备900通过SIM卡和网络交互,实现通话以及数据通信等功能。在一些实施例中,电子设备900采用eSIM,即:嵌入式SIM卡。eSIM卡可以嵌在电子设备900中,不能和电子设备900分离。
电子设备900的软件***可以采用分层架构,事件驱动架构,微核架构,微服务架构,或云架构。
需要说明的是,上述装置/单元之间的信息交互、执行过程等内容,由于与本申请方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述***中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
本申请实施例还提供了一种电子设备,该电子设备包括:至少一个处理器、存储器以及存储在所述存储器中并可在所述至少一个处理器上运行的计算机程序,所述处理器执行所述计算机程序时可实现上述任意方法中的步骤。
本申请实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现可实现上述各个方法实施例中的步骤。
本申请实施例提供了一种计算机程序产品,该计算机程序产品包括计算机程序,当计算机程序被处理器执行时可实现上述各个方法实施例中的步骤。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质至少可以包括:能够将计算机程序代码携带到拍照装置/电子设备的任何实体或装置、记录介质、计算机存储器、只读存储器(read-only memory,ROM)、随机存取存储器(random accessmemory,RAM)、电载波信号、电信信号以及软件分发介质。例如U盘、移动硬盘、磁碟或者光盘等。在某些司法管辖区,根据立法和专利实践,计算机可读介质不可以是电载波信号和电信信号。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/设备实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个***,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。

Claims (10)

1.一种预读方法,其特征在于,包括:
通过遍历的方式设置第一挂载设备的第一预读参数阈值,所述第一挂载设备为预读操作对应的挂载设备;
监控第一挂载设备的第一预读参数阈值,使得所述第一挂载设备的第一预读参数阈值不被修改;
获取***的压力阻塞信息PSI;
根据所述PSI,确定***的***资源压力;所述***资源压力包括内存压力或IO压力中的至少一项;
根据所述***资源压力和所述第一挂载设备的第一预读参数阈值,确定所述第一挂载设备的目标预读窗口大小;所述第一预读参数阈值包括第一内存压力阈值或第一IO压力阈值中的至少一项;
所述根据所述***资源压力和所述第一挂载设备的第一预读参数阈值,确定所述第一挂载设备的目标预读窗口大小,包括:
当所述IO压力小于IO压力阈值时,确定所述目标预读窗口大小为原预读窗口大小,所述IO压力阈值小于或等于所述第一IO压力阈值;或者,
当所述IO压力大于或等于所述IO压力阈值且所述内存压力小于内存压力阈值时,根据预读窗口的需求大小req_size和挂载设备的最大IO大小io_size,确定所述目标预读窗口大小,所述内存压力阈值小于或等于所述第一内存压力阈值,所述IO压力阈值小于或等于所述第一IO压力阈值;或者,
当所述IO压力大于或等于所述IO压力阈值且所述内存压力大于或等于所述内存压力阈值时,确定所述目标预读窗口大小小于所述原预读窗口大小,所述内存压力阈值小于或等于所述第一内存压力阈值,所述IO压力阈值小于或等于所述第一IO压力阈值。
2.根据权利要求1所述的方法,其特征在于,所述监控第一挂载设备的所述第一预读参数阈值,使得所述第一挂载设备的所述第一预读参数阈值不被修改,包括:
周期性读取所述第一挂载设备的第二预读参数阈值,所述第二预读参数阈值用于表示周期性读取到的所述第一挂载设备的预读参数阈值;
判断所述第一挂载设备的所述第二预读参数阈值与所述第一预读参数阈值是否一致;
当判断结果为不一致时,将所述第一挂载设备的所述第二预读参数阈值修改为与所述第一预读参数阈值相同。
3.根据权利要求1所述的方法,其特征在于,所述预读窗口的req_size是根据按需预读策略确定的;所述按需预读策略包括根据缺失miss值和命中hit值确定所述req_size为所述原预读窗口大小的2的N次幂倍,N为大于或等于零的整数。
4.根据权利要求1所述的方法,其特征在于,所述当所述IO压力大于或等于所述IO压力阈值且所述内存压力小于所述内存压力阈值时,根据预读窗口的需求大小req_size和挂载设备的最大IO大小,确定所述目标预读窗口大小,所述内存压力阈值小于或等于所述第一内存压力阈值,所述IO压力阈值小于或等于所述第一IO压力阈值,包括:
当所述预读窗口的req_size小于所述io_size时,确定所述目标预读窗口大小为所述原预读窗口大小和所述io_size中的较小值;或者,
当所述预读窗口的req_size大于或等于所述io_size时,确定所述目标预读窗口大小大于所述原预读窗口大小。
5.根据权利要求1至4中任一项所述的方法,其特征在于,所述根据所述PSI,确定***的***资源压力,包括:
根据所述PSI,确定任务阻塞时间在整个统计时间周期内的占比,所述任务阻塞时间包括部分任务阻塞的时间和所有任务同时阻塞的时间;
根据所述任务阻塞时间在整个统计时间周期内的占比与占比阈值之间的关系,确定所述***资源压力。
6.根据权利要求1至4中任一项所述的方法,其特征在于,所述第一预读参数阈值包括第一预读窗口大小阈值,所述目标预读窗口大小小于或等于所述第一预读窗口大小阈值。
7.一种预读装置,其特征在于,包括:
设置单元,用于通过遍历的方式设置第一挂载设备的第一预读参数阈值,以及用于监控第一挂载设备的第一预读参数阈值,使得所述第一挂载设备的第一预读参数阈值不被修改,所述第一挂载设备为预读操作对应的挂载设备;
获取单元,用于获取***的压力阻塞信息PSI;
处理单元,用于根据所述PSI,确定***的***资源压力,以及用于根据所述***资源压力和所述第一挂载设备的所述第一预读参数阈值,确定所述第一挂载设备的目标预读窗口大小;所述第一预读参数阈值包括第一内存压力阈值或第一IO压力阈值中的至少一项;所述***资源压力包括内存压力或IO压力中的至少一项;
所述处理单元具体用于,当所述IO压力小于IO压力阈值时,确定所述目标预读窗口大小为原预读窗口大小,所述IO压力阈值小于或等于所述第一IO压力阈值;或者,
当所述IO压力大于或等于所述IO压力阈值且所述内存压力小于内存压力阈值时,根据预读窗口的需求大小req_size和挂载设备的最大IO大小io_size,确定所述目标预读窗口大小,所述内存压力阈值小于或等于所述第一内存压力阈值,所述IO压力阈值小于或等于所述第一IO压力阈值;或者,
当所述IO压力大于或等于所述IO压力阈值且所述内存压力大于或等于所述内存压力阈值时,确定所述目标预读窗口大小小于所述原预读窗口大小,所述内存压力阈值小于或等于所述第一内存压力阈值,所述IO压力阈值小于或等于所述第一IO压力阈值。
8.根据权利要求7所述的装置,其特征在于,所述设置单元具体用于:
周期性读取所述第一挂载设备的第二预读参数阈值,所述第二预读参数阈值用于表示周期性读取到的所述第一挂载设备的预读参数阈值;
判断所述第一挂载设备的所述第二预读参数阈值与所述第一预读参数阈值是否一致;
当判断结果为不一致时,将所述第一挂载设备的所述第二预读参数阈值修改为与所述第一预读参数阈值相同。
9.一种电子设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至6中任一项所述的方法。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至6中任一项所述的方法。
CN202310032749.3A 2023-01-10 2023-01-10 预读方法和预读装置 Active CN117130952B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310032749.3A CN117130952B (zh) 2023-01-10 2023-01-10 预读方法和预读装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310032749.3A CN117130952B (zh) 2023-01-10 2023-01-10 预读方法和预读装置

Publications (2)

Publication Number Publication Date
CN117130952A CN117130952A (zh) 2023-11-28
CN117130952B true CN117130952B (zh) 2024-06-21

Family

ID=88851502

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310032749.3A Active CN117130952B (zh) 2023-01-10 2023-01-10 预读方法和预读装置

Country Status (1)

Country Link
CN (1) CN117130952B (zh)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112445725A (zh) * 2019-08-27 2021-03-05 华为技术有限公司 预读取文件页的方法、装置和终端设备

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4107083B2 (ja) * 2002-12-27 2008-06-25 株式会社日立製作所 高可用ディスク制御装置とその障害処理方法及び高可用ディスクサブシステム
CN104040634A (zh) * 2012-01-12 2014-09-10 索尼公司 存储控制装置、存储装置、信息处理***及其处理方法
JP2013218505A (ja) * 2012-04-09 2013-10-24 Hitachi Ltd クライアントとサーバ間の通信を中継する通信装置及び通信システム
US9753669B2 (en) * 2014-05-13 2017-09-05 Velostrata Ltd. Real time cloud bursting
CN106681939B (zh) * 2017-01-03 2019-08-23 北京华胜信泰数据技术有限公司 磁盘页面的读取方法和装置
CN114168065B (zh) * 2020-09-10 2024-05-31 荣耀终端有限公司 调整内存配置参数的方法和装置
CN114461588B (zh) * 2021-08-20 2023-01-24 荣耀终端有限公司 调节预读窗口的方法及电子设备
CN113760192B (zh) * 2021-08-31 2022-09-02 荣耀终端有限公司 数据读取方法、装置、存储介质和程序产品

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112445725A (zh) * 2019-08-27 2021-03-05 华为技术有限公司 预读取文件页的方法、装置和终端设备

Also Published As

Publication number Publication date
CN117130952A (zh) 2023-11-28

Similar Documents

Publication Publication Date Title
CN113395382B (zh) 一种设备间数据交互的方法及相关设备
WO2021190314A1 (zh) 触控屏的滑动响应控制方法及装置、电子设备
CN114422340B (zh) 日志上报方法、电子设备及存储介质
CN111552451A (zh) 显示控制方法及装置、计算机可读介质及终端设备
EP4181016A1 (en) Image processing method, electronic device, image processing system and chip system
CN114490174B (zh) 文件***检测方法、电子设备及计算机可读存储介质
CN114880251B (zh) 存储单元的访问方法、访问装置和终端设备
CN114554012B (zh) 来电接听方法、电子设备及存储介质
CN116389884B (zh) 缩略图显示方法及终端设备
CN116055859B (zh) 图像处理方法和电子设备
CN116048831B (zh) 一种目标信号处理方法和电子设备
CN116048772B (zh) 中央处理单元频率的调整方法、装置和终端设备
CN113542574A (zh) 变焦下的拍摄预览方法、终端、存储介质及电子设备
CN114466238B (zh) 帧解复用方法、电子设备及存储介质
CN117130952B (zh) 预读方法和预读装置
CN116661984B (zh) 一种负载管控方法、电子设备及存储介质
CN116775419B (zh) 文件***的监视方法和装置
CN116723384B (zh) 进程的控制方法、电子设备及可读存储介质
CN113672454B (zh) 冻屏监控方法、电子设备及计算机可读存储介质
CN116048769B (zh) 内存回收方法、装置和终端设备
CN114362878B (zh) 数据处理方法及电子设备
WO2023237087A1 (zh) 易孕期的预测方法、装置和电子设备
CN118331641A (zh) 指令存储***、指令存储方法、指令读取方法及电子设备
CN118057858A (zh) 数据处理方法、设备和***
CN116449942A (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