2021-07-22 11:25:32 +08:00
|
|
|
/*
|
2021-08-08 01:24:59 +08:00
|
|
|
* example_rwlock.c
|
2021-07-22 11:25:32 +08:00
|
|
|
*/
|
2021-07-22 06:58:13 +08:00
|
|
|
#include <linux/interrupt.h>
|
2021-07-22 06:35:24 +08:00
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/module.h>
|
|
|
|
|
|
|
|
DEFINE_RWLOCK(myrwlock);
|
|
|
|
|
|
|
|
static void example_read_lock(void)
|
|
|
|
{
|
|
|
|
unsigned long flags;
|
|
|
|
|
|
|
|
read_lock_irqsave(&myrwlock, flags);
|
|
|
|
pr_info("Read Locked\n");
|
|
|
|
|
|
|
|
/* Read from something */
|
|
|
|
|
|
|
|
read_unlock_irqrestore(&myrwlock, flags);
|
|
|
|
pr_info("Read Unlocked\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
static void example_write_lock(void)
|
|
|
|
{
|
|
|
|
unsigned long flags;
|
|
|
|
|
|
|
|
write_lock_irqsave(&myrwlock, flags);
|
|
|
|
pr_info("Write Locked\n");
|
|
|
|
|
|
|
|
/* Write to something */
|
|
|
|
|
|
|
|
write_unlock_irqrestore(&myrwlock, flags);
|
|
|
|
pr_info("Write Unlocked\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
static int example_rwlock_init(void)
|
|
|
|
{
|
|
|
|
pr_info("example_rwlock started\n");
|
|
|
|
|
|
|
|
example_read_lock();
|
|
|
|
example_write_lock();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void example_rwlock_exit(void)
|
|
|
|
{
|
|
|
|
pr_info("example_rwlock exit\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
module_init(example_rwlock_init);
|
|
|
|
module_exit(example_rwlock_exit);
|
|
|
|
|
|
|
|
MODULE_DESCRIPTION("Read/Write locks example");
|
|
|
|
MODULE_LICENSE("GPL");
|