自旋锁

以下笔记摘自《linux设备驱动开发详解》
自旋锁的描述:
自旋锁是一种典型的对临界资源进行互斥访问的手段。获得一个自旋锁,在cpu上运行的代码前需先执行一个原子操作,该操作测试并设置某个内存变量,由于它是原子操作,在该操作完成之前其他执行单元不可能访问这个内存变量。如果测试结果表明锁已经空闲,则程序获得这个自旋锁并继续执行,否则程序将在一个小循环内重复这个“测试并设置”的操作。

自旋锁的操作:
1、定义
spinlock_t lock;
2、初始化
spin_lock_init(&lock);该宏用于动态初始化自旋锁
3、获取
spin_lock(&lock);该宏用来获取一个自旋锁,获取成功立即返回,否则,在那里自旋,直到该互斥锁释放
4、尝试获取
spin_trylock(&lock);该宏用来尝试获取一个自旋锁,获取成功返回true,否则返回false,即是获取失败不会等待该互斥锁释放
5、释放
spin_unlock(&lock);
它与spin_lock(&lock);或者spin_trylock(&lock);配对使用

自旋锁使用的注意事项:
1、自旋锁可能会导致系统死锁。引发这个问题常见的情况是递归使用一个自旋锁
2、在自旋锁 锁定期间不能调用可能引起调度的函数。如果进程获得锁后再进行阻塞,则可能导致内核的崩溃,如在获得锁后调用copy_to_user、copy_from_user、kmalloc、msleep等

你可能感兴趣的:(linux驱动笔记,驱动开发,linux)