Nothing Special   »   [go: up one dir, main page]

CN107436839B - Process load acquisition method, electronic terminal and computer readable storage medium - Google Patents

Process load acquisition method, electronic terminal and computer readable storage medium Download PDF

Info

Publication number
CN107436839B
CN107436839B CN201710580205.5A CN201710580205A CN107436839B CN 107436839 B CN107436839 B CN 107436839B CN 201710580205 A CN201710580205 A CN 201710580205A CN 107436839 B CN107436839 B CN 107436839B
Authority
CN
China
Prior art keywords
event
processor
description information
switching
information
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
CN201710580205.5A
Other languages
Chinese (zh)
Other versions
CN107436839A (en
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.)
Guangdong Oppo Mobile Telecommunications Corp Ltd
Original Assignee
Guangdong Oppo Mobile Telecommunications 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 Guangdong Oppo Mobile Telecommunications Corp Ltd filed Critical Guangdong Oppo Mobile Telecommunications Corp Ltd
Priority to CN201710580205.5A priority Critical patent/CN107436839B/en
Publication of CN107436839A publication Critical patent/CN107436839A/en
Application granted granted Critical
Publication of CN107436839B publication Critical patent/CN107436839B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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/3409Recording 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 for performance assessment
    • G06F11/3433Recording 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 for performance assessment for load management
    • 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)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Debugging And Monitoring (AREA)

Abstract

The embodiment of the invention discloses a process load obtaining method, which is applied to the technical field of computers and comprises the following steps: acquiring description information of a process switching event occurring in a preset time length and description information of a processor frequency change event; obtaining the execution time of the process switched and executed in the preset duration under different frequencies of the processor according to the description information of the process switching event and the description information of the processor frequency change event; and taking the sum of the products of each execution time and the different frequencies of the corresponding processors as the total load of the process of the switching execution within the preset duration, and outputting the total load. The embodiment of the invention also discloses an electronic terminal and a computer readable storage medium, which can obtain more accurate process load information under the dynamic frequency conversion environment.

Description

