找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 9248|回复: 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);
    7 _3 z. {6 _9 ^) c1 N! j0 g
  2.   //! Z  o5 l& Y( A; `2 @: d% {4 Z# g
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed
    7 ?5 P$ g7 O3 `8 M/ y' G: K
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    * f' J& L2 Q' \. k4 `, w, Z6 b) k7 x$ C
  5.   // All other return values for SetJump are undefined.
    6 r" w$ L* T) c9 l8 O( x6 B- S) l
  6.   //
    2 m  H5 }9 }1 g) T8 r
  7.   if (Status == EFI_SUCCESS) {
    & K) s% K% y" Q: e- w/ o1 b/ t5 |6 Y

  8. & @7 U3 H- q# }
  9.     //* x/ H% g2 x; |) _
  10.     // Call the image's entry point& a! v" B/ s& x! e3 g
  11.     //, G; W# T% C6 W" @4 O" r
  12.     Image->Started = TRUE;
    ) J, T6 w0 b) l4 l; }7 H
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);
    , E. }  V1 Z$ ^+ P) L" d

  14. . v* ?& u+ J/ T' w; ?) S1 Y0 D2 E
  15.     //0 M) J/ _) S; R; D0 u
  16.     // Add some debug information if the image returned with error.   v$ B. |2 K+ ?# w+ o% q
  17.     // This make the user aware and check if the driver image have already released
    9 \% K. |+ r+ j9 V6 r! n( N4 g
  18.     // all the resource in this situation. & a* x) T, a; `; G9 _% V
  19.     /// K& b; d  J9 Q7 Q2 o0 ~
  20.     DEBUG_CODE (' N6 j& L1 B4 n* ?% a" n) @
  21.       if (EFI_ERROR (Image->Status)) {( }# u" c* q: [" |5 }7 X4 O
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    ) [3 G3 w  J: T1 N
  23.       }9 Y1 q+ H+ J7 Y3 |: i7 G
  24.     )
    $ q3 n: g  `5 ^" Z# N" ?& K- N
  25.    
    . [4 U1 I0 N5 s7 a+ D8 b. |
  26.     //$ _( y+ Z6 l/ Z3 Y7 V
  27.     // If the image returns, exit it through Exit()1 k. Z- P- U% m* E6 \
  28.     //
    / W% ~# n2 n+ }5 u' c* \
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);3 A: R" {" |3 ^, |' B0 C' b
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态3 _! m3 p9 ?( `! f: X
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
' q. i1 n, U) h而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
4 i' ?6 x0 u: I2 E: O# T  a( ~3 ~% z  v  e9 v7 y1 J/ }
我感觉有点多此一举了...不解
发表于 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。
: h9 @. U' B- ~
2 Z! r) ^8 n/ b2 a+ nEFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.
9 q) d+ ]5 V: }& N1 K- y, A9 a没有用过,暂且记下了.
, ^2 f/ \% D8 b- R" F7 n! A  `- [5 ?5 T0 I6 _
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 17:57 , Processed in 0.024018 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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