首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

深入理解Linux内核之进程唤醒

1.开场白 环境: 处理器架构:arm64 内核源码:linux-5.10.50 ubuntu版本:20.04.1 代码阅读工具:vim+ctags+cscope 前面文章,我们介绍了进程是如何睡眠,本文来揭开进程唤醒的神秘面纱...应用场景 进程唤醒主要应用场景如下: fork的时候唤醒子进程 exec的时候唤醒进程 睡眠超时唤醒 睡眠锁释放唤醒 IO读写完成唤醒 其他正常的唤醒路径 注:应用场景在此不再分析,感兴趣的小伙伴可以自行查阅内核源代码...),而远程cpu可能处于idle状态,需要发生ipi来唤醒远程cpu处理重新调度(在中断处理返回内核态前夕就可以发生调度了)。...resched_curr主要用于设置重新调度标志和抢占重新调度标志,会考虑是本地cpu还是远程cpu的情况,并不是发生调度,需要等到最近的调度点到来时发生调度(可能是重新开启抢占的时候,也可能是中断返回前夕,见之前讲解到的内核抢占相关文章...将唤醒进程加入到目标cpu的运行队列,这里会调用到调度enqueue_task回调,如加入cfs的红黑树。 唤醒抢占处理,被唤醒的高优先级进程可以抢占当前进程。

2.8K20
您找到你想要的搜索结果了吗?
是的
没有找到

深入理解Linux内核内核线程(下)

7.2 使用调度上下文 当内核线程唤醒,在合适的时机被调度时,会执行如下内核路径: __schedule //kernel/sched/core.c ->context_switch ->switch_to...用例1:linux系统中,当内存不足时,会唤醒kswapd内核线程来进行异步内存回收,下面我们来看他的创建过程: mm/vmscan.c kswapd_init ->for_each_node_state...(kswapd, pgdat, "kswapd%d", nid) //使用kthread_run结构创建并唤醒创建的内核线程 执行kswapd函数 用例2:Linux软中断是下半部的一种机制,一般对效率要求较高的场景会使用到...kthread_run实现一样将内核线程创建信息添加到kthread_create_list链表 然后唤醒kthreadd来创建内核线程,最后会绑定到对应的cpu上去。...内核模块代码:kthread_demo.c #include #include #include #include

2K30

Linux内核线程

线程通常被定义为一个进程中代码的不同执行路线。从实现方式上划分,线程有两种类型:“用户级线程”和“内核线程”。...用户线程指不需要内核支持而在用户程序中实现的线程,其不依赖于操作系统核心,应用进程利用线程库提供创建、同步、调度和管理线程的函数来控制用户线程。...这种线程甚至在象 DOS 这样的操作系统中也可实现,但线程的调度需要用户程序完成,这有些类似 Windows 3.x 的协作式多任务。另外一种则需要内核的参与,由内核完成线程的调度。...而内核线程则没有各个限制,有利于发挥多处理器的并发优势,但却占用了更多的系统开支。...Windows NT和OS/2支持内核线程Linux 支持内核级的多线程

4K00

深入理解Linux内核内核线程(上)

1.开场白 环境: 处理器架构:arm64 内核源码:linux-5.11 ubuntu版本:20.04.1 代码阅读工具:vim+ctags+cscope 在linux系统中, 我们接触最多的莫过于用户空间的任务...,像用户线程或用户进程,因为他们太活跃了,也太耀眼了以至于我们感受不到内核线程的存在,但是内核线程却在背后默默地付出着,如内存回收,脏页回写,处理大量的软中断等,如果没有内核线程那么linux世界是那么的可怕...2.当前内核线程在285 行睡眠后 谁来唤醒我?...4.2 wake_up_process唤醒 上面通过kthread_create创建完成内核线程之后,内核线程处于TASK_UNINTERRUPTIBLE状态,等待被唤醒,这个时候kthread_run...kthread_run:创建并唤醒一个内核线程 kthread_create:创建一个内核线程,创建之后处于TASK_UNINTERRUPTIBLE状态 wake_up_process:唤醒一个任务 kthread_stop

2K20

Linux 内核】进程管理 ( 内核线程概念 | 内核线程、普通进程、用户线程 | 内核线程与普通进程区别 | 内核线程主要用途 | 内核线程创建函数 kernel_thread 源码 )

文章目录 一、内核线程概念 二、内核线程、普通进程、用户线程 三、内核线程、普通进程区别 四、内核线程主要用途 五、内核线程创建函数 kernel_thread 源码 一、内核线程概念 ---- 直接...由 Linux 内核 启动的线程 , 被称为 " 内核线程 " ; " 内核线程 " 是一种 特殊进程 , 独立运行在 " 内核空间 " , 其将 " 内核函数 " 委托给 独立进程 , 该 " 独立进程..." 与 其它进程 ( 包括 普通进程 , 内核自身 , 用户级线程 ) 并行执行 ; " 内核线程 " 也称为 " 守护进程 " ; 二、内核线程、普通进程、用户线程 ---- 在 【Linux 内核...】进程管理 ( 进程特殊形式 | 内核线程 | 用户线程 | C 标准库与 Linux 内核中进程相关概念 | Linux 查看进程命令及输出字段解析 ) 一、进程特殊形式 ( 内核线程 | 用户线程...-5.6.18\include\linux\sched.h 四、内核线程主要用途 ---- 内核线程主要用途 : 内存同步 : 周期性执行如下同步操作 , 同步 " 修改的内存页 " 与 " 页来源块设备

3.7K20

Netty之线程唤醒wakeup

首先回顾下, Netty中的IO线程主要完成三件事 IO线程三件事 轮询IO事件 处理IO事件 执行任务 在轮询IO事件的过程中,在Linux系统下, 使用epoll实现....当任务提交到任务队列后, 那么就会面临一个问题.此时的IO线程处于阻塞状态, 是否需要唤醒它呢? 答案是需要唤醒, 之所以要把它唤醒, 是需要让IO线程可以及时的处理刚刚非IO线程提交的任务....IO线程调用select方法被阻塞, 非IO线程通过调用wakeup方法将IO线程唤醒. 接下来通过查看它的系统调用, 弄清楚它到底是如何实现的. 环境 1....selector.wakeup(); } } 以上代码的逻辑比较简单, 一个线程调用select()方法阻塞, 另一个线程唤醒它....使用grep命令搜索关键字epoll 通过epoll_create创建4号文件描述符. 5和7这两个文件描述符添加到epoll上(底层是添加到内核的红黑树).