Process load acquisition method, electronic terminal and computer readable storage medium
Technical Field
The invention belongs to the technical field of computers, and particularly relates to a process load obtaining method, an electronic terminal and a computer readable storage medium.
Background
With the development of computer technology, electronic terminal devices such as smart phones, tablet computers and desktop computers play an increasingly higher role in life of people. In order to save energy consumption of the electronic terminal device, the operating system needs to be able to dynamically adjust the operating frequency of a Central Processing Unit (CPU) according to the actual change condition of the process load, for example, when the load is lifted, the operating frequency of the CPU is raised; when the load decreases, the operating frequency of the CPU is lowered. Therefore, whether the load of the process can be accurately acquired is important for dynamically adjusting the working frequency of the CPU. The load of a process is the amount of computation of the process.
The existing CPU working frequency adjusting technology mainly calculates the operation amount of the pid process by analyzing the output information of/proc/pid/stat nodes, and can accurately acquire the operation amount of the process in a fixed frequency environment. However, in a dynamic frequency conversion environment, because the execution time of the process is stored in the/proc/pid/stat node, and the running speed of the CPU is constantly changing, the technique cannot accurately calculate the computation amount of the process according to the execution time of the process.
Disclosure of Invention
The invention provides a process load obtaining method, an electronic terminal and a computer readable storage medium, which can obtain more accurate information of process load under a dynamic frequency conversion environment.
A first aspect of an embodiment of the present invention provides a method for acquiring a process load, including: acquiring description information of a process switching event occurring in a preset time length and description information of a processor frequency change event; obtaining the execution time of the process switched and executed in the preset duration under different frequencies of the processor according to the description information of the process switching event and the description information of the processor frequency change event; and taking the sum of the products of each execution time and different frequencies of the corresponding processor as the total load of the process of the switching execution in the preset duration, and outputting the total load.
A second aspect of an embodiment of the present invention provides an electronic terminal, including: the system comprises a description information acquisition module, a processor frequency change module and a processing module, wherein the description information acquisition module is used for acquiring description information of a process switching event and description information of a processor frequency change event which occur in a preset time length; the execution time acquisition module is used for acquiring the execution time of the process switched and executed in the preset duration under different frequencies of the processor according to the description information of the process switching event and the description information of the processor frequency change event; a total load obtaining module, configured to use a sum of products of each execution time and different frequencies of the corresponding processor as a total load of the process of the handover execution within the preset duration; and the output module is used for outputting the total load.
A third aspect of an embodiment of the present invention provides an electronic terminal, including: the process load obtaining method provided by the first aspect of the embodiments of the present invention is implemented when the processor executes the computer program.
A fourth aspect of the embodiments of the present invention provides a computer-readable storage medium, on which a computer program is stored, where the computer program, when executed by a processor, implements the method for acquiring a process load provided in the first aspect of the embodiments of the present invention.
In the process load obtaining method, the electronic terminal, and the computer readable storage medium according to the embodiments of the present invention, the sum of products of each execution time of the process switched and executed in the preset time and different frequencies of the corresponding processor is used as the total load of the process switched and executed in the preset time.
Drawings
In order to more clearly illustrate the embodiments of the present invention or the technical solutions in the prior art, the drawings used in the description of the embodiments or the prior art will be briefly described below, and it is obvious that the drawings in the following description are only some embodiments of the present invention.
Fig. 1 is a schematic flow chart illustrating an implementation process of a process load obtaining method according to an embodiment of the present invention;
fig. 2 is a schematic flow chart illustrating an implementation of a process load obtaining method according to another embodiment of the present invention;
FIG. 3 is a diagram of a first linked list in the process load obtaining method shown in FIG. 2;
FIG. 4 is a diagram of a second linked list in the process load obtaining method shown in FIG. 2;
fig. 5 is a schematic structural diagram of an electronic terminal according to an embodiment of the present invention;
fig. 6 is a schematic structural diagram of an electronic terminal according to another embodiment of the present invention;
fig. 7 is a hardware structure diagram of an electronic terminal according to an embodiment of the present invention.
Detailed Description
In order to make the objects, features and advantages of the present invention more obvious and understandable, the technical solutions in the embodiments of the present invention will be clearly and completely described below with reference to the accompanying drawings in the embodiments of the present invention, and it is apparent that the described embodiments are only a part of the embodiments of the present invention, and not all of the embodiments. All other embodiments, which can be derived by a person skilled in the art from the embodiments given herein without making any creative effort, shall fall within the protection scope of the present invention.
Referring to fig. 1, fig. 1 is a schematic diagram illustrating an implementation flow of a process load obtaining method according to an embodiment of the present invention, where the method is applicable to an electronic terminal, and the electronic terminal includes: the mobile electronic data processing device comprises an electronic data processing device such as a smart phone, a tablet computer and a notebook computer, which can be used in a mobile manner, and other electronic data processing devices which can not be used in a mobile manner, such as a desktop computer. As shown in fig. 1, the method mainly comprises the following steps:
s101, obtaining description information of a process switching event occurring in a preset time length and description information of a processor frequency change event;
specifically, when a load acquisition command input by a user is received, the time length information in the load acquisition command is used as a preset time length, and step S101 to step S103 are executed.
As an actual application example, the superstate command may be customized to trigger the execution of steps S101 to S103. Taking a mobile phone as an example, firstly installing an adb (Android Debug Bridge) environment in the mobile phone, enabling a user to enter a mobile phone terminal through an adb command, and then executing a super command to obtain a load (i.e., an operand) of each process of the system, where relevant parameters are described as follows:
d test duration (in seconds)
M number of output processes (ranking by operand, outputting the top m process information)
The following may be done, for example, based on user input: the command of super-state-d 30-m 100 triggers execution of step S101 to step S103.
It should be noted that the superstate command is only an example, and in practical applications, the superstate command may be other commands named by other names with the same function.
Optionally, the system may also automatically trigger execution of steps S101 to S103 according to a preset trigger time when the trigger time is reached.
The description information of the process switching event occurring within the preset duration is used to describe what process is switched at what time and what process is executed within the preset test duration, and may include, but is not limited to: the method comprises the steps of generating process switching events, wherein the process switching events are carried out in a preset test duration, and the process switching events are related to process identification information, process switching time stamps and processor identification information occupied by processes executed before switching. The identification information of the process related to each process switching event comprises identification information of the process before switching and identification information of the process after switching. Identification information of a process is information that can be used to uniquely identify the identity of the process, such as: process name and process number.
The description information of the frequency change event of the processor occurring within the preset time period is used to describe what change occurs in the frequency of which processor within the preset test time period, and may include, but is not limited to: the method comprises the steps of presetting identification information of a processor with changed frequency, a timestamp of the changed frequency and the changed frequency of the processor, wherein the frequency is related to each processor frequency change event occurring in a test duration. Wherein the identification information of the processor is identification information that can be used to uniquely identify the processor, such as: the number of the processor.
The frequency in this embodiment refers to the operating frequency of the processor. The processor in this embodiment includes: a CPU, a Graphics Processing Unit (GPU), and other processors having a frequency conversion function.
S102, obtaining the execution time of the process switched and executed in the preset duration under different frequencies of the processor according to the description information of the process switching event and the description information of the processor frequency change event;
and obtaining the execution time of each process related to all process switching events occurring in the preset test duration under different frequencies of the processor according to the description information of the process switching events and the description information of the processor frequency change events. Wherein the processor is not limited to one. For example: the execution time of process a at the first frequency of processor a, the execution time at the second frequency of processor a, the execution time at the first frequency of processor B, and so on.
The execution time may be obtained according to the timestamp in the description information and the identification information of the process, or the description information may directly include information of the execution time of the process that is switched to be executed.
And S103, taking the sum of the products of each execution time of the switched and executed process and different frequencies of the corresponding processor as the total load of the switched and executed process in the preset duration, and outputting the total load.
In the embodiment of the invention, the sum of the products of each execution time of the process switched and executed in the preset duration and the different frequencies of the corresponding processor is used as the total load of the process switched and executed in the preset duration, and the total load is calculated according to the different frequency changes of the processor, so that the actual change condition of the load of the process in the dynamic frequency conversion environment is met, and more effective reference can be provided for user software and process load analysis and behavior analysis in the frequency conversion environment.
Referring to fig. 2, fig. 2 is a schematic view of an implementation flow of a process load obtaining method according to another embodiment of the present invention, where the method is applicable to an electronic terminal, and the electronic terminal includes: the mobile electronic data processing device comprises an electronic data processing device such as a smart phone, a tablet computer and a notebook computer, which can be used in a mobile manner, and other electronic data processing devices which can not be used in a mobile manner, such as a desktop computer. As shown in fig. 2, the method mainly includes the following steps:
s201, acquiring original information of a process switching event and original information of a processor frequency change event in a preset duration through an ftrace debugging tool;
specifically, when a load obtaining command input by a user is received, the time length information in the load obtaining command is used as a preset time length, and the steps in the embodiment are executed.
As an actual application example, the superstate command can be customized to trigger the execution of the steps in the present embodiment. Taking a mobile phone as an example, firstly installing an adb (Android Debug Bridge) environment in the mobile phone, enabling a user to enter a mobile phone terminal through an adb command, and then executing a super command to obtain a load (i.e., an operand) of each process of the system, where relevant parameters are described as follows:
d test duration (in seconds)
M number of output processes (ranking by operand, outputting the top m process information)
The following may be done, for example, based on user input: the command of super-state-d 30-m 100 triggers the execution of the steps in the present embodiment.
It should be noted that the superstate command is only an example, and in practical applications, the superstate command may be other commands named by other names with the same function.
Optionally, the system may also automatically trigger to execute each step in this embodiment according to a preset trigger time when the trigger time is reached.
ftrace is a debugging tool based on a linux system, for example, a CPU is used, a process switching event can be acquired through a ftrace-scheduled _ switch event, and a frequency change event of the CPU can be acquired through a ftrace-CPU _ frequency event. The original information of the sched _ switch event can be shown as follows:
Figure BDA0001352065120000061
the original information of the cpu _ frequency event may be, for example, as follows:
cfinteractive-74[001]...1 302.072082:cpu_frequency:state=819000cpu_id=0
cfinteractive-74[001]...1 302.072104:cpu_frequency:state=819000 cpu_id=1
cfinteractive-74[001]...1 302.072118:cpu_frequency:state=819000 cpu_id=2
cfinteractive-74[001]...1 302.072133:cpu_frequency:state=819000 cpu_id=3
s202, analyzing original information of a process switching event and original information of a processor frequency change event to obtain description information of the process switching event and description information of the processor frequency change event;
analyzing the original information of the process switching event to obtain the identification information of the process before switching, the identification information of the process after switching, the timestamp for generating process switching and the identification information of the processor occupied by the process executed before switching in the original information as the description information of the process switching event. Wherein the identification information of the process includes: process name and process number.
Analyzing the original information of the processor frequency change event to obtain the identification information of the processor with changed frequency, the timestamp with changed frequency and the changed frequency in the original information as the description information of the processor frequency change event. Wherein the identification information of the processor includes a number of the processor. The frequency in this embodiment refers to the operating frequency of the processor. The processor in this embodiment includes: and all processors with frequency conversion functions, such as a CPU (central processing unit), a GPU (graphic processing unit) and the like.
S203, taking each process switching event and each processor frequency changing event as an event object, and taking the description information of the process switching event or the processor frequency changing event corresponding to the event object as the description information of the event object;
in the parsing process, each event including a process switching event and a processor frequency change event is described by using 1 event object (hereinafter, referred to as an event _ info object), and the description information of the process switching event or the processor frequency change event corresponding to each event object is the description information of the event object. In practical applications, taking a CPU as an example, the pseudo code of the event _ info object can be described as follows:
Figure BDA0001352065120000071
Figure BDA0001352065120000081
the pseudo code is used for recording the description information of the event object, wherein the intent _ type in struct event _ info is used for identifying whether the description information recorded in the section of code corresponds to a process switching event or a processor frequency change event. The description information of the two events is not recorded in the same pseudo code at the same time.
Int CPU and struct time event _ time in struct event _ info are consistent with CPU number and timestamp in description information of the specific event identified by int event _ type.
S204, storing each event object in a preset first linked list according to the sequence of the timestamps in the description information of the event objects;
and adding all event _ info objects into a preset first linked list according to the sequence of the timestamps.
In order to make the organization form clearer and improve the processing efficiency, optionally, a sub-chain table is respectively created for each processor, all event _ info objects corresponding to each processor are stored in the sub-chain table corresponding to each processor according to the sequence of timestamps in the description information of the event _ info objects, and the plurality of sub-chain tables together form the first chain table. Taking a CPU as an example, the first linked list may be composed of X sub-linked lists as shown in fig. 3, and each sub-linked list corresponds to CPU-1 to CPU-X, respectively.
S205, identifying the description information of each event object in the first linked list to obtain the execution time of each switching execution process in the preset duration under different frequencies of the processor;
the execution time can be identified according to the timestamp in the description information of each event object and the identification information of the process. For example: the description information of the event object a stored in the child link corresponding to the CPU1 is assumed to be: the timestamp of the process switching event is 1705, the process number before switching is 1, and the process number after switching is 2; the description information of the event object B is: the timestamp of the occurrence of the process switch event is 1707, the process number before switching is 2, and the process number after switching is 3. Since the number of the process after the switching in the event object a is 2, the number of the process before the switching in the event object B is 2, and the event objects a and B are consecutive, the time difference between the time stamp 1707 of the event object B and the time stamp 1705 of the event object a can be identified as the execution time X of the process with the process number of 2. Then, based on the time stamp 1705, an event object corresponding to the processor frequency change event matching the time stamp is searched for in the child link, and based on the description information of the event object, the operating frequency of the CPU1 corresponding to the execution time X of the process with the process number 2 can be identified.
Optionally, considering that all event _ info objects are added to the first linked list according to the sequence of the timestamps, which has a high requirement on the memory, in order to configure a lower terminal, the step of analyzing the original information of the process switching event and the original information of the processor frequency change event to obtain the description information of the process switching event and the description information of the processor frequency change event may be performed in groups according to a preset event information processing number, and the step of identifying the description information of each event object in the first linked list to obtain the execution time of the process to be switched and executed at different frequencies of the processor until the execution time of all the processes to be switched and executed at different frequencies of the processor is obtained. That is, the above steps S202 to S205 are performed in groups until the execution time of all the processes of the handover execution at different frequencies of the processor is obtained. For example: assuming that there are 200 events in total, 50 events can be grouped into one group, the 200 events are grouped into four groups, the steps S202 to S205 are respectively executed on the first group of 50 events to obtain the execution time of the process switched and executed in the first group of 50 events under different frequencies of the processor, then the steps S202 to S205 are respectively executed on the second group of 50 events to obtain the execution time of the process switched and executed in the second group of 50 events under different frequencies of the processor, and the process is cycled until the execution time of all the processes switched and executed in the 200 events under different frequencies of the processor is obtained.
S206, taking the sum of the products of each execution time of the process of the switching execution and different frequencies of the corresponding processor as the total load of the process of the switching execution within a preset time length, and recording the total load and the identification information of the process of the switching execution as the description information of the corresponding process object;
specifically, the total load of each handover execution process within the preset time period can be obtained through the following formula.
Figure BDA0001352065120000101
Wherein L oad refers to handover executionTotal load of the line process, FreqiIs the frequency, time, of the processoriI is the execution time of the process of the switching execution at the frequency, and i is the number of the event object.
Optionally, before recording the total load and the identification information of the process executed by switching as the description information of the corresponding process object (proc _ info object), it is determined whether the process executed by switching has the corresponding process object. And if no corresponding process object exists, creating a corresponding process object for the process executed by switching, and then recording the total load and the identification information of the process executed by switching as the description information of the created process object. And if the corresponding process object exists, updating the total load obtained by calculation into the total load in the description information of the corresponding process object.
S207, storing the process objects in a preset second linked list, and sequencing the process objects in the second linked list according to the sequence of the total load from large to small;
all proc _ info objects are saved in a preset second linked list, which may be as shown in fig. 4. And then sequencing the process objects in the second linked list according to the size of the total load described in the description information of the process objects and the sequence from large to small, and finally obtaining a linked list with the load from large to small.
And S208, outputting the description information of the process object with the preset place before the ranking on the second linked list.
The number of the output process objects can be determined according to the value of the number parameter m in the super state command, or according to a system default value preset by a user. The output description information includes identification information of the process and a load of the process. Wherein the identification information of the process includes a process number and a process name.
In the embodiment of the invention, the sum of the products of each execution time of the process switched and executed in the preset duration and the different frequencies of the corresponding processor is used as the total load of the process switched and executed in the preset duration, and the total load is calculated based on the different frequency changes of the processor, so that the actual change condition of the load of the process in the dynamic frequency conversion environment is met, and more effective reference can be provided for user software and process load analysis and behavior analysis in the frequency conversion environment.
Referring to fig. 5, fig. 5 is a schematic structural diagram of an electronic terminal according to an embodiment of the present invention, and for convenience of description, only the portions related to the embodiment of the present invention are shown. The electronic terminal illustrated in fig. 5 may be an execution subject of the process load obtaining method provided in the foregoing embodiment illustrated in fig. 1. The electronic terminal illustrated in fig. 5 mainly includes:
the description information obtaining module 501 is configured to obtain description information of a process switching event occurring within a preset time length and description information of a processor frequency change event.
An execution time obtaining module 502, configured to obtain, according to the description information of the process switching event and the description information of the processor frequency change event, execution times of the process switched and executed within the preset duration at different frequencies of the processor.
A total load obtaining module 503, configured to use a sum of products of each execution time and different frequencies of the corresponding processor as a total load of the process of the handover execution within the preset duration.
An output module 504, configured to output the total load.
Specifically, when receiving a load acquisition command input by a user, the electronic terminal uses the duration information in the load acquisition command as a preset duration, and obtains, through the description information obtaining module 501, description information of a process switching event occurring within the preset duration and description information of a processor frequency change event. Then, the execution time of the process switched and executed within the preset duration at different frequencies of the processor is obtained by the execution time obtaining module 502 according to the description information of the process switching event and the description information of the processor frequency changing event. Then, the total load obtaining module 503 is used to obtain the sum of the products of each execution time and the different frequencies of the corresponding processor as the total load of the process of the switching execution within the preset duration. Finally, the total load is output through an output module 504.
For details that are not described in the present embodiment, please refer to the description of the embodiment shown in fig. 1, which is not described herein again.
It should be noted that, in the embodiment of the electronic terminal illustrated in fig. 5, the division of the functional modules is only an example, and in practical applications, the above functions may be distributed by different functional modules according to needs, for example, configuration requirements of corresponding hardware or convenience of implementation of software, that is, the internal structure of the electronic terminal is divided into different functional modules to complete all or part of the functions described above. In addition, in practical applications, the corresponding functional modules in this embodiment may be implemented by corresponding hardware, or may be implemented by corresponding hardware executing corresponding software. The above description principles can be applied to various embodiments provided in the present specification, and are not described in detail below.
In the embodiment of the invention, the sum of the products of each execution time of the process switched and executed in the preset duration and the different frequencies of the corresponding processor is used as the total load of the process switched and executed in the preset duration, and the total load is calculated according to the different frequency changes of the processor, so that the actual change condition of the load of the process in the dynamic frequency conversion environment is met, and more effective reference can be provided for user software and process load analysis and behavior analysis in the frequency conversion environment.
Referring to fig. 6, a schematic structural diagram of an electronic terminal according to another embodiment of the present invention is shown, which only shows portions related to the embodiment of the present invention for convenience of description. The electronic terminal illustrated in fig. 6 may be an execution subject of the process load obtaining method provided in the foregoing embodiments illustrated in fig. 1 to 4. The electronic terminal illustrated in fig. 6 is different from the electronic terminal in the embodiment illustrated in fig. 5 mainly in that:
further, the description information obtaining module 501 includes:
the original information obtaining module 5011 is configured to obtain, by using an ftrace debugging tool, original information of the process switching event and original information of the processor frequency change event;
the parsing module 5012 is configured to parse the original information of the process switching event and the original information of the processor frequency change event to obtain description information of the process switching event and description information of the processor frequency change event, where the description information of the process switching event includes: identification information of a process executed by switching in the preset time length, a timestamp for process switching and identification information of a processor occupied by the process executed before switching; the description information of the frequency change event of the processor comprises the following steps: identification information of a processor whose frequency has changed, a timestamp of the occurrence of the frequency change, and a changed frequency of the processor.
Specifically, the original information obtaining module 5011 calls an ftrace debugging tool to obtain original information of a process switching event occurring within a preset time and original information of a frequency change event of the processor. Then, the parsing module 5012 parses the original information of the process switching event and the original information of the processor frequency change event to obtain the description information of the process switching event and the description information of the processor frequency change event.
Further, the parsing module 5012 is further configured to use each process switching event and each processor frequency change event as an event object, and use description information of the process switching event or the processor frequency change event corresponding to the event object as description information of the event object;
the electronic terminal further comprises:
a storing module 601, configured to store each event object in a preset first linked list according to a sequence of timestamps in the description information of the event object;
the execution time obtaining module 502 is further configured to identify the description information of each event object in the first linked list, so as to obtain the execution time of each process executed by switching under different frequencies of the processor.
Specifically, in the parsing process, each process switching event and each processor frequency change event are respectively used as an event object by the parsing module 5012, description information of the process switching event or the processor frequency change event corresponding to the event object is used as description information of the event object, and then, each event object is stored in the preset first linked list by the storage module 601 according to the sequence of the timestamps in the description information of the event object. The execution time obtaining module 502 identifies the description information of each event object in the first linked list, so as to obtain the execution time of each process executed by switching under different frequencies of the processor.
Further, if the first linked list is composed of a plurality of sub-chain tables, the storing module 601 is further configured to create a corresponding sub-chain table for each processor, and store all the event objects corresponding to each processor in the sub-chain table corresponding to each processor according to the sequence of the timestamps in the description information of the event objects.
Specifically, in order to make the organization form clearer and improve the processing efficiency, the storage module 601 creates a corresponding sublink for each processor, and stores all the event objects corresponding to each processor in the sublink corresponding to each processor according to the sequence of the timestamps in the description information of the event objects.
Further, the electronic terminal further includes:
a recording module 602, configured to record the total load and the identification information of the process executed by the switch as description information of a corresponding process object;
the storing module 601 is further configured to store the process objects in a preset second linked list, and sort the process objects in the second linked list according to a descending order of the total load;
the output module 504 is further configured to output description information of the process object with the preset bit before the rank on the second linked list.
Specifically, the total load of each process is recorded in the form of a linked list. That is, the recording module 602 records the total load and the identification information of the process executed by the switch as the description information of the corresponding process object. Then, the process objects are stored in a preset second linked list through the storage module 601, and the process objects in the second linked list are sorted according to the sequence of the total load from large to small. Then, the description information of the process object with the pre-set bit before the rank on the second linked list is output through the output module 504.
Further, the electronic terminal further includes:
a determining module 603, configured to determine whether the process executed by the switch has a corresponding process object;
a creating module 604, configured to create a process object for the process executed by switching if the determination result of the determining module 603 is that the process executed by switching does not have a corresponding process object, and trigger the recording module 602 to perform the step of recording the total load and the identification information of the process executed by switching as the description information of the corresponding process object according to the created process object;
the recording module 602 is further configured to update the total load in the description information of the corresponding process object if the determination result of the determining module 603 is that the process executed by switching has the corresponding process object.
Specifically, before the step of recording the total load and the identification information of the process executed by switching as the description information of the created process object is executed by the recording module 602, the determining module 603 determines whether the process executed by switching has a corresponding process object. If the judgment result of the judgment module 603 is that the process executed by switching does not have a corresponding process object, the creation module 604 creates a process object for the process executed by switching, and triggers the recording module 602 to execute the step of recording the total load and the identification information of the process executed by switching as the description information of the created process object. If the judgment result of the judging module 603 is that the process executed by the switch has the corresponding process object, the recording module 602 updates the total load in the description information of the corresponding process object.
Further, the parsing module 5012 is further configured to perform a step of parsing the original information of the process switching event and the original information of the processor frequency change event in groups according to a preset number of event information processes to obtain description information of the process switching event and description information of the processor frequency change event;
the parsing module 5012 is further configured to perform, in groups, according to the preset number of event information processes, a step of taking each process switching event and each processor frequency change event as an event object, and taking description information of the process switching event or the processor frequency change event corresponding to the event object as description information of the event object;
the storing module 601 is further configured to perform, in groups, a step of storing each event object in a preset first linked list according to the preset number of processed event information and the sequence of timestamps in the description information of the event object;
the execution time obtaining module 502 is further configured to perform grouping execution to identify the description information of each event object in the first linked list according to the preset event information processing quantity, so as to obtain the execution time of each process executed by switching under different frequencies of the processor;
the saving module 601 is further configured to perform grouping execution to create a corresponding sublink for each processor according to the preset number of event information processes, and save all the event objects corresponding to each processor in the sublink corresponding to each processor according to the sequence of the timestamps in the description information of the event objects.
Specifically, in order to consider that all event _ info objects are added to the first linked list according to the sequence of the timestamps, which has a high requirement on the memory, in order to configure a lower terminal, according to the preset number of event information processes, the parsing module 5012, the storing module 601 and the execution time obtaining module 502 are controlled to perform respective steps in a packet-loop manner until the execution times of all processes performed by switching at different operating frequencies of the processor are obtained.
For details that are not described in the present embodiment, please refer to the description of the embodiment shown in fig. 1 to fig. 5, which will not be described herein again.
In the embodiment of the invention, the sum of the products of each execution time of the process switched and executed in the preset duration and the different frequencies of the corresponding processor is used as the total load of the process switched and executed in the preset duration, and the total load is calculated according to the different frequency changes of the processor, so that the actual change condition of the load of the process in the dynamic frequency conversion environment is met, and more effective reference can be provided for user software and process load analysis and behavior analysis in the frequency conversion environment.
Referring to fig. 7, fig. 7 is a hardware structure diagram of an electronic terminal according to an embodiment of the present invention.
The electronic terminal described in this embodiment includes:
a memory 51, a processor 52 and a computer program stored in the memory 51 and executable on the processor, wherein the processor executes the computer program to implement the process load obtaining method described in the embodiments of fig. 1 to 4.
Further, the electronic terminal further includes:
at least one input device 53; at least one output device 54.
The memory 51, the processor 52, the input device 53 and the output device 54 are connected by a bus 55.
The input device 53 may be a camera, a touch panel, a physical button, or a mouse. The output device 54 may specifically be a display screen.
The Memory 51 may be a high-speed Random Access Memory (RAM) Memory or a non-volatile Memory (non-volatile Memory), such as a disk Memory. The memory 51 is used for storing a set of executable program codes, and the processor 52 is coupled to the memory 51.
Further, an embodiment of the present invention further provides a computer-readable storage medium, where the computer-readable storage medium may be provided in the electronic terminal in the foregoing embodiments, and the computer-readable storage medium may be the memory in the foregoing embodiment shown in fig. 7. The computer-readable storage medium has stored thereon a computer program which, when executed by a processor, implements the process load acquisition method described in the embodiments of fig. 1 to 4. Further, the computer-readable storage medium may be various media that can store program codes, such as a usb disk, a removable hard disk, a Read-Only Memory (ROM), a Random Access Memory (RAM), a magnetic disk, or an optical disk.
In the embodiments provided in the present application, it should be understood that the disclosed electronic terminal and method can be implemented in other ways. For example, the above-described embodiments are merely illustrative, and for example, the division of the modules is merely a logical division, and an actual implementation may have another division, for example, a plurality of modules or components may be combined or integrated into another system, or some features may be omitted, or not executed. In addition, the shown or discussed mutual coupling or direct coupling or communication link may be through some interfaces, and the indirect coupling or communication link of the modules may be in an electrical, mechanical or other form.
The modules described as separate parts may or may not be physically separate, and parts displayed as modules may or may not be physical modules, may be located in one place, or may be distributed on a plurality of network modules. Some or all of the modules may be selected according to actual needs to achieve the purpose of the solution of the present embodiment.
In addition, functional modules in the embodiments of the present invention may be integrated into one processing module, or each of the modules may exist alone physically, or two or more modules are integrated into one module. The integrated module can be realized in a hardware mode, and can also be realized in a software functional module mode.
It should be noted that, for the sake of simplicity, the above-mentioned method embodiments are described as a series of acts or combinations, but those skilled in the art should understand that the present invention is not limited by the described order of acts, as some steps may be performed in other orders or simultaneously according to the present invention. Further, those skilled in the art will appreciate that the embodiments described in the specification are presently preferred and that no acts or modules are necessarily required of the invention.
In the above embodiments, the descriptions of the respective embodiments have respective emphasis, and for parts that are not described in detail in a certain embodiment, reference may be made to related descriptions of other embodiments.
In the above description, for a person skilled in the art, there are variations on the specific implementation and application scope according to the concepts of the embodiments of the present invention, and in summary, the content of the present specification should not be construed as a limitation to the present invention.

