Skip to content

Latest commit

 

History

History
68 lines (42 loc) · 3.38 KB

jyy_operate_system_notes.md

File metadata and controls

68 lines (42 loc) · 3.38 KB

我被游戏外挂视频吸引进 jyy 的操作系统课(最喜欢 2022 版敲代码部分比较多)

C 实现继承/多态黑魔法

生存指南里演示了虚函数多态和多继承的实现,国汽智能网联的 r4l 课程里面讲 Linux 源码的时候提到有不少结构体用到了类继承的写法

一些技巧来实现类似于继承的概念。这通常被称为结构体的嵌套。通过在一个结构体中嵌套另一个结构体,可以实现某种形式的代码复用和属性继承,并不是严格意义上的类继承

linux 源码中习惯把 dyn trait 类型命名成 xxx_ops, 对应 Rust for Linux 的 #[vtable] 宏?

AbstractMachine

代码仓库应该是: https://github.com/NJU-ProjectN/abstract-machine

文章有个错误案例是 64-bits 汇编解析成 32-bit 指令导致 Segmentation Fault

好消息是不用像 rcore 那样手搓 linker script, elf 似乎编译成 MBR 引导?

复位后只关心 cr0 和 cs/ip 寄存器

cr0 是处理器当前运行在 16/32/64 哪种 bits 模式, rip=pc=cs<<4+ip

gdb

jyy 视频里面 gdb 的配置好花哨,想起了 rcore 里面推荐的 gdb-dashboard

(图为 starti 停在程序的第一个指令和 bt full 命令)

layout asm/regs/src

弹出汇编代码的上半窗口, 再按 layout next 切回上一个 layout

info threads/inferiors 区别

info threads:这个命令用于显示程序中所有线程的信息。它会列出每个线程的唯一标识符(thread ID),当前所在的函数调用栈,以及其他线程相关的信息。您可以使用 info threads 来查看程序中所有线程的状态和调用栈信息,以便分析和调试多线程程序。

info inferiors:这个命令用于显示程序中所有子进程的信息。在 gdb 中,一个调试会话可能包含多个子进程,例如多进程程序或调试器本身产生的辅助进程等。info inferiors 命令可以显示每个子进程的唯一标识符(inferior ID),当前被调试的二进制文件路径,以及其他子进程相关的信息

!cat /proc/2717/maps

gdb 里面打印进程地址空间映射,注意不能用 /proc/self 不然打印成 cat 自身的

watch point

root@DESKTOP-1PU6QQH:~# cat asm_rdrand.c
#include <unistd.h>
int main() { while(1) {
asm volatile("rdrand %rax");
}}

(gdb) watch $rax

其他工具的使用

vim/gdb :!gcc 可以执行命令,vim 里面 :! file % 百分号等于指代当前文件

vim :%! grep stat % 可以将 grep 过滤后内容更新到当前 vim buffer

JTAG ≈ gdb(嵌入式)?

我不知道的 C 语法

the declaration char *m="1" "2" "3"; is a valid C syntax.

In C, adjacent string literals are concatenated, so "1" "2" "3" is equivalent to "123"

htop 的 load 表示在一段时间内待处理的任务数量,通常以三个数值表示,如"0.71 0.36 0.20"。这些数值对应于最近1分钟、5分钟和15分钟

gdb 确定到 Segmentation Fault 的位置,而它恰好是一条 SSE 指令 则很可能原因是没对齐(如果是 SIGILL 大概率是不支持 SSE 指令集)

pthread 线程默认是 “joinable” 的。joinable 的线程只要没有 join 过,资源就一直不会释放(produces a "zombie thread") 除非设置成 detach