45720

Java 线程的虚假唤醒

最近在学习Java多线程设计的时候,在网上看到一个面试题目的讨论,虽然楼主所说有些道理,但感觉还是有些问题,故此在和同事讨论以后还是有了若干收获,在此略作总结。 首先,来看看这个面试题目吧。...问题描述: 状况1: 假设有三个线程: A,B,C. A 负责放入数据到list,就是调用push操作, B,C分别执行Pop操作,移除数据。...A线程调用notify(),唤醒等待中的线程A。 如果此时, C获取到基于对象的锁,则优先执行,执行pop方法,获取数据,从list移除一个元素。...等待notify()、notifyAll()操作的唤醒。 存在被虚假唤醒的可能。 何为虚假唤醒?...虚假唤醒就是一些obj.wait()会在除了obj.notify()和obj.notifyAll()的其他情况被唤醒,而此时是不应该唤醒的。

29720

Java 线程的虚假唤醒

最近在学习Java多线程设计的时候,在网上看到一个面试题目的讨论,虽然楼主所说有些道理,但感觉还是有些问题,故此在和同事讨论以后还是有了若干收获,在此略作总结。 首先,来看看这个面试题目吧。...问题描述: 状况1: 假设有三个线程: A,B,C. A 负责放入数据到list,就是调用push操作, B,C分别执行Pop操作,移除数据。...A线程调用notify(),唤醒等待中的线程A。 如果此时, C获取到基于对象的锁,则优先执行,执行pop方法,获取数据,从list移除一个元素。...等待notify()、notifyAll()操作的唤醒。 存在被虚假唤醒的可能。 何为虚假唤醒?...虚假唤醒就是一些obj.wait()会在除了obj.notify()和obj.notifyAll()的其他情况被唤醒,而此时是不应该唤醒的。

95321

Java线程Linux内核线程的映射关系

