学习中断确实是没坚持下来,重新捡起来。跟着up主大佬路线学习总结:
补充0X15中断功能号0XE820调用说明
一级页表中,假设经过段部件得到的线性地址为0x1234。到达页部件,高地址20位为1。1*4+cr3中页表的物理地址 就可以从该物理地址得到页面项0x9000,将此映射物理地址0x9000加上低12位,得到最终的物理地址0x9234。
进程一多,页表项占用的空间也很可观,此时需要动态创建页表,采用二级页表(此时cr3用来记录页目录物理地址(高20位,剩下12位都为0,故用来记录其余信息))。虚拟地址高10位用来定位页目录中的目录项,中间10位用来定位页表项,剩下12位用于页内偏移地址。清除cr3会使TLB(高速缓存)失效。
(gcc -m32 -E main.c -Ihttps://www.bilibili.com/read/include > test.c预处理,将宏展开。 gcc -m32 -S test.c > test.s编译成汇编文件。as -32 test.s -o test.o汇编成可执行文件。)
导入bochs-gdb,就可以直接在vscode里面打断点调试asm和c文件(-exec display/8xw $sp可以展示栈顶位置往下8个值,栈顶位于高地址,往低地址延。-exec x/i 0x080496eb(call指令压入的栈顶数据)可以查看此位置的指令)。
想补充的是,在控制台敲下指令的时候,在while里接收指令后会fork一个子进程去执行。当指令用|隔开,操作系统会用一条管道pipline(文件)连接父子进程,而这个管道在指令执行完后被关闭。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/197129.html