找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 9914|回复: 3

请教: UEFI CoreStartImage中为什么用EFI_PEI_TRANSFER_CONTROL_PROTOCOL?

[复制链接]
发表于 2008-10-28 10:50:31 | 显示全部楼层 |阅读模式
EDK_20080905(各家IBV的应该类似),文件Image.c,在CoreStartImage(),如下一段中:
  1.   Status = gEfiPeiTransferControl->SetJump (gEfiPeiTransferControl, Image->JumpContext);, G5 f& ?* G7 ]$ E/ ?% m$ o. a
  2.   //6 G5 z( {. @" C- h( r4 V! [
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed0 E! @; T3 e1 [: j7 t6 w" s
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump: U6 m: l. I! e, ~
  5.   // All other return values for SetJump are undefined.+ s- s! ~- u' I/ V5 L. O1 g3 a
  6.   //
    : t/ K. _, s" {
  7.   if (Status == EFI_SUCCESS) {
    - E! V& G/ U2 M4 F

  8. . ?* P, P5 }5 I' b$ a
  9.     //7 [9 p" B: q! e6 \0 C4 A, x# s' }
  10.     // Call the image's entry point
    9 Y3 T2 Q" a* P: I8 b8 z  S8 R
  11.     //
    4 B& G% H. K0 q4 o1 u! D) c
  12.     Image->Started = TRUE;
    + y. y! b$ Q! ^& P
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);
    . c# Y1 {6 G1 k. J6 H
  14. , N9 w* q: h, j2 p+ E" S4 }% m
  15.     //
    ( D4 y9 h. M  m$ d" r
  16.     // Add some debug information if the image returned with error.
    " R0 |$ W" D" f8 N
  17.     // This make the user aware and check if the driver image have already released
    7 G- h- m# _4 t4 O2 F8 }6 a$ I
  18.     // all the resource in this situation. % M& j7 H1 `3 Y8 |
  19.     //
    & F- p5 |- e) L$ A* Y
  20.     DEBUG_CODE (
    & O2 q" [2 J3 O$ x, G
  21.       if (EFI_ERROR (Image->Status)) {
    6 d$ b0 m8 `9 M
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));" H. n" h* z- d* T
  23.       }
    $ M& e& w6 J4 ]7 R/ z
  24.     )
    & [3 ]6 @* r4 C9 w, H
  25.       k7 f* \* }" p$ I
  26.     //8 ^  i$ O5 R: s- S* M$ _& @
  27.     // If the image returns, exit it through Exit()2 S8 t& p8 P0 p: D6 W( ?
  28.     //
    ! M3 Q8 t+ d( V9 r4 |; v
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    6 ]- q$ o" Y, l5 s0 {5 X* J
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态* B) G) |* [$ Q1 E1 \
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?: ?; \7 k; ?8 Y, i1 C
而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
3 L% j- q0 u" J3 R& m0 r  a& ^/ I3 v" v# @4 S% z9 o
我感觉有点多此一举了...不解
发表于 2008-10-28 22:29:18 | 显示全部楼层
我觉得可能是要保证DXE driver之间的独立性吧。
回复

使用道具 举报

发表于 2008-10-29 13:42:13 | 显示全部楼层
C程序可以用return语句在main()里退出,也可以用exit()函数在程序里任何合适的地方退出。UEFI也提供了类似的机制,即Exit boot service。与从UEFI driver的入口函数中用return退出相比,用Exit()除了可以在其它的函数中直接退出,而不用先返回到入口函数再退出之外,还可以返回额外的Exit data。
2 X5 x# \' H; J( @6 W0 D9 u
5 S& i) r" S  O. N+ u4 ?6 pEFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.
6 ]+ C6 L, k9 ^; m没有用过,暂且记下了.* B* |- l0 e3 i
# S  k$ g6 ^' ~0 h3 i
非常感谢!!!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

Archiver|手机版|小黑屋|计匠网

GMT+8, 2025-5-23 10:55 , Processed in 0.033997 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表