linux内核设计与实现

在这里插入图片描述

进程上下文

可执行文件载入进程空间运行代码。
linux的进程继承关系,所有进程都是init进程(pid == 1)的后代,系统启动的最后阶段启动init进程。

进程创建

写时拷贝

只有在实际写入的时候才会拷贝。
fork的实际开销: 复制父进程的页表和子进程创建的唯一的进程描述符。

fork

fork() -> clone() -> do_fork()

copy_process()
在这里插入图片描述
在这里插入图片描述

线程

线程只是共享某些资源的进程。每个线程都有自己的task_struct。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

进程终结

exit() -> do_exit()
在这里插入图片描述

删除进程描述符

wait_pid -> release_task()
在这里插入图片描述

孤儿进程

init进程会调用wait 等待子进程,清除所有的僵死进程。

3 调度

3.1 策略

优先级高的先运行,优先级高的时间片也长。
在这里插入图片描述
在这里插入图片描述
时间片
在这里插入图片描述

进程抢占

可执行队列

可执行队列时给定处理器上的可执行进程的链表,每个处理器一个。
在这里插入图片描述

优先级数组

14 页高速缓存和页回写

页高速缓存结构

在这里插入图片描述

a_ops 操作函数表

在这里插入图片描述

读页面过程

(1)在页高速缓存中搜索数据
(2)如果没有,内核分配一页,加入到页缓存中。
(3)调用read_page()函数,从磁盘读入,加入到页缓存中,然后返回用户

写页面过程

一、文件映射
(1)当页面修改了,直接调用 set_page_dirty(page) 函数
二、文件写操作
(1)在页面缓存中搜索页面。
(2)如果不在,内核在高速缓存中分配一页。
(3)调用prepare_write() 创建一个写请求,将数据从用户空间拷贝到内核缓冲中。
(4)通过commit_write() 函数将数据拷贝到磁盘。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值