почему mutex_unlock работает без вызова от владельца - PullRequest
1 голос
/ 02 октября 2019

В дальнейшем мьютекс должен быть освобожден той же задачей, которая его получила.

Вышеуказанная строка присутствует в 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
...