找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10779|回复: 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);& K  |8 N/ E+ E+ o/ s- M& Y
  2.   //
    0 j) Q) J* A/ `% Q, Q3 I; a: M2 D# O  k
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed/ T! G% F, n7 E) H& }  P
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    2 f  ]; B# E: o; ^5 x
  5.   // All other return values for SetJump are undefined.0 S, b9 o. Z( @2 H5 y, S/ S
  6.   //. ?; C0 E9 i% f& y0 m0 l- w
  7.   if (Status == EFI_SUCCESS) {. _  K3 a( f: f+ C8 i
  8. , g) j/ i( b& D4 K8 o
  9.     //
    , Z& [7 P2 p' f- I' J- }1 X
  10.     // Call the image's entry point
    1 R% |; s$ u3 h* U1 A' l
  11.     //1 v# C' T" l' ?, L( q% m
  12.     Image->Started = TRUE;
    8 i2 e7 V+ ~- p, @! j6 l5 w
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);
    , _5 K* o; R( b7 o2 r
  14. 7 Y+ |# t& J/ g+ ]2 g8 x7 P% b
  15.     //1 L2 Q# m: C3 |( m* {+ [5 B0 `
  16.     // Add some debug information if the image returned with error.
    $ {- ^4 z& E0 K  }( Z
  17.     // This make the user aware and check if the driver image have already released $ }4 O& o4 e1 k4 H/ k2 d
  18.     // all the resource in this situation. 1 _* B6 ^" r8 Y
  19.     //
    + y' L- n& T- ^: h4 M( K  Y
  20.     DEBUG_CODE (
    & b9 }) j) X# z) i. L
  21.       if (EFI_ERROR (Image->Status)) {! ?3 A, Z3 k- e+ C" k
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
      T1 [  R7 I& R* r' H
  23.       }- ~' g3 G7 v, K! U2 }
  24.     ), D9 Q! ]: [' o, ^2 [/ w  _$ J
  25.     - j6 O  G/ V: t
  26.     //
    7 Q$ A# x2 `* j& z8 m& v; N
  27.     // If the image returns, exit it through Exit(): s7 g# S% S* E6 S, [
  28.     //. n" U2 p; [# O- B8 q' Z
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    1 A+ I% `& u+ Q  p; e3 ]6 q
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态7 O9 g3 m$ G8 q
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?; t. M0 {  C+ h) X) g  M) }
而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
) ^' O& _: M* v( N) t  {3 q6 d$ V( Q
+ T0 Z( c  W1 o8 g  n% V我感觉有点多此一举了...不解
发表于 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。
3 Q: A- P0 N4 Z; L  p  h# w, ~3 }  B6 k7 M# J; ^
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.
: A! t1 b$ ^, M0 ?: T1 r- o. S没有用过,暂且记下了.+ y. f2 ?; Y2 i+ L5 ]8 x

/ Z. g% T9 B- V2 ]7 W4 N3 y& D0 D非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-8 08:32 , Processed in 0.073111 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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