找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 9573|回复: 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);
    % n' I0 Z  a- ~& R; B
  2.   //6 o% z7 p7 i- V$ t6 |) t
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed* v7 V, r  ?. }
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump; ]) P8 e+ s$ D! y% C8 G) a
  5.   // All other return values for SetJump are undefined.1 v+ e! j, ]+ b  P
  6.   //
    * M* }3 G- k! b9 b8 ]0 E/ k: t
  7.   if (Status == EFI_SUCCESS) {/ v# c  f+ r+ ]% Y/ U4 I, I$ |* H
  8. 7 B- |6 f9 H6 @$ o1 k
  9.     //
    6 H% \% _! z( R
  10.     // Call the image's entry point. C* }  R& w$ N& ]
  11.     //
    * D7 ^  @, o" Z" ^- t# W2 B. g+ n
  12.     Image->Started = TRUE;. _8 N1 |9 w  o9 ?* i4 O
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);
    0 W; F5 H/ @3 Z

  14. 3 n7 D2 R' Q. l* |2 e$ l9 ~8 E! b7 c
  15.     //( F! y* r1 k# i) w5 E/ \
  16.     // Add some debug information if the image returned with error. ' O$ e, ]( U# g/ i
  17.     // This make the user aware and check if the driver image have already released 7 H3 H% P) |- c6 Q) D
  18.     // all the resource in this situation. & z# ^. ?) I% V+ K8 g$ V8 i0 U6 V
  19.     //
    8 N3 j8 t" Z3 w0 ^) [* ]
  20.     DEBUG_CODE (
    # ?4 l6 I8 y" e9 g& l8 K
  21.       if (EFI_ERROR (Image->Status)) {  {, E* N: l8 d6 R( v8 {; V
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));( {7 m! S) p3 \( x9 ?& t* @
  23.       }
    : L8 N3 D+ M- G) X: v: p8 a
  24.     )
    / g* [  i$ [" B8 `& I( r9 g8 G4 n6 Y
  25.    
    7 k3 W9 o& d& \5 @
  26.     //
    0 z# T) a% ~4 a
  27.     // If the image returns, exit it through Exit()
    & Y* M3 G% W9 u
  28.     //
    8 }& z! X3 X7 o5 t% X& n
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    , H8 u2 r. b6 ~; E1 q( b9 `
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态
( e  o& o- h4 k8 E! v9 @( F2 f; d2 I既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?$ j  c5 B" J" a0 j* j( s
而且目前来看driver只会返回Status而已,根据这个就可以做处理了." Q% Y3 n- O+ q) ^
8 K4 R- G* E( @0 G  F+ n* t
我感觉有点多此一举了...不解
发表于 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。9 n1 Q# s/ G( Y9 `

* D0 a6 B9 W  l% R( a# yEFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.1 O4 ~" b+ l( e6 l2 }5 }
没有用过,暂且记下了.
, I6 N) x8 u" q0 }0 N
6 U+ a5 a/ L6 T, w非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-21 18:58 , Processed in 0.026852 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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