• 操作系统之基础


    一、控制系统启动过程

    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的中断处理程序入口地址

  • 相关阅读:
    spacy 语言包离线安装
    linux 进程通信
    UNIX网络编程5 POSIX 消息队列
    UNIX网络编程 12 15共享内存区
    高级UNIX环境编程13 守护进程
    高级UNIX环境编程11 线程
    高级UNIX环境编程10 信号
    高级UNIX环境编程7 进程
    高级UNIX环境编程5 标准IO库
    高级UNIX环境编程4 文件和目录
  • 原文地址:https://www.cnblogs.com/zhengmingli/p/8048456.html
Copyright © 2020-2023  润新知