找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 9955|回复: 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);
    4 n, }" h2 |8 k  o4 [9 H! _0 M
  2.   //  ]6 B: v) S9 O9 ^9 V9 {
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed
    5 p/ Z. [6 J% b6 A
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    . p% P+ J5 z% d
  5.   // All other return values for SetJump are undefined.
    , O! t# K2 i: U+ ?
  6.   //
      f) T5 r5 d. T5 j
  7.   if (Status == EFI_SUCCESS) {7 |, {' m! U. d
  8. ) G' H1 x! N' m; k
  9.     //
    ' A9 T7 J( b, H- I  D
  10.     // Call the image's entry point
    ) H% |( O% J  B; B7 ?" W4 Q& o
  11.     //
    - {1 x) u, f7 @7 o
  12.     Image->Started = TRUE;) J) J1 q- a1 @
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);9 @, o. ~) X0 v; V9 x* B/ Q

  14. 4 \2 [9 a, h9 E' b* D" N
  15.     //4 K; _% c- i0 D1 J
  16.     // Add some debug information if the image returned with error. 2 R$ k" j6 e) `3 R9 `2 W" I6 \3 T
  17.     // This make the user aware and check if the driver image have already released
    . q5 c5 I$ M. w! e' m
  18.     // all the resource in this situation. ) l; f+ a8 R- N' Z+ b3 ]
  19.     //
    ' q  I: F# z- J
  20.     DEBUG_CODE (8 v" b& Q/ ?. h+ k
  21.       if (EFI_ERROR (Image->Status)) {
    / u6 z; f5 z: R9 P
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    6 N( h6 q# R  j0 S6 C
  23.       }" ~( }, ?; |. H
  24.     )1 }3 k& M% ~7 x( ?: B* C
  25.    
    * Q) x! M) U: j4 j
  26.     //4 d  U" d' s+ H) P: X( W; k
  27.     // If the image returns, exit it through Exit()
    ! s+ T0 r- q+ Y: q- m. l$ M
  28.     //1 J  Y  [! o5 G* g% v
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    ( Q; C7 G5 s, u1 C+ X8 s1 o
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态! g/ H; ^* ~6 r3 V0 i# G
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
! j1 T/ J1 Q4 k( d7 a而且目前来看driver只会返回Status而已,根据这个就可以做处理了.. g4 L4 U: w  G5 m! y! C

% v% @4 U' B0 \1 i我感觉有点多此一举了...不解
发表于 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。* ~# v+ w8 t. |! n$ V* B
9 ?5 W$ s9 _- {7 m( d
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.
) ~% I  S) {# x7 J$ t- y没有用过,暂且记下了.
/ ^% d( Y+ N# Z8 I9 N0 g) Z' s: }: L$ T9 u# n
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-16 19:35 , Processed in 0.105467 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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