随笔分类 - Linux内核
摘要:1 /* kernel/power/earlysuspend.c 2 * 3 * Copyright (C) 2005-2008 Google, Inc. 4 * 5 * This software is licensed under the terms of the GNU G...
阅读全文
摘要:1. Oops信息来源及格式Oops这个单词含义为“惊讶”,当内核出错时(比如访问非法地址)打印出来的信息被称为Oops信息。Oops信息包含以下几部分内容:(1)一段文本描述信息。 比如类似“Unable to handle kernel NULL pointer dereference at v...
阅读全文
摘要:理论上:mutex和spinlock都是用于多进程/线程间访问公共资源时保持同步用的,只 是在lock失败的时候处理方式有所不同。首先,当一个thread 给一个mutex上锁失败的时候,thread会进入sleep状态,从而让其他的thread运行,其中就包裹已经给mutex上锁成功的那个 thr...
阅读全文
摘要:当我们在链表添加/修改多个节点后,我们最终是要通过查找链表中的某一个节点并对其数据进行操作,我们将逐一分析kernel/include/linux/list.h中关于链表遍历的接口。1,list_entry用于获取struct list_head结构体指针所在结构体变量的首地址。@ptr:指向我们要求首地址的结构体内的struct list_head成员变量,ptr的类型也为struct list_head。@type:要求首地址的结构体类型,即struct list_head变量所在的结构体的类型。@member:要求首地址结构体类型内struct list_head变量的变量名。/** .
阅读全文
摘要:Linux内核链表的操作定义在kernel/include/linux/list.h中,我们将逐一分析此文件中关于链表操作的接口。1,struct list_head的定义在kernel/include/linux/types.h中:struct list_head { struct list_head *next, *prev;};struct list_head类型的结构体包含了两个指向struct list_head结构类型的成员指针next和prev,因此我们可以看出struct list_head类型的变量可以进行双向链表的操作。2,静态初始化链表头节点:/* * Si...
阅读全文
摘要:中断通常被定义为一个事件,该事件改变处理器执行的指令顺序。这样的事件与CPU芯片内外部硬件电路产生的电信号相对应。 中断分为同步中断和异步中断: 同步中断是当指令执行时由CPU控制单元产生的,之所以称为同步,是因为CPU在每条指令执行结束前,都要检查是否有中断信号出现,如果有,那它就要在执行完当前指令之后,转入中断处理,而不继续执行下一条指令。 指令周期包含如下子周期: 取址(Fetch):将下一条指令由存储器读入CPU。 执行(Execute):解释操作码并完成指定的操作。 中断(interrupt):若中断是允许的并且有中断发...
阅读全文
摘要:等待队列在内核中很有用途,尤其用在中断处理、进程同步及定时。 等待队列实现了在事件上的条件等待:希望等待特定事件的进程把自己放进合适的等待队列,并放弃控制权。因为,等待队列表示一组睡眠的进程,当某一条件变为真时,由内核唤醒他们。1.每个等待队列都有一个等待队列头(wait queue head),等待队列头是一个类型为wait_queue_head_t的数据结构:struct __wait_queue_head { spinlock_t lock; struct list_head task_list;};typedef struct __wait_queue_head wa...
阅读全文
摘要:为了深刻描述程序动态执行过程的性质,人们引入“进程(Process)”概念。 进程的定义 进程是一个具有独立功能的程序关于某个数据集合的一次运行活动。它可以申请和拥有系统资源,是一个动态的概念,是一个活动的实体。它不只是程序的代码,还包括当前的活动,通过程序计数器的值和处理寄存器的内容来表示。它是系统进行资源分配和调度的一个独立单位。 进程的概念 进程的概念主要有两点:第一,进程是一个实体。每一个进程都有它自己的地址空间,一般情况下,包括文本区域(text region)、数据区域(data region)和堆栈(stack region)。文本区域存储处理器执行的代码;数据区域存...
阅读全文
浙公网安备 33010602011771号