lkmpg/examples/example_mutex.c

41 lines
774 B
C
Raw Normal View History

/*
* example_mutex.c
*/
2021-07-22 06:35:24 +08:00
#include <linux/module.h>
#include <linux/mutex.h>
#include <linux/printk.h>
2021-07-22 06:35:24 +08:00
static DEFINE_MUTEX(mymutex);
2021-07-22 06:35:24 +08:00
static int __init example_mutex_init(void)
2021-07-22 06:35:24 +08:00
{
int ret;
pr_info("example_mutex init\n");
ret = mutex_trylock(&mymutex);
if (ret != 0) {
pr_info("mutex is locked\n");
if (mutex_is_locked(&mymutex) == 0)
pr_info("The mutex failed to lock!\n");
mutex_unlock(&mymutex);
pr_info("mutex is unlocked\n");
} else
2021-07-22 06:35:24 +08:00
pr_info("Failed to lock\n");
return 0;
}
static void __exit example_mutex_exit(void)
2021-07-22 06:35:24 +08:00
{
pr_info("example_mutex exit\n");
}
module_init(example_mutex_init);
module_exit(example_mutex_exit);
MODULE_DESCRIPTION("Mutex example");
MODULE_LICENSE("GPL");