Update Booting/linux-bootstrap-2.md

This commit is contained in:
hailin cai
2016-02-24 11:47:03 -05:00
parent 30b2dc880f
commit 972604850c

2
Booting/linux-bootstrap-2.md Executable file → Normal file
View File

@@ -519,7 +519,7 @@ static inline void set_fs(u16 seg)
接下来,内核调用`query_ist`方法获取[Intel SpeedStep](http://en.wikipedia.org/wiki/SpeedStep)信息。这个方法首先检查CPU类型然后调用`0x15`中断获得这个信息并放入`boot_params`中。
接下来,内核会调用[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表示支持保护模式),那么代码直接返回错误。否则,将进行下面的步骤。
接下来,内核会调用[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`中断使用32位接口重新连接`APM`;最后使用`ax = 0x5300`调用`0x15`中断再次获取APM设置然后将信息写入`boot_params.apm_bios_info`