在使用关中断自旋锁(spin_lock_irqsave)的过程中,中断被打开

本文主要介绍在使用自旋锁(spin_lock_irqsave)的过程中,中断被打开,要锁定“打开中断的代码”的调试过程。

首先介绍spin_lock_irqsave的定义:

函数声明:
	void spin_lock_irqsave(spinlock_t *lock, unsigned long flags);
函数功能:
	1. 保存本地中断状态
	2. 关闭本地中断
	3. 获取自旋锁
参数说明:
	lock:被定义且初始化过的锁;
	flags:保存本地中断状态;

spin_lock_irqsave更具体的介绍

调试方法是根据spin_lock_irqsave传回的参数“flags”进行的。

调试方法的依据:

  1. 在调用spin_lock_irqsave时首先会保存当前的中断状态到“flags”,其次再关闭中断,因此保存的中断状态是关闭中断之前的中断状态。
  2. 本地测试的结果是“在中断未关闭的情况下上锁返回的flags值为1,在中断关闭后再次上锁返回的flags值为0”

调试方法:

定义多个自旋锁,在上锁与解锁过程中使用二分法多次进行上锁操作,打印flags值。如果flags的值由0变为1就说明在这两次上锁的过程中中断被打开了。

下面就是进行上锁的代码:

static DEFINE_SPINLOCK(lock_t1);
spin_lock_init(&lock_t1);
unsigned long flags_t1;
spin_lock_irqsave(&lock_t1, flags_t1);
printk(KERN_EMERG " spin_unlock flags print:----------> file: %s , func: %s , line: %d , flags: %x .\n" , __FILE__ , __FUNCTION__ , __LINE__ , flags_t1);

注意:

在调试中频繁调用printk会阻塞程序运行。

这个调试方法比较笨拙粗糙,如果有错误的地方请指正,写在这里的目的也是为了抛砖引玉,如果大家有好的调试方法可以发出来

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
spin_lock() 和 spin_lock_irqsave() 都是 Linux 内核用于保护共享资源的自旋锁函数,它们的区别在于是否对中断进行处理。 spin_lock() 函数会获取自旋锁,并禁用本地 CPU 的中断。这意味着,如果在获取自旋锁过程发生了中断中断处理程序将无法运行,直到自旋锁被释放。因此,spin_lock() 主要用于在中断被禁用的情况下保护共享资源,以防止其他 CPU 并发访问。 而 spin_lock_irqsave() 函数则会获取自旋锁,并保存本地 CPU 的中断状态。这意味着,在获取自旋锁过程中断可以被触发,但是中断处理程序不能访问被保护的共享资源,因为它们也会尝试获取自旋锁。因此,spin_lock_irqsave() 主要用于在中断被启用的情况下保护共享资源。 在使用 spin_lock_irqsave() 函数时,需要在获取自旋锁的同时保存中断状态,并在释放自旋锁的同时恢复中断状态,以避免出现中断状态被篡改的情况。常见的用法是: ```c spinlock_t my_lock; unsigned long flags; spin_lock_irqsave(&my_lock, flags); // 获取自旋锁并保存中断状态 // 在这里进行对共享资源的访问 spin_unlock_irqrestore(&my_lock, flags); // 释放自旋锁并恢复中断状态 ``` 总之,spin_lock() 适用于在禁用中断的情况下保护共享资源,而 spin_lock_irqsave() 适用于在启用中断的情况下保护共享资源,它们的使用方式略有不同,需要根据具体情况选择合适的函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值