Claims (15)

1. A method for acquiring process load is characterized by comprising the following steps:
acquiring description information of a process switching event occurring in a preset time length and description information of a processor frequency change event;
obtaining the execution time of the process switched and executed in the preset duration under different frequencies of the processor according to the description information of the process switching event and the description information of the processor frequency change event;
taking the sum of the products of the execution times and different frequencies of the corresponding processors as the total load of the process of the switching execution within the preset duration, and outputting the total load;
the obtaining the execution time of the process switched and executed in the preset duration under different frequencies of the processor according to the description information of the process switching event and the description information of the processor frequency change event comprises:
taking each process switching event and each processor frequency changing event as an event object respectively, and taking the description information of the process switching event or the processor frequency changing event corresponding to the event object as the description information of the event object;
storing each event object in a preset first linked list according to the sequence of the timestamps in the description information of the event objects;
the obtaining, according to the description information of the process switching event and the description information of the processor frequency change event, the execution time of the process switched and executed within the preset duration at different frequencies of the processor includes:
and identifying the description information of each event object in the first linked list to obtain the execution time of the process of switching execution in the preset duration under different frequencies of the processor.
2. The method for acquiring process load according to claim 1, wherein the acquiring description information of the process switching event and the description information of the processor frequency change event occurring within the preset duration comprises:
acquiring the original information of the process switching event and the original information of the processor frequency change event through an ftrace debugging tool;
analyzing the original information of the process switching event and the original information of the processor frequency change event to obtain the description information of the process switching event and the description information of the processor frequency change event, wherein the description information of the process switching event comprises: the identification information of the process executed by switching in the preset time length, the timestamp of the process switching and the identification information of the processor occupied by the process executed before the switching; the description information of the processor frequency change event comprises: identification information of a processor whose frequency changes, a timestamp of the occurrence of the frequency change, and a changed frequency of the processor.
3. The process load obtaining method according to claim 1, wherein the first linked list is composed of a plurality of sub-linked lists, and the step of storing each event object in a preset linked list according to the order of timestamps in the description information of the event object includes:
creating a corresponding sublink table for each processor;
and storing all the event objects corresponding to each processor in the sublink corresponding to each processor according to the sequence of the timestamps in the description information of the event objects.
4. The process load obtaining method according to any one of claims 1 to 3, wherein the taking a sum of products of each execution time and different frequencies of the corresponding processors as a total load of the process of the switching execution within the preset time period comprises:
recording the total load and the identification information of the process executed by switching as the description information of the corresponding process object;
and storing the process objects in a preset second linked list, and sequencing the process objects in the second linked list according to the sequence of the total load from large to small.
5. The process load acquisition method of claim 4, wherein said outputting the total load comprises:
and outputting the description information of the process object with the preset position before the rank on the second linked list.
6. The process load obtaining method according to claim 4, wherein before recording the total load and the identification information of the process executed by switching as the description information of the corresponding process object, the method further comprises:
judging whether the process executed by switching has a corresponding process object;
if the process executed by switching does not have the corresponding process object, creating a process object for the process executed by switching, and recording the total load and the identification information of the process executed by switching as the description information of the corresponding process object according to the created process object;
and if the process executed by switching has the corresponding process object, updating the total load in the description information of the corresponding process object.
7. The process load obtaining method according to claim 2, wherein the step of analyzing the original information of the process switching event and the original information of the processor frequency change event to obtain the description information of the process switching event and the description information of the processor frequency change event is performed in groups according to a preset number of event information processing, to the step of identifying the description information of each event object in the first linked list to obtain the execution time of each process executed by switching at different frequencies of the processor, until the execution time of all the processes executed by switching at different frequencies of the processor is obtained.
8. An electronic terminal, comprising:
the system comprises a description information acquisition module, a processor frequency change module and a processing module, wherein the description information acquisition module is used for acquiring description information of a process switching event and description information of a processor frequency change event which occur in a preset time length;
the execution time acquisition module is used for acquiring the execution time of the process switched and executed in the preset duration under different frequencies of the processor according to the description information of the process switching event and the description information of the processor frequency change event;
a total load obtaining module, configured to use a sum of products of each execution time and different frequencies of the corresponding processor as a total load of the process of the handover execution within the preset duration;
an output module for outputting the total load;
the description information acquisition module includes: the analysis module is used for respectively taking each process switching event and each processor frequency change event as an event object, and taking the description information of the process switching event or the processor frequency change event corresponding to the event object as the description information of the event object;
the storage module is used for storing each event object in a preset first linked list according to the sequence of the timestamps in the description information of the event objects;
the execution time obtaining module is specifically configured to: and identifying the description information of each event object in the first linked list to obtain the execution time of the process of switching execution in the preset duration under different frequencies of the processor.
9. The electronic terminal of claim 8, wherein the description information obtaining module further comprises:
the original information acquisition module is used for acquiring original information of the process switching event and original information of the processor frequency change event through an ftrace debugging tool;
the analysis module is further configured to analyze original information of the process switching event and original information of the processor frequency change event to obtain description information of the process switching event and description information of the processor frequency change event, where the description information of the process switching event includes: the identification information of the process executed by switching in the preset time length, the timestamp of the process switching and the identification information of the processor occupied by the process executed before the switching; the description information of the processor frequency change event comprises: identification information of a processor whose frequency changes, a timestamp of the occurrence of the frequency change, and a changed frequency of the processor.
10. The electronic terminal according to claim 9, wherein the first linked list is composed of a plurality of sub-linked lists, and the storing module is further configured to create a corresponding sub-linked list for each processor, and store all the event objects corresponding to each processor in the sub-linked list corresponding to each processor according to a sequence of timestamps in the description information of the event objects.
11. The electronic terminal of claim 10, wherein the electronic terminal further comprises:
a recording module, configured to record the total load and the identification information of the process executed by switching as description information of a corresponding process object;
the storage module is further configured to store the process objects in a preset second linked list, and sort the process objects in the second linked list according to a descending order of the total load;
the output module is further configured to output description information of the process object with a preset bit before ranking on the second linked list.
12. The electronic terminal of claim 11, wherein the electronic terminal further comprises:
the judging module is used for judging whether the process executed by switching has a corresponding process object;
a creating module, configured to create a process object for the handover-executed process if the determination result of the determining module indicates that the handover-executed process does not have a corresponding process object, and trigger the recording module to record the total load and the identification information of the handover-executed process as the description information of the corresponding process object according to the created process object;
the recording module is further configured to update a total load in the description information of the corresponding process object if the determination result of the determining module indicates that the process executed by switching has the corresponding process object.
13. The electronic terminal of claim 12,
the analysis module is further configured to perform a step of analyzing the original information of the process switching event and the original information of the processor frequency change event in groups according to a preset event information processing number to obtain description information of the process switching event and description information of the processor frequency change event;
the analysis module is further configured to perform, in groups, according to the preset event information processing quantity, a step of taking each process switching event and each processor frequency change event as an event object, and taking description information of the process switching event or the processor frequency change event corresponding to the event object as description information of the event object;
the storage module is further configured to perform, in groups, a step of storing each event object in a preset first linked list according to the preset number of processed event information and the sequence of timestamps in the description information of the event objects;
the execution time obtaining module is further configured to perform grouping execution to identify the description information of each event object in the first linked list according to the preset event information processing quantity, so as to obtain the execution time of each process executed by switching at different frequencies of the processor;
the storage module is further configured to create a corresponding sublink for each processor in a grouping manner according to the preset event information processing quantity, and store all the event objects corresponding to each processor in the sublink corresponding to each processor according to the sequence of the timestamps in the description information of the event objects.
14. An electronic terminal, comprising: memory, processor and computer program stored on the memory and executable on the processor, characterized in that the processor implements the process load obtaining method according to any of claims 1 to 7 when executing the computer program.
15. A computer-readable storage medium, on which a computer program is stored, which, when being executed by a processor, carries out the process load acquisition method according to any one of claims 1 to 7.
CN201710580205.5A 2017-07-17 2017-07-17 Process load acquisition method, electronic terminal and computer readable storage medium Active CN107436839B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710580205.5A CN107436839B (en) 2017-07-17 2017-07-17 Process load acquisition method, electronic terminal and computer readable storage medium

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710580205.5A CN107436839B (en) 2017-07-17 2017-07-17 Process load acquisition method, electronic terminal and computer readable storage medium

