-
-
Notifications
You must be signed in to change notification settings - Fork 334
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Improve CPU usage efficiency #1448
Conversation
src/windows/process.rs
Outdated
let global_kernel_time = filetime_to_u64(fglobal_kernel_time); | ||
let global_user_time = filetime_to_u64(fglobal_user_time); | ||
// by default, use previous values | ||
let mut global_kernel_time: u64 = p.cpu_calc_values.old_system_sys_cpu; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
At this point, why not just return the previously computed cpu usage?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I apologize for my significant oversight. I revised the code to return the unchanged process CPU usage if the last_update
field hasn't exceeded the time it takes to update the CPU values. It should be good now. Again, passed all cargo fmt, clippy and test commands.
…rather than re-calculating using old values.
src/windows/process.rs
Outdated
// FIXME: should these values be stored in one place to make use of | ||
// `MINIMUM_CPU_UPDATE_INTERVAL`? | ||
|
||
if p.cpu_calc_values.last_update.elapsed() <= MINIMUM_CPU_UPDATE_INTERVAL { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This can be put at the very beginning of this function, no need for all the variable initializations and the GetProcessTimes
call.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed.
Thanks! |
Problem
The
compute_cpu_usage
function relied on redundant operations and inefficient handling of cached system times. This could lead to unnecessary updates to system times, resulting in reduced efficiency and increased overhead.Solution
I updated the function to use cached values unless the time elapsed since the previous values were cached exceeds MINIMUM_CPU_UPDATE_INTERVAL, ensuring system times are only refreshed when necessary.
GetSystemTimes
, andfiletime_to_u64
.Now, after each call to
compute_cpu_usage
if the last time these values were retrieved ( a call toGetSystemTimes
took place ) is less than MINIMUM_CPU_UPDATE_INTERVAL ( system values haven't updated ) the function will use the values used previously. Otherwise,GetSystemTimes
will be called, values will be retrieved, and an Instant::now() value will be saved in cpu_calc_values to determine the timeGetSystemTimes
was last called.Tests
cargo test
.Other
cargo fmt
andcargo clippy
were ran successfully.