02 2014 档案
摘要:中断通常被定义为一个事件,该事件改变处理器执行的指令顺序。这样的事件与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号