Update Booting/linux-bootstrap-2.md

This commit is contained in:
hailin cai
2016-02-24 11:44:23 -05:00
parent 83ba78a7dd
commit f473b96e1c

View File

@@ -521,7 +521,7 @@ static inline void set_fs(u16 seg)
接下来,内核会调用[query_apm_bios](https://github.com/torvalds/linux/blob/master/arch/x86/boot/apm.c#L21) 方法从BIOS获得 [高级电源管理](http://en.wikipedia.org/wiki/Advanced_Power_Management) 信息。`query_apm_bios`也是调用`0x15`中断,只不过将`ax`设置成0x5300以得APM设置信息。中断调用返回之后代码将检查`bx``cx`的值,如果`bx`不是`0x504d` ( PM 标记 ),或者`cx`不是0x02 (0x02表示支持保护模式),那么代码直接返回错误。否则,将进行下面的步骤。
接下来,代码使用`ax = 0x5304`来调用`0x15`中断,以断开`APM`接口;然后使用`ax = 0x5303`调用`0x15`中断,以连接到保护模式接口;最后使用`ax = 0x5300`调用`0x15`中断再次获取APM设置然后将信息写入`boot_params.apm_bios_info`
接下来,代码使用`ax = 0x5304`来调用`0x15`中断,以断开`APM`接口;然后使用`ax = 0x5303`调用`0x15`中断,使用32位接口重新连接`APM`;最后使用`ax = 0x5300`调用`0x15`中断再次获取APM设置然后将信息写入`boot_params.apm_bios_info`
需要注意的是,只有在`CONFIG_APM`或者`CONFIG_APM_MODULE`被设置的情况下,`query_apm_bios`方法才会被调用: