一、控制系统启动过程
1.要想顺利启动系统,bootsect.s必须让在磁盘的固定位置上,这个工作是由 make / makefile 完成的
2.启动保护模式以后,指令jmpi 0, 8和没有启动保护模式的区别:得出跳转地址的方式不一样
3.在setup中获取内存大小这一个硬件参数的目的是为后面的mem_init()做准备
4.在屏幕上打出“Loading System…”等系统Logo的时候,计算机内部正在:初始化内存管理数据结构、读磁盘、启动保护模式
5.Windows系统启动和Linux系统启动时,初始化内核数据结构不一样
6.根据GDT表,jmpi 0, 8要跳到0地址处去执行,那么能不能执行jmp 0呢?也可能,但首先要设置cs,并且要保证cs指向的那个GDT表项中的基地址为0
7.操作系统启动要完成的工作:初始化IDT表、初始化mem_map、初始化GDT表
8.mem_init就是初始化一个数组,如果某个数组项中的内容为0,则表示对应的那一段内存空闲;数组中的每个项表示固定大小的一段内存;mem_init调用之前可以不获得物理内存的大小;此外,并非初始化时将所有数组项中的内容都设置为0
二、系统接口
1.用户程序调用printf(“Hello World!”)最终要通过写显存来完成Hello World!的输出,从用户程序到写显存中间经过的顺序为:用户程序;C函数库;系统调用;sys_write;写显存
2.将程序的执行分为用户态和内核态是为了保护操作系统内核
3.在系统调用的实现中,在int 0x80指令调用之前,给eax赋值的目的是传递系统调用号
4.为什么称为系统调用:为了和其他的函数调用相区别,表现为一个函数调用,最终调用了操作系统提供的功能;而并非call了一个内核中的函数
5.鼓励操作系统实现POSIX接口的真正目的是上层应用程序可以移植
6.printf(“Hello World!”)中的字符串地址最终是通过寄存器和栈的配合以参数的形式传递给sys_write函数的
7.int 0x80是唯一能从CPL=3(用户态)到CPL=0(内核态)的指令跳转,所以应用程序中的系统调用要展开成一段包含int 0x80的代码
8.系统调用有open,printf,write等,但cos不是
9.Windows的系统接口和Linux接口的不一样导致了Windows上的程序不能在Linux上运行
10.在Linux上添加一个系统调用foo()的步骤有:在int 0x80的中断处理程序中增加对sys_foo的函数调用,修改sys_call_table这个函数表,将foo展开成一段包含int 0x80的代码;而不是设置int 0x80的中断处理程序入口地址