找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10254|回复: 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);
      a2 \1 c/ g+ }7 z7 E9 ~+ ^
  2.   //' s$ d( Z% K# z& J& y: b4 G
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed  d9 n0 S& @0 t6 R6 X9 Q$ U: b" x
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump9 |# l0 H5 {4 y% X
  5.   // All other return values for SetJump are undefined.* a/ Q* i2 ]# t9 L- g
  6.   //
    . [1 F! c6 V! _! F; N
  7.   if (Status == EFI_SUCCESS) {+ i9 z+ r6 m$ j: H2 `4 Y
  8. % C5 t; z; t: p1 m
  9.     //1 H; \, k! ~) U; e/ m
  10.     // Call the image's entry point
    6 K1 s( c: t; v! S
  11.     //
    7 g, G8 w- _* a$ ?* k
  12.     Image->Started = TRUE;9 G; r% ~1 M% D$ v) H7 m
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);
    . }: a. l# a/ [0 Z$ _9 M6 W

  14. , l, D. _6 Q4 [
  15.     //
    " l) D0 w& [9 y4 W" Q
  16.     // Add some debug information if the image returned with error.
    & t& J' X1 S( I" ^6 a
  17.     // This make the user aware and check if the driver image have already released
    ' Z9 m) f$ r8 k
  18.     // all the resource in this situation.
    , A# F8 o! {. @; L8 c' s
  19.     //
    5 R5 f4 V- v8 R! p! m7 f
  20.     DEBUG_CODE (
    - i: C8 J2 I3 w4 m# w) z  P
  21.       if (EFI_ERROR (Image->Status)) {' `9 R- p3 h3 a# b
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));) [0 w& n$ y( B9 l& J" C
  23.       }
      p5 y  x# a2 R* l
  24.     )
    1 w: X% {# I$ j0 E1 V' E
  25.    
    : _9 M) N9 ]% \1 g5 I- F
  26.     /// y! _4 G. q" b  Y  ~9 R6 h5 p
  27.     // If the image returns, exit it through Exit()1 i$ o; k' N( K" |
  28.     //; |1 i$ S0 j/ h( O+ R
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);% h, E0 B/ ]/ n* ~4 J0 M, q2 _  Y
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态. i$ Y  H: G( ?1 |" `5 C. g  ~
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?* C% Y% I1 p) I$ B% b6 ~- }
而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
9 v8 h$ f' \- N% O$ W- ?- S5 S" {# E
我感觉有点多此一举了...不解
发表于 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。7 `) u0 |1 }) \' _7 L! E

' e, Y" U# |$ B! jEFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.) j# F( e0 _! T1 U
没有用过,暂且记下了.
5 x4 \3 S% B* H) n% D2 D. q# Z: g3 T# R
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-21 17:20 , Processed in 0.086093 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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