Я хочу периодически вызывать программу пространства пользователя из модуля ядра. Но программа ядра замораживает систему, а я пытаюсь ее загрузить. Ниже приводится программа,Модуль ядра, периодически вызывающий программу пользовательского пространства
#include <linux/module.h> /* Needed by all modules */
#include <linux/kernel.h> /* Needed for KERN_INFO */
#include <linux/init.h> /* Needed for the macros */
#include <linux/jiffies.h>
#include <linux/time.h>
#include <linux/proc_fs.h>
#include <asm/uaccess.h>
#include <linux/hrtimer.h>
#include <linux/sched.h>
#include <linux/delay.h>
#define TIME_PERIOD 50000
static struct hrtimer hr_timer;
static ktime_t ktime_period_ns;
static enum hrtimer_restart timer_callback(struct hrtimer *timer){
char userprog[] = "test.sh";
char *argv[] = {userprog, "2", NULL };
char *envp[] = {"HOME=/", "PATH=/sbin:/usr/sbin:/bin:/usr/bin", NULL };
printk("\n Timer is running");
hrtimer_forward_now(&hr_timer, ktime_period_ns);
printk("callmodule: %s\n", userprog);
call_usermodehelper(userprog, argv, envp, UMH_WAIT_PROC);
return HRTIMER_RESTART;
}
static int __init timer_init() {
ktime_period_ns= ktime_set(0, TIME_PERIOD);
hrtimer_init (&hr_timer, CLOCK_MONOTONIC, HRTIMER_MODE_REL);
hr_timer.function = timer_callback;
hrtimer_start(&hr_timer, ktime_period_ns, HRTIMER_MODE_REL);
return 0;
}
static int __exit timer_exit(){
int cancelled = hrtimer_cancel(&hr_timer);
if (cancelled)
printk(KERN_ERR "Timer is still running\n");
else
printk(KERN_ERR "Timer is cancelled\n");
}
module_init(timer_init);
module_exit(timer_exit);
MODULE_LICENSE("GPL");
test.sh представляет собой скрипт, который просто повторяет комментарий. Я проверил часть call_usermodehelper и часть таймера отдельно, и он работает нормально. Но когда я совмещаю два кода, система зависает. Может кто-нибудь, пожалуйста, помогите мне решить проблему.
Вы звоните в свой таймер каждые 50 лет, вы уверены, что это правильно? Попробуйте с одной секундой или более периодом, чтобы убедиться, что если он работает. – HappyCactus
Обратный звонок для * hrtimer * выполняется в * атомном * контексте, поэтому он не должен блокироваться. 'call_usermodehelper' блокирует процесс вызова, пока вызываемая программа не вернется. Вы можете использовать 'delayed_work' вместо hrtimer для периодического выполнения задач блокировки. – Tsyvarev
Да .... call_usermodehelper блокирует код. Но test.sh - это просто «тестирование» эха. Не знаю, пока он не выходит из этого. – BusyTraveller