ICode9

精准搜索请尝试: 精确搜索
  • Linux内核机制—spin_lock2022-06-12 15:03:45

    一、spin_lock概述 1. spin lock 是一种可休眠锁,可用于原子上下文。当获取不到锁的时候会spin等待,此时是running状态。 2. spin lock 的发展到现在经历了四个阶段 (1) CAS 锁只有一个原子变量,执行单个 compare-and-swap 指令来获取锁。问题是没有公平可言,无法让等待最长的那

  • linux驱动移植-进程同步之自旋锁2022-02-23 20:04:25

    一、自旋锁(spinlock) 1.1  什么是自旋锁 自旋锁(spinlock)是一种典型的对临界资源进行互斥访问的手段,其名称来源于它的工作方式。 为了获得一个自旋锁,在某CPU上运行的代码需先执行一个原子操作,该操作测试并设置(Test-AndSet)某个内存变量。由于它是原子操作,所以在该操作完成之前

  • 【Kernel】内核同步2022-02-21 09:59:25

    【Kernel】内核同步 内核源码快捷查看 一、什么是内核同步 同步是指用于实现控制多个进程按照一定的规则或顺序访问某些系统资源的机制。 内核同步这里有一个官方形式的说法,但个人认为这一解释对理解其实际功能没什么帮助,这里仅仅对其进行引用。为了便于理解,这里介绍两个概念

  • spinlock 和抢占2022-02-16 20:34:11

     场景分析 对于spin lock,其保护的资源可能来自多个CPU CORE上的进程上下文和中断上下文的中的访问,其中,进程上下文包括:用户进程通过系统调用访问,内核线程直接访问,来自workqueue中work function的访问(本质上也是内核线程)。中断上下文包括:HW interrupt context(中断handler)、软中断上

  • 【C# 线程】.NET 中的轻量级线程安全2021-12-28 05:32:59

    对线程安全有要求的代码中,通常会使用锁(lock)。自 .NET 诞生以来就有锁,然而从 .NET Framework 4.0 开始,又诞生了 6 个轻量级的线程安全方案:SpinLock, SpinWait, CountdownEvent, SemaphoreSlim, ManualResetEventSlim, Barrier。 如何轻量 这些轻量级线程同步方案因为没有使用到 Win

  • Linux 驱动开发 二十七:自旋锁2021-12-26 16:30:16

    内核当发生访问资源冲突的时候,可以有两种锁的解决方案选择: 一个是原地等待一个是挂起当前进程,调度其他进程执行(睡眠) spin lock 是一种死等的机制,当前的执行 thread 会不断的重新尝试直到获取锁进入临界区。 spin lock 一次只能有一个 thread 获取锁并进入临界区,其他的 thread

  • 【无标题】2021-11-18 13:03:25

    目录 一、虚拟地址转换[一]-基本流程 1 二、虚拟地址转换[二]-具体实现 4 三、虚拟地址转换[三]-多级页表 9 四、虚拟地址转换[四]-large page/hugepage 14 五、虚拟地址转换[五]-paging structure caches 17 六、Cache之读写一致性 20 七、TLB之flush操作[一] 23 八、TLB之flus

  • 我对eBPF的偏见2021-07-25 11:32:19

    台风天气,适合饮酒作文。 我并不反对eBPF技术本身,相反,我很喜欢eBPF并且是它的粉丝,我反对的是对eBPF的滥用。 上周听了一个关于eBPF技术扩展spinlock的讨论,基于以下这个paper: https://www.sigops.org/s/conferences/hotos/2021/papers/hotos21-s08-park.pdf 大致说的是,可以使用

  • linux kernel的spinlock在armv7和armv8中的不同2021-06-21 14:55:03

    在armv7中:spin_lock调用了wfe指令,让cpu进入低功耗状态;在spin_unlock中调用了sev指令,让cpu退出低功耗模式; 在armv8中,spin_lock调用了wfe指令,让cpu进入低功耗状态; 在spin_unlock中确删除了sev指令,为什么这样呢? 我们在armv8的文档中找到答案: stlrh是带有释放语义的存储指令,会改

  • linux kernel的spin_lock的详细介绍(以arm64为例)2021-06-21 14:52:04

    1、spin_lock的调用流程: static __always_inline void spin_lock(spinlock_t *lock) { raw_spin_lock(&lock->rlock); } #define raw_spin_lock(lock) _raw_spin_lock(lock) void __lockfunc _raw_spin_lock(raw_spinlock_t *lock) __acquires(lock); void __lockfunc

  • Linux内核原语(四)——自旋锁(Spinlock)2021-05-17 23:59:00

        Linux内核原语(四)——自旋锁(Spinlock) 小狼@http://blog.csdn.net/xiaolangyangyang   内核当发生访问资源冲突的时候,可以有两种锁的解决方案选择: 一个是原地等待一个是挂起当前进程,调度其他进程执行(睡眠) Spinlock 是内核中提供的一种比较常见的锁机制,自旋锁是“原地等待

  • 线程同步机制之自旋锁2021-03-28 13:04:18

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <pthread.h> #include <errno.h> /* 定义变量 */ pthread_spinlock_t spin; /*定义全局变量*/ int i = 0; /* 线程函数 */ void *thread_fun(void *arg)

  • Linux实时补丁即将合并进Linux 5.32021-01-30 21:56:43

    Linux PREEMPT_RT 补丁终于要合并进Linux 5.3了。意味着开发了十几年的实时补丁将得以和主线Linux 协同发展。 以下文章改编自 杨燚 的 Linux 实时技术与典型实现分析(文尾链接) 一、实时的概念 所谓实时,就是一个特定任务的执行时间必须是确定的,可预测的,并且在任何情况下都能保证任务

  • Linux内核源码分析 -- 同步原语 -- 自旋锁 spinlock2020-06-07 23:02:21

    Linux内核源码分析 -- 同步原语 -- 自旋锁 spinlock_t typedef struct spinlock { union { struct raw_spinlock rlock; #ifdef CONFIG_DEBUG_LOCK_ALLOC # define LOCK_PADSIZE (offsetof(struct raw_spinlock, dep_map)) struct {

  • SpinLock-自旋锁2020-05-31 10:53:12

    自旋锁(spinlock): 是指当一个线程在获取锁的时候,如果锁已经被其它线程获取,那么该线程将循环等待,然后不断的判断锁是否能够被成功获取,直到获取到锁才会退出循环。   什么情况下使用自旋锁: 自旋锁非常有助于避免阻塞,但是如果预期有大量阻塞,由于旋转过多,您可能不应该使用自旋锁。当锁

  • 自旋锁(spinLock)2020-04-22 10:55:09

    1.AtomicReference         AtomicReference类提供了一个可以原子读写的对象引用变量。原子意味着尝试更改AtomicReference的多个线程(例如:比较和交换操作),不会是AtomicReference最终达到不一致的效果。        AtomicReference有一个先进的方法compareAndSet(),它可

  • linux 自旋锁 API 简介2019-07-06 10:01:26

    自旋锁原语要求的包含文件是 <linux/spinlock.h>. 一个实际的锁有类型 spinlock_t. 象任何其他数据结构, 一个 自旋锁必须初始化. 这个初始化可以在编译时完成, 如下:   spinlock_t my_lock = SPIN_LOCK_UNLOCKED; 或者在运行时使用: void spin_lock_init(spinlock_t *lock); 在

  • linux – 用户空间进程和中断上下文代码之间的同步2019-07-04 04:38:15

    最近我参加了几次采访.在提出的所有内核问题中,有一个具体问题我无法找到令人信服的答案. 在用户空间进程和中断上下文功能之间共享数据时,您将如何使用不同的同步技术?我令人信服的答案是: 在中断上下文代码中: 1. do *spin_lock_irqsave* 2. access data buffer which is shared be

  • 在linux内核中,是否会调用kfree?2019-07-03 15:38:13

    标题几乎就是问题…… 我正在编写一些使用自旋锁来帮助列表管理的代码.关于自旋锁的文档很清楚,没有调用任何会睡觉的东西.我知道有办法分配“原子”的内存,但我还没有看到任何关于kfree或释放内存的东西. 直觉告诉我它不应该睡觉,但我没有发现这是明确的.解决方法:不,它永远不会睡

  • linux – 如果需要调用copy_to_user,如何使用自旋锁?2019-05-29 23:48:44

    我写了一个小驱动程序来读取一些数据并将其提供给用户.我的驱动程序可以被多个应用程序使用,即它是一个可重入的驱动程序,因此使用自旋锁.但我发现不应该在保持旋转锁的情况下调用copy_to_user. char_device_buf在以下代码中是共享数据;我必须保护它.除了互斥锁之外是否有任何机制

  • C++11 —— 简易的旋转锁类2019-01-25 16:04:04

    简易的旋转锁 使用 C++11 的原子操作,实现的简易旋转锁(xspinlock.h): /** * @file xspinlock.h * <pre> * Copyright (c) 2019, Gaaagaa All rights reserved. * * 文件名称:xspinlock.h * 创建日期:2019年01月22日 * 文件标识: * 文件摘要:简易的旋转锁类。 * * 当前版本:1

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有