找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10842|回复: 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);
    * N8 j- G, M; ]0 u; b
  2.   //
    % k7 f% m+ p  x' d  I0 ~  D% g
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed' W/ T, a1 N, `( T
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump5 f- Z$ l# W; I# K2 f9 k
  5.   // All other return values for SetJump are undefined.
    , w: d. o3 c3 u0 H
  6.   //
      S' F- e7 t* r( @/ M. S
  7.   if (Status == EFI_SUCCESS) {
    6 _' N0 Q6 h9 K2 M

  8. ; C$ G' B( Z+ {
  9.     //# U( f( ^" _0 B2 X8 B1 a
  10.     // Call the image's entry point
    & [: l: o3 ^7 U* r% _7 X- ]
  11.     //
    1 }0 n1 }* s) O1 b/ Z4 K7 q
  12.     Image->Started = TRUE;$ u5 n1 E; s0 u: t
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);2 X+ h6 ~, O+ `" O9 v
  14. 5 f& ^5 Q) |8 |! i' k4 V
  15.     //
    * g3 F, c4 [, Y/ }
  16.     // Add some debug information if the image returned with error. 0 j" `8 f9 o( y- P
  17.     // This make the user aware and check if the driver image have already released 1 p3 _) \6 y! J' w* S; n
  18.     // all the resource in this situation.
    % c9 j1 x; g. B2 K
  19.     //
    4 V7 M" L" p" E) Z
  20.     DEBUG_CODE (2 c$ ^5 f% Q% N  p7 T) U
  21.       if (EFI_ERROR (Image->Status)) {
    5 R2 t6 I, q# J& [
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));! u- `/ e' T* W$ F
  23.       }, [, U* o0 z6 e/ D/ R2 x
  24.     )
    , Y. E9 p3 r% J: l! o
  25.     0 ^; Y9 C6 F+ l. N6 r6 b% W5 M
  26.     //3 t% `, k7 c, D
  27.     // If the image returns, exit it through Exit()
    + `: j! R3 ?3 H  W5 X/ f
  28.     //
    , b* c5 p! U7 n7 |5 Z7 B
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);: p! ?4 x: r$ _7 e- r6 E
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态
& M) B- I9 n. L9 N" T; }3 e  G既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
$ I2 u5 ^& L. S2 g& L6 b; z. M9 Z而且目前来看driver只会返回Status而已,根据这个就可以做处理了.  `0 G9 f+ m& F
. w+ y/ u" h  q" C! {1 b+ m
我感觉有点多此一举了...不解
发表于 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。
# {6 {% x0 l: j: C; v  V$ k- }. ~. C& G6 `( q
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.& U* U1 y) ?; I4 ?" Q2 b+ R/ v
没有用过,暂且记下了.
' f) y, x' f1 x! o& t5 d# ?; V$ o4 D7 l( N6 R- N
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-29 04:25 , Processed in 0.701101 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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