getmemsize(), 1419行. 找出并计算所有可用之记忆体, 并保留 msgbuf (保留在 avail_end 後面, MSGBUF_SIZE 大小).
init386(), 1802行. 参数 first 为未使用的 free mem addr (physfree).
1824-1825行, preload_bootstrap_relocate(), kern/subr_module.c, 234行, relocate 预先载入(preload)的 kernel module. 执行 loader 的动作, 修改 module 的 address depend 资料.
1839-1860行, 设定 gdt (global descriptor table). 由於 gdt 的格式较为 杂, 因此有所谓的 soft_segment_descriptor (ssd), i386/include/segments.h, 165行, gdt_segs 就是 ssd list, 让 gdt 较容易操作. 因此在 1853-1860行, 必需进行 转换动作, 由 ssdtosd(), i386/i386/support.s, 157行, 从 ssd 转换 成 CPU 所能接受的 segment descriptor 格式.
1862-1864行, load gdt, 使刚设好的 gdt 发生作用. lgdt(), i386/i386/support.s, 1521行.
1885-1894行, 设定 ldt.
1897-1923行, 设定 idt. 所有的 idt entry 都指向 vector routines, i386/i386/exception.s, 122行. 每一个 trap or fault 都会有对应的 entry point, 作为实 际 isr 和 cpu 之间介面. 关於上述介面, 另见专文.
1928行, cninit(), console 初始化.
1932行, isa_defaultirq(), i386/isa/intr_machdep.c, 219行. 设定 isa device 所使用的 irq (设定 icu;8259), 并设定对应的 isr.
1948-1955行, 设定并安装 tss.
1971行, getmemsize(), i386/i386/machdep.c, 1419行, 找出并计算所有可用之 memory, 并保留 msgbuf. getmemsize 会设立几个 global 变数. physmem 实际可用的 page 数目. Maxmem physcial memory address 的最大值. phys_avail list of 可用的 mem block. avail_start 由 pmap_bootstrap(). avail_end 最大可用之 physcial memory address. 所有的分配都必需小於这个位址.
1976-1979行, msgbuf initialization.
1982-1995行, install a call gate for system call.
1999-2008行, setup process 0. |