В дальнейшем мьютекс должен быть освобожден той же задачей, которая его получила.
Вышеуказанная строка присутствует в kernel / lock / mutex.c в определении mutex_lock.
Я не могу увидеть то же поведение с примером кода. Я делаю какую-либо ошибку. Пожалуйста, проверьте мой код ниже и dmesg.
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/delay.h>
#include <linux/mutex.h>
#include <linux/slab.h>
#include <linux/kthread.h>
MODULE_LICENSE("GPL");
DEFINE_MUTEX(my_lock);
struct task_struct *mythread;
static int threadfn(void *data)
{
pr_info("Kernel thread running on processor:%d\n", smp_processor_id());
pr_info("Kernel thread unlocking without calling lock on processor:%d\n", smp_processor_id());
mutex_unlock(&my_lock);
pr_info("Kernel thread unlocked without calling lock on processor:%d\n", smp_processor_id());
return 0;
}
static int __init test_hello_init(void)
{
mutex_init(&my_lock);
pr_info("Init function running on processor:%d\n", smp_processor_id());
mutex_lock(&my_lock);
pr_info("Init function locked on processor:%d\n", smp_processor_id());
mythread = kthread_run(threadfn, NULL, "mythread");
msleep(8000);
pr_info("Init function completed on processor:%d\n", smp_processor_id());
return -1;
}
static void __exit test_hello_exit(void)
{
}
module_init(test_hello_init);
module_exit(test_hello_exit);
dmesg:
[27389.146151] Init function running on processor:5
[27389.146152] Init function locked on processor:5
[27389.146351] Kernel thread running on processor:2
[27389.146352] Kernel thread unlocking without calling lock on processor:2
[27389.146352] Kernel thread unlocked without calling lock on processor:2
[27397.385479] Init function completed on processor:5
insmod: ERROR: could not insert module ./hello.ko: Operation not permitted