sched/cpuload: add SCHED_CPULOAD_OSCLK option

Signed-off-by: yinshengkai <yinshengkai@xiaomi.com>
This commit is contained in:
yinshengkai 2023-04-26 22:30:34 +08:00 committed by Xiang Xiao
parent d1b5558c8b
commit 08c4ac133b
5 changed files with 28 additions and 15 deletions

View File

@ -2351,7 +2351,7 @@ void nxsched_alarm_tick_expiration(clock_t ticks);
* *
****************************************************************************/ ****************************************************************************/
#if defined(CONFIG_SCHED_CPULOAD) && defined(CONFIG_SCHED_CPULOAD_EXTCLK) #ifdef CONFIG_SCHED_CPULOAD_EXTCLK
void nxsched_process_cpuload_ticks(uint32_t ticks); void nxsched_process_cpuload_ticks(uint32_t ticks);
# define nxsched_process_cpuload() nxsched_process_cpuload_ticks(1) # define nxsched_process_cpuload() nxsched_process_cpuload_ticks(1)
#endif #endif

View File

@ -880,7 +880,6 @@ config SCHED_CRITMONITOR_MAXTIME_PANIC
config SCHED_CPULOAD config SCHED_CPULOAD
bool "Enable CPU load monitoring" bool "Enable CPU load monitoring"
default n default n
select SCHED_CPULOAD_EXTCLK if SCHED_TICKLESS
---help--- ---help---
If this option is selected, the timer interrupt handler will monitor If this option is selected, the timer interrupt handler will monitor
if the system is IDLE or busy at the time of that the timer interrupt if the system is IDLE or busy at the time of that the timer interrupt
@ -898,14 +897,32 @@ config SCHED_CPULOAD
if SCHED_CPULOAD if SCHED_CPULOAD
config SCHED_CPULOAD_EXTCLK choice
bool "Use external clock" prompt "Select CPU load clock source"
default n default SCHED_CPULOAD_EXTCLK if SCHED_TICKLESS
config SCHED_CPULOAD_SYSCLK
bool "Use system clock"
---help--- ---help---
If this option is enabled, the system clock is used for cpu load
measurement by default.
There is a serious issue for the accuracy of measurements if the
system clock is used, however. NuttX threads are often started at
the time of the system timer expiration. Others may be stopped at
the time of the system timer expiration (if round-robin time-slicing
is enabled). Such thread behavior occurs synchronously with the
system timer and, hence, is not randomly sampled. As a consequence,
the CPU load attributed to these threads that run synchronously with
they system timer may be grossly in error.
The CPU load measurements are determined by sampling the active The CPU load measurements are determined by sampling the active
tasks periodically at the occurrence to a timer expiration. By tasks periodically at the occurrence to a timer expiration. By
default, the system clock is used to do that sampling. default, the system clock is used to do that sampling.
config SCHED_CPULOAD_EXTCLK
bool "Use external clock"
depends on SCHED_TICKLESS
---help---
There is a serious issue for the accuracy of measurements if the There is a serious issue for the accuracy of measurements if the
system clock is used, however. NuttX threads are often started at system clock is used, however. NuttX threads are often started at
the time of the system timer expiration. Others may be stopped at the time of the system timer expiration. Others may be stopped at
@ -924,6 +941,8 @@ config SCHED_CPULOAD_EXTCLK
nxsched_process_cpuload_ticks() at each timer expiration with interrupts nxsched_process_cpuload_ticks() at each timer expiration with interrupts
disabled. disabled.
endchoice
if SCHED_CPULOAD_EXTCLK if SCHED_CPULOAD_EXTCLK
config SCHED_CPULOAD_TICKSPERSEC config SCHED_CPULOAD_TICKSPERSEC

View File

@ -395,17 +395,11 @@ int nxsched_pause_cpu(FAR struct tcb_s *tcb);
# define nxsched_islocked_tcb(tcb) ((tcb)->lockcount > 0) # define nxsched_islocked_tcb(tcb) ((tcb)->lockcount > 0)
#endif #endif
#ifndef CONFIG_SCHED_CPULOAD_EXTCLK
/* CPU load measurement support */ /* CPU load measurement support */
# ifdef CONFIG_SCHED_CPULOAD #ifdef CONFIG_SCHED_CPULOAD_SYSCLK
void nxsched_process_cpuload_ticks(uint32_t ticks); void nxsched_process_cpuload_ticks(uint32_t ticks);
# else #define nxsched_process_cpuload() nxsched_process_cpuload_ticks(1)
# define nxsched_process_cpuload_ticks(ticks)
# endif
# define nxsched_process_cpuload() nxsched_process_cpuload_ticks(1)
#endif #endif
/* Critical section monitor */ /* Critical section monitor */

View File

@ -220,7 +220,7 @@ void nxsched_process_timer(void)
clock_timer(); clock_timer();
#ifndef CONFIG_SCHED_CPULOAD_EXTCLK #ifdef CONFIG_SCHED_CPULOAD_SYSCLK
/* Perform CPU load measurements (before any timer-initiated context /* Perform CPU load measurements (before any timer-initiated context
* switches can occur) * switches can occur)
*/ */

View File

@ -421,7 +421,7 @@ static unsigned int nxsched_timer_process(unsigned int ticks,
clock_update_wall_time(); clock_update_wall_time();
#endif #endif
#ifndef CONFIG_SCHED_CPULOAD_EXTCLK #ifdef CONFIG_SCHED_CPULOAD_SYSCLK
/* Perform CPU load measurements (before any timer-initiated context /* Perform CPU load measurements (before any timer-initiated context
* switches can occur) * switches can occur)
*/ */