Возможно, вы ищете get_avenrun()
функцию в kernel/sched.c
. Пример того, как использовать это в fs/proc/loadavg.c
:
static int loadavg_proc_show(struct seq_file *m, void *v)
{
unsigned long avnrun[3];
get_avenrun(avnrun, FIXED_1/200, 0);
seq_printf(m, "%lu.%02lu %lu.%02lu %lu.%02lu %ld/%d %d\n",
LOAD_INT(avnrun[0]), LOAD_FRAC(avnrun[0]),
LOAD_INT(avnrun[1]), LOAD_FRAC(avnrun[1]),
LOAD_INT(avnrun[2]), LOAD_FRAC(avnrun[2]),
nr_running(), nr_threads,
task_active_pid_ns(current)->last_pid);
return 0;
}
Хотя я немного скептически отношусь к тому, как вы можете использовать среднее значение нагрузки для изменения драйвера - среднее значение нагрузки лучше всего рассматривать как эвристику для системных администраторов, чтобы измерить, как их система изменяется со временем Не обязательно, насколько «здоровым» это может быть в любой момент - что конкретно у водителя вызывает проблемы? Вероятно, есть лучший механизм, чтобы он хорошо сочетался с остальной системой.