From db895182b962e72944d9e1f38318d0c33e0b87b4 Mon Sep 17 00:00:00 2001 From: Yourtion Date: Mon, 11 Apr 2016 18:06:12 +0800 Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0=E6=B1=89=E5=8C=96=E7=9B=B8?= =?UTF-8?q?=E5=85=B3=E5=86=85=E5=AE=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- 06_day/bootpack.c | 6 ++-- 07_day/bootpack.c | 6 ++-- 08_day/asmhead.nas | 68 +++++++++++++++++++++++----------------------- 08_day/bootpack.c | 8 +++--- 4 files changed, 44 insertions(+), 44 deletions(-) diff --git a/06_day/bootpack.c b/06_day/bootpack.c index 58547ae..d40ac60 100644 --- a/06_day/bootpack.c +++ b/06_day/bootpack.c @@ -11,7 +11,7 @@ void HariMain(void) init_gdtidt(); init_pic(); - io_sti(); /* IDT/PICの初期化が終わったのでCPUの割り込み禁止を解除 */ + io_sti(); /* IDT/PIC的初始化已经完成,于是开放CPU的中断 */ init_palette(); init_screen8(binfo->vram, binfo->scrnx, binfo->scrny); @@ -22,8 +22,8 @@ void HariMain(void) sprintf(s, "(%d, %d)", mx, my); putfonts8_asc(binfo->vram, binfo->scrnx, 0, 0, COL8_FFFFFF, s); - io_out8(PIC0_IMR, 0xf9); /* PIC1とキーボードを許可(11111001) */ - io_out8(PIC1_IMR, 0xef); /* マウスを許可(11101111) */ + io_out8(PIC0_IMR, 0xf9); /* 开放PIC1和键盘中断(11111001) */ + io_out8(PIC1_IMR, 0xef); /* 开放鼠标中断(11101111) */ for (;;) { io_hlt(); diff --git a/07_day/bootpack.c b/07_day/bootpack.c index 8d2618d..80cca35 100644 --- a/07_day/bootpack.c +++ b/07_day/bootpack.c @@ -15,12 +15,12 @@ void HariMain(void) init_gdtidt(); init_pic(); - io_sti(); /* IDT/PICの初期化が終わったのでCPUの割り込み禁止を解除 */ + io_sti(); /* IDT/PIC的初始化已经完成,于是开放CPU的中断 */ fifo8_init(&keyfifo, 32, keybuf); fifo8_init(&mousefifo, 128, mousebuf); - io_out8(PIC0_IMR, 0xf9); /* PIC1とキーボードを許可(11111001) */ - io_out8(PIC1_IMR, 0xef); /* マウスを許可(11101111) */ + io_out8(PIC0_IMR, 0xf9); /* 开放PIC1和键盘中断(11111001) */ + io_out8(PIC1_IMR, 0xef); /* 开放鼠标中断(11101111) */ init_keyboard(); diff --git a/08_day/asmhead.nas b/08_day/asmhead.nas index c5bce1b..b9448a0 100644 --- a/08_day/asmhead.nas +++ b/08_day/asmhead.nas @@ -5,7 +5,7 @@ BOTPAK EQU 0x00280000 ; 加载bootpack DSKCAC EQU 0x00100000 ; 磁盘缓存的位置 DSKCAC0 EQU 0x00008000 ; 磁盘缓存的位置(实模式) -; BOOT_INFO相关 +; BOOT_INFO 相关 CYLS EQU 0x0ff0 ; 引导扇区设置 LEDS EQU 0x0ff1 VMODE EQU 0x0ff2 ; 关于颜色的信息 @@ -15,7 +15,7 @@ VRAM EQU 0x0ff8 ; 图像缓冲区的起始地址 ORG 0xc200 ; 这个的程序要被装载的内存地址 -; 画面モードを設定 +; 画面设置 MOV AL,0x13 ; VGA显卡,320x200x8bit MOV AH,0x00 @@ -25,25 +25,25 @@ VRAM EQU 0x0ff8 ; 图像缓冲区的起始地址 MOV WORD [SCRNY],200 MOV DWORD [VRAM],0x000a0000 -; 通过BIOS获取指示灯状态 +; 通过 BIOS 获取指示灯状态 MOV AH,0x02 INT 0x16 ; keyboard BIOS MOV [LEDS],AL -; 防止PIC接受所有中断 -; AT兼容机的规范、PIC初始化 -; 然后之前在CLI不做任何事就挂起 -; PIC在同意后初始化 +; PIC关闭一切中断 +; 根据AT兼容机的规格,如果要初始化PIC, +; 必须在CLI之前进行,否则有时会挂起。 +; 随后进行PIC的初始化。 MOV AL,0xff OUT 0x21,AL - NOP ; 不断执行OUT指令 + NOP ; 如果连续执行OUT指令,有些机种会无法正常运行 OUT 0xa1,AL - CLI ; 进一步中断CPU + CLI ; 禁止CPU级别的中断 -; 让CPU支持1M以上内存、设置A20GATE +; 为了让CPU能够访问1MB以上的内存空间,设定A20GATE CALL waitkbdout MOV AL,0xd1 @@ -53,18 +53,18 @@ VRAM EQU 0x0ff8 ; 图像缓冲区的起始地址 OUT 0x60,AL CALL waitkbdout -; 保护模式转换 +; 切换到保护模式 [INSTRSET "i486p"] ; 说明使用486指令 LGDT [GDTR0] ; 设置临时GDT MOV EAX,CR0 - AND EAX,0x7fffffff ; 使用bit31(禁用分页) + AND EAX,0x7fffffff ; 设bit31为0(禁用分页) OR EAX,0x00000001 ; bit0到1转换(保护模式过渡) MOV CR0,EAX JMP pipelineflush pipelineflush: - MOV AX,1*8 ; 写32bit的段 + MOV AX,1*8 ; 可读写的段 32bit MOV DS,AX MOV ES,AX MOV FS,AX @@ -73,32 +73,31 @@ pipelineflush: ; bootpack传递 - MOV ESI,bootpack ; 源 - MOV EDI,BOTPAK ; 目标 + MOV ESI,bootpack ; 转送源 + MOV EDI,BOTPAK ; 转送目标 MOV ECX,512*1024/4 CALL memcpy -; 传输磁盘数据 +; 磁盘数据最终转送到它本来的位置去 +; 首先从启动扇区开始 -; 从引导区开始 - - MOV ESI,0x7c00 ; 源 - MOV EDI,DSKCAC ; 目标 + MOV ESI,0x7c00 ; 转送源 + MOV EDI,DSKCAC ; 转送目标 MOV ECX,512/4 CALL memcpy ; 剩余的全部 - MOV ESI,DSKCAC0+512 ; 源 - MOV EDI,DSKCAC+512 ; 目标 + MOV ESI,DSKCAC0+512 ; 转送源 + MOV EDI,DSKCAC+512 ; 转送源目标 MOV ECX,0 MOV CL,BYTE [CYLS] - IMUL ECX,512*18*2/4 ; 除以4得到字节数 - SUB ECX,512/4 ; IPL偏移量 + IMUL ECX,512*18*2/4 ; 从柱面数变换为字节数/4 + SUB ECX,512/4 ; 减去 IPL 偏移量 CALL memcpy -; 由于还需要asmhead才能完成 -; 完成其余的bootpack任务 +; 必须由asmhead来完成的工作,至此全部完毕 +; 以后就交由bootpack来完成 ; bootpack启动 @@ -106,19 +105,20 @@ pipelineflush: MOV ECX,[EBX+16] ADD ECX,3 ; ECX += 3; SHR ECX,2 ; ECX /= 4; - JZ skip ; 传输完成 - MOV ESI,[EBX+20] ; 源 + JZ skip ; 没有要转送的东西时 + MOV ESI,[EBX+20] ; 转送源 ADD ESI,EBX - MOV EDI,[EBX+12] ; 目标 + MOV EDI,[EBX+12] ; 转送目标 CALL memcpy skip: MOV ESP,[EBX+12] ; 堆栈的初始化 JMP DWORD 2*8:0x0000001b waitkbdout: - IN AL,0x64 - AND AL,0x02 - JNZ waitkbdout ; AND结果不为0跳转到waitkbdout + IN AL,0x64 + AND AL,0x02 + IN AL,0x60 ; 空读(为了清空数据接收缓冲区中的垃圾数据) + JNZ waitkbdout ; AND的结果如果不是0,就跳到waitkbdout RET memcpy: @@ -127,14 +127,14 @@ memcpy: MOV [EDI],EAX ADD EDI,4 SUB ECX,1 - JNZ memcpy ; 运算结果不为0跳转到memcpy + JNZ memcpy ; 减法运算的结果如果不是0,就跳转到memcpy RET ; memcpy地址前缀大小 ALIGNB 16 GDT0: RESB 8 ; 初始值 - DW 0xffff,0x0000,0x9200,0x00cf ; 写32bit位段寄存器 + DW 0xffff,0x0000,0x9200,0x00cf ; 可以读写的段(segment)32bit DW 0xffff,0x0000,0x9a28,0x0047 ; 可执行的文件的32bit寄存器(bootpack用) DW 0 diff --git a/08_day/bootpack.c b/08_day/bootpack.c index 401f1af..b0a023f 100644 --- a/08_day/bootpack.c +++ b/08_day/bootpack.c @@ -17,18 +17,18 @@ void init_keyboard(void); void HariMain(void) { struct BOOTINFO *binfo = (struct BOOTINFO *) ADR_BOOTINFO; - struct MOUSE_DEC mdec; char s[40], mcursor[256], keybuf[32], mousebuf[128]; int mx, my, i; + struct MOUSE_DEC mdec; init_gdtidt(); init_pic(); - io_sti(); /* IDT/PICの初期化が終わったのでCPUの割り込み禁止を解除 */ + io_sti(); /* IDT/PIC的初始化已经完成,于是开放CPU的中断 */ fifo8_init(&keyfifo, 32, keybuf); fifo8_init(&mousefifo, 128, mousebuf); - io_out8(PIC0_IMR, 0xf9); /* PIC1とキーボードを許可(11111001) */ - io_out8(PIC1_IMR, 0xef); /* マウスを許可(11101111) */ + io_out8(PIC0_IMR, 0xf9); /* 开放PIC1和键盘中断(11111001) */ + io_out8(PIC1_IMR, 0xef); /* 开放鼠标中断(11101111) */ init_keyboard();