深入解析Linux进程控制技巧

一个父进程可以创建多个子进程,而一个子进程只能有一个父进程。因此,对于子进程来说,父进程是不需要被标识的;而对于父进程来说,子进程是需要被标识的,因为父进程创建子进程的目的是让其执行任务的,父进程只有知道了子进程的PID才能很好的对该子进程指派任务。 为什么fork函数有两个返回值?父进程调用fork函数后,为了创建子进程,fork函数内部将会进行一系列操作,包括创建子进程的进程控制块、创建子进程的进程地址空间、创建子进程对应的页表等等。子进程创建完毕后,操作系统还需要将子进程的进

Linux内核低精度定时器原理解析

在学习数据结构课程时,我们知道用于快速查找有序数据的数据结构有如何几种:平衡二叉树最大堆/最小堆跳跃表…由于这些数据结构的时间复杂度都是log(n),对性能要求非常高的内核来说是不能接受的,所以内核使用了一种性能更高的数据结构:时间轮。时间轮能够保证在时间复杂度为log(1)的情况下找到将要到期的定时器,下面我们将会介绍时间轮的原理。时间轮的基本思想是通过数组来保存定时器,而数组的索引就是定时器的过期时间。如下图所示:如上图所示的数组中,索引为1的槽位存放

Linux设备树DTS入门指南

ARMdevicetree的来源:在过去的armlinux中,存在大量的冗余代码。这些设备代码与特定公司的单板启动或运行细节紧密耦合,无法被重用或移植。同时,内核缺乏引导标准,导致代码不断膨胀。最终,由于tonylindgren向linus发送了一封邮件,请求提交omap平台代码的修改,并附上了修改内容以及如何解决合并冲突的方法,使得linus怒不可遏地抱怨道:“该死。伙计们,这整个arm的事情真是个讨厌的麻烦。”。经过讨论后,对ARM平台相关代码做出了一些规范:ARM的核心代码

目录[+]