Publications (2)

Publication Number Publication Date
CN107436839A CN107436839A (en) 2017-12-05
CN107436839B true CN107436839B (en) 2020-07-17

Family

ID=60460242

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710580205.5A Active CN107436839B (en) 2017-07-17 2017-07-17 Process load acquisition method, electronic terminal and computer readable storage medium

Country Status (1)

Country Link
CN (1) CN107436839B (en)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113138909A (en) * 2020-01-20 2021-07-20 Oppo广东移动通信有限公司 Load statistical method, device, storage medium and electronic equipment
CN112333233B (en) * 2020-09-23 2023-11-24 北京达佳互联信息技术有限公司 Event information reporting method and device, electronic equipment and storage medium
CN115309347B (en) * 2022-10-10 2023-03-24 苏州浪潮智能科技有限公司 Time management method, device, equipment and medium based on SSD master control frequency conversion

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1359041A (en) * 2000-12-18 2002-07-17 联想(北京)有限公司 Method for adjusting CPU frequency according to CPU availability
CN101853066A (en) * 2009-02-11 2010-10-06 上海芯豪微电子有限公司 Method and device for automatically adjusting clock frequency of system in real time
CN103955264A (en) * 2014-05-15 2014-07-30 乐视致新电子科技(天津)有限公司 Method and system for dynamically regulating working frequency of processor
CN105045369A (en) * 2015-06-19 2015-11-11 北京大学深圳研究生院 Dynamic CPU frequency adjustment method based on historical user-interaction information

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8732495B2 (en) * 2010-08-31 2014-05-20 Integrated Device Technology, Inc. Systems, apparatuses and methods for dynamic voltage and frequency control of components used in a computer system

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1359041A (en) * 2000-12-18 2002-07-17 联想(北京)有限公司 Method for adjusting CPU frequency according to CPU availability
CN101853066A (en) * 2009-02-11 2010-10-06 上海芯豪微电子有限公司 Method and device for automatically adjusting clock frequency of system in real time
CN103955264A (en) * 2014-05-15 2014-07-30 乐视致新电子科技(天津)有限公司 Method and system for dynamically regulating working frequency of processor
CN105045369A (en) * 2015-06-19 2015-11-11 北京大学深圳研究生院 Dynamic CPU frequency adjustment method based on historical user-interaction information

