linux自旋锁

#include<linux/fs.h>
#include<linux/sched.h>
#include<linux/kthread.h>
#include<linux/module.h>
#include<linux/delay.h>
static int i=0,j=100;
struct task_struct *MyThread1=NULL;
struct task_struct *MyThread2=NULL;
static int myVar = 0;
static int count = 0;
spinlock_t lock;
static void setMyVar(int input)
{
        spin_lock(&lock);
        if(count)
        {
            printk("busy setMyVar\n");
        }
        count++;
    myVar = input;
    printk("setMyVar is %d\n",myVar);
    spin_unlock(&lock);
    count--;
}
static int getMyVar(void)
{
    int res = 0 ;
        spin_lock(&lock);
        if(count)
        {
            printk("busy setMyVar\n");
        }
        count++;
    res = myVar;
    printk("getMyVar is %d\n",res);
    spin_unlock(&lock);
    count--;
    return 0;
}
static int print1(void *data)
{
    while(!kthread_should_stop())
    {
        printk("this is thread1......\n");
        getMyVar();
        setMyVar(i);
        ssleep(1);
        i++;
    }
    return 0;
}
static int print2(void *data)
{
    while(!kthread_should_stop())
    {
        printk("this is thread2......\n");
        getMyVar();
        setMyVar(j);
        ssleep(1);
        j++;
    }
    return 0;
}

static int __init hello_init(void){
    spin_lock_init(&lock);
    MyThread1 = kthread_run(print1,NULL,"mythread1");
    MyThread2 = kthread_run(print2,NULL,"mythread2");
    return 0;
}
static void __exit
hello_exit(void){
    if(MyThread1)
    {
        printk("kthread1 stop....\n");
        kthread_stop(MyThread1);
        MyThread1=NULL;
    }
    if(MyThread2)
    {
        printk("kthread2 stop....\n");
        kthread_stop(MyThread2);
        MyThread2=NULL;
    }
        
}
module_init(hello_init);
module_exit(hello_exit);
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Valerie Henson val@nmt.edu");
MODULE_DESCRIPTION("\"Hello, world!\" minimal module");
MODULE_VERSION("printk");
### Linux 自旋锁 API 函数 #### 初始化自旋锁 为了创建并初始化一个新的自旋锁,可以使用 `spin_lock_init` 函数: ```c void spin_lock_init(spinlock_t *lock); ``` 此函数接受指向 `spinlock_t` 类型变量的指针作为参数,并将其初始化为未锁定状态。 #### 获取自旋锁 获取自旋锁可以通过调用 `spin_lock` 来完成: ```c void spin_lock(spinlock_t *lock); ``` 该操作会使当前执行路径等待直到获得指定的锁。如果锁已经被其他处理器持有,则当前CPU会在忙等循环中持续尝试获取锁[^5]。 对于不可抢占内核配置下的单处理机(UP),宏定义简化了这一过程[^3]。 #### 释放自旋锁 当不再需要保持独占访问权时,应该通过下面的方法来解锁: ```c void spin_lock_unlock(spinlock_t *lock); ``` 这允许其他可能正在等待相同资源的任务继续前进。 #### 尝试获取自旋锁而不阻塞 有时希望测试能否立即取得锁而不想陷入长时间等待的情况,这时可选用 `spin_trylock` 方法: ```c int spin_trylock(spinlock_t *lock); ``` 成功返回非零值;失败则返回0表示未能立刻占有目标对象。 需要注意的是,在多处理器环境中或启用了预占特性的单一中央单元上应用这些接口特别重要,因为它们能有效防止竞争条件的同时确保高效性能表现。 此外,被自旋锁保护的关键区域绝对不允许调用可能导致休眠的操作系统服务,以免引发潜在的死锁风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值