linux下的进程切换

1.进程切换首先要进行用户空间的切换,即将新进程页面目录的起始物理地址装入控制寄存器CR3.

static inline void switch_mm(struct mm_struct *prev,
                                         struct mm_struct *next,
                                         struct task_struct *tsk,
                                         unsigned cpu)
{
    ......
    asm volatile("movl %0, %%cr3": : "r" (__pa(next->pgd)));
    ....
}


值得注意的是此时cpu在系统空间内运行,所有进程的页面目录中与系统空间相对应的目录项都指向相同的目录表,所以每一个进程都有相同的页面目录。


2.然后进行堆栈的切换。

#define switch_to(prev, next, last) do {   \
    asm volatile("pushl %%esi \n\t"         \
                       "pushl %%ebi \n\t"         \
                       "pushl %%ebp \n\t"         \
                       "movl %%esp, %0 \n\t"     \                 // save ESP for prev
                       "movl %3,%%esp \n\t"     \                  // restore ESP to next
                       "movl $1f, %1 \n\t"         \                   // set EIP for prev 
                       "pushl %4 \n\t"               \                   // restore EIP for next, which is $1f
                       "jump __switch_to \n"       \                  // ret and set EIP to %4
                       "1:\t"                            \                    
                       "popl %%ebp \n\t"        \
                      "popl  %%ebi \n\t"          \
                      "popl  %%esi  \n\t"          \
                     :"=m" (prev->thread.esp), "=m" (prev->thread.eip), \
                     :"=b" (last)                   \
                     :"m" (next->thread.esp), "m"(next->thread.eip),       \
                     "a" (prev), "d" (next),           \
                     "b" (prev)) ;                       \
} while(0)


Linux进程切换是指操作系统内部的一种调度机制,它允许计算机在同一时刻执行多个独立的任务,每个任务表现为一个进程。当一个进程运行时,CPU会分配给它一段时间的处理时间片。当时间片用完或者遇到了I/O操作(如读写磁盘)等不可预见的操作需要阻塞时,处理器会按照某种策略(通常是抢占式调度)将控制权交给其他进程。 在Linux下,进程切换通常由内核的调度器完成,主要包括以下几个关键点: 1. **进程就绪队列**:所有能够运行的进程都放在一个或多个就绪队列中,当有进程的时间片用尽时,会被移到就绪队列。 2. **调度算法**:Linux提供了多种调度算法,如Round Robin(轮转调度)、Priority Scheduling(优先级调度)等。调度器会选择下一个应被执行的进程,依据算法规则进行选择。 3. **中断和信号处理**:进程可能会因为外部事件(如用户输入、定时器中断)而被打断,这时会进入中断处理或信号处理阶段,然后恢复到之前的位置继续执行。 4. **上下文切换**:当从一个进程切换到另一个进程时,系统会保存前者的寄存器信息、内存映射等上下文,以便于恢复切换后的进程状态。 通过这种方式,Linux允许多个进程并发执行,提高系统的效率和响应速度。当用户需要查看或管理进程时,可以使用`ps`, `top`, 或者`jobs`等命令。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值