我正在尝试理解pinto引导加载程序的代码,在某一行中有些东西让我感到奇怪。
addr32 movl %eax, init_ram_pages - LOADER_PHYS_BASE - 0x20000
这里的这一行应该将4K页面的数量放入头文件中定义的变量init_ram_pages中:extern uint32_t init_ram_pages;
我不明白的是为什么我们要从init_ram_pages
中减去这些值?在mov
的目标操作数中进行减法操作是什么意思?
查看更多详细信息:
在%eax中设置内存大小(以4K页面为单位)的代码如下:(如果我理解正确的话)
movb $0x88, %ah
int $0x15
addl $1024, %eax # Total kB memory
cmp $0x10000, %eax # Cap at 64 MB
jbe 1f
mov $0x10000, %eax
1: shrl $2, %eax # (shift right by two = divide by 4)
# now eax contains the number of 4K pages I guess?
常量定义为:
/* Kernel virtual address at which all physical memory is mapped.
Must be aligned on a 4 MB boundary. */
#define LOADER_PHYS_BASE 0xc0000000 /* 3 GB. */
编辑
变量本身在同一个文件中定义如下:(在文件中.code32后面的部分中)
#### Physical memory size in 4 kB pages. This is exported to the rest
#### of the kernel.d
.globl init_ram_pages
init_ram_pages:
.long 0
减法没有什么特别的,它只是一个简单的汇编或链接时间操作。在最终的二进制文件中,将显示计算结果。
我假设这是引导加载程序的实模式部分,但它使用保护模式内存映射进行组装/链接。这个调整大概是在汇编程序生成代码时使用的保护模式地址和cpu在运行该代码时实际使用的实模式地址之间进行转换的。