Java线程Linux内核线程的映射关系Linux内核2.6开始使用NPTL (Native POSIX Thread Library)支持,但这时线程本质上还轻量级进程。...Java里的线程是由JVM来管理的,它如何对应到操作系统的线程是由JVM的实现来确定的。Linux 2.6上的HotSpot使用了NPTL机制,JVM线程内核轻量级进程有一一对应的关系。...线程的调度完全交给了操作系统内核,当然jvm还保留一些策略足以影响到其内部的线程调度,举个例子,在linux下,只要一个Thread.run就会调用一个fork产生一个线程。...Java线程在Windows及Linux平台上的实现方式,现在看来,是内核线程的实现方式。...看图: Java线程Linux内核线程的映射关系 (说明:KLT即内核线程Kernel Thread,是“内核分身”。

2.1K40

线程的阻塞和唤醒

Java的线程阻塞和唤醒是通过Unsafe类的park和unpark方法做到的。 两个方法都是native方法,本身由c实现的核心功能。...park:是让当前运行的线程Thread.currentThread()休眠。 unpark:是唤醒指定线程。 两个方法底层使用操作系统提供的信号量机制来实现。...Thread内部有个parkBlocker属性,保存来当前线程因为什么而park。起到一系列冲突线程的管理的协调者,哪个线程该休眠该唤醒都是由他来控制的。...Java的锁数据结构是通过调用LockSupport来实现休眠和唤醒的。线程对象里面的parkBlocker字段值是排队管理器。 当多个线程争用一把锁时,必须排队机制将那些没能取得锁的线程串在一起。...线程在执行Lock.park方法时会自我休眠,并不是非得等到其他线程unpark了才会唤醒,它可能因为某种未知原因醒来,park返回原因有四种: 其他线程unpark了当前线程

1.5K30

JUC - 线程中断与线程等待、唤醒(LockSupport)

了),返回当前值并清零置false 线程等待和唤醒 LockSupport是用来创建和其他同步类的基本线程阻塞原语 文档 LockSupport中的 park() 和 unpark() 的作用分别是阻塞线程和解除被阻塞的线程...三种线程等待唤醒的方式 使用Object的wait()方法让线程等待,使用 Object中的notify()方法唤醒线程 使用JUC包中Condition的await方法让线程等待,使用signal(...)方法唤醒线程 LockSupport类可以阻塞当前线程以及唤醒指定被阻塞的线程 Object private static void syncWaitNotify() { Object...,直到别的线程给当前线程发放permit,park方法才会被唤醒 unpark(Thread thread):唤醒,调用unpark(thread)方法后,就会将thread线程的许可证permit发放...为什么唤醒两次后阻塞两次,但最终结果还是会阻塞线程

86340

工作线程唤醒及创建(19)

平台来说,工作线程通过note睡眠其实是通过futex系统调用睡眠在内核之中,所以唤醒处于睡眠状态的线程也需要通过futex系统调用进入内核唤醒,所以这里的futexwakeup又继续调用包装了futex...系统调用的futex函数来实现唤醒睡眠在内核中的工作线程。...系统调用通过AX寄存器返回返回值,这里把返回值保存到内存之中 RET futex函数由汇编代码写成,前面的几条指令都在为futex系统调用准备参数,参数准备完成之后则通过SYSCALL指令进入操作系统内核完成线程唤醒功能...,内核在完成唤醒工作之后当前工作线程则从内核返回到futex函数继续执行SYSCALL指令之后的代码并按函数调用链原路返回,继续执行其它代码,而被唤醒的工作线程则由内核负责在适当的时候调度到CPU上运行...这些准备工作完成之后代码调用syscall指令进入内核,由内核帮助我们创建系统线程

86040

Java线程等待、唤醒通信机制详解

(线程阻塞、 线程唤醒) 示例 线程-1去买包子,没有包子,则不再执行 线程-2生产出包子,通知线程-1继续执行 4.1 suspend、resume(废弃) 调用suspend挂起目标线程 resume...wait 方法导致当前线程等待,加入该对象的等待集合中,并且放弃当前持有的对象锁。 notify/notifyAll 方法唤醒一个/所有正在等待这个对象锁的线程。...正常使用 死锁 synchronized 或 lock 线程先要获得并持有锁,必须在锁块(synchronized或lock)中。必须要先等待后唤醒线程才能够被唤醒。...官方推荐应该在循环中检查等待条件,因为处于等待状态的线程可能会收到错误警报和伪唤醒,如果不在循环中检查等待条件,程序就可能在没有满足结束条件的情况下退出。...伪唤醒是指线程并非因为notify、notifyall、 unpark等API调用而唤醒,而是更底层原因导致的。

73420
领券