Also Published As

Publication number Publication date
CN107436839A (en) 2017-12-05

Similar Documents

Publication Publication Date Title
CN107239392B (en) Test method, test device, test terminal and storage medium
US9558016B2 (en) Platform system, method for changing support hardware configuration of universal extensible firmware interface basic input output system and computer program product
EP3069267A1 (en) Software component recommendation based on multiple trace runs
CN113364882B (en) Internet of things terminal, data transmission method thereof and related equipment
CN104679500B (en) Method and device for realizing automatic generation of entity class
CN107436839B (en) Process load acquisition method, electronic terminal and computer readable storage medium
CN111143039A (en) Virtual machine scheduling method and device and computer storage medium
CN112100950B (en) Method, system, device and storage medium for chip design
CN111930215A (en) Power monitoring system for virtual platform simulation
CN114721686A (en) Configuration data updating method and device, electronic equipment and storage medium
US8516441B2 (en) Software optimization device and software optimization method
CN108733536B (en) Monitoring management system and method
US20180173601A1 (en) Energy consumption analysis based on telemetry data
CN112445855A (en) Visual analysis method and visual analysis device for graphic processor chip
CN114756211B (en) Model training method and device, electronic equipment and storage medium
CN112905931B (en) Page information display method and device, electronic equipment and storage medium
CN115269431A (en) Interface testing method and device, electronic equipment and storage medium
CN112783574A (en) Application program development method, device, equipment and storage medium
CN113869882A (en) Data processing method, device and medium
CN109799715B (en) Data receiving method, device and terminal equipment
CN110347577B (en) Page testing method, device and equipment thereof
CN112232027A (en) Symbol translation method, device, equipment and computer readable storage medium
CN107220053B (en) BIOS management method and electronic equipment
CN112487314A (en) Building search method and device based on knowledge graph and storage medium
CN115292194B (en) Method for debugging flow, electronic equipment and computer readable storage medium

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
CB02 Change of applicant information

Address after: Changan town in Guangdong province Dongguan 523860 usha Beach Road No. 18

Applicant after: GUANGDONG OPPO MOBILE TELECOMMUNICATIONS Corp.,Ltd.

Address before: Changan town in Guangdong province Dongguan 523860 usha Beach Road No. 18

Applicant before: GUANGDONG OPPO MOBILE TELECOMMUNICATIONS Corp.,Ltd.

CB02 Change of applicant information
GR01 Patent grant
GR01 Patent grant