找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10621|回复: 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);
    2 H: x/ K, `$ K
  2.   //
    8 I% e' u2 w% u
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed
    7 O1 _- F' [( Y& a8 \8 h' M
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump7 d( I8 N* m& O% [: y6 D$ n2 v
  5.   // All other return values for SetJump are undefined.! C6 K) D' G& S* m! G* M
  6.   //8 E: G3 h$ F( |9 }8 H/ ~9 }7 ]
  7.   if (Status == EFI_SUCCESS) {* [6 v' D! R' K. R8 ~0 Q

  8. ! b8 P. w- c( F
  9.     //- P9 ?: j8 w* M0 e# `) @6 R
  10.     // Call the image's entry point
    ) o% c8 X2 @4 T5 V
  11.     //
    ( m7 c- ~- z% A
  12.     Image->Started = TRUE;
    9 G$ e1 m# V& z  r6 U" `
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);' p# N5 `* g2 p0 |) o
  14. " }& Y; a4 n! i. y6 E8 D
  15.     //# \% E: l. S6 J% R: Z4 b" g' j- a
  16.     // Add some debug information if the image returned with error. ! N6 V& g9 v3 }! Y+ ~9 ~" U3 e# j
  17.     // This make the user aware and check if the driver image have already released & b) A$ A5 x, z
  18.     // all the resource in this situation. + l0 Y' N2 w9 s0 g) T* p+ Z
  19.     //' W) N' K; \( t1 V/ D
  20.     DEBUG_CODE (
    3 p  a3 p+ b7 Y: H" P
  21.       if (EFI_ERROR (Image->Status)) {
    & q# K8 ^* u; ?" P8 m
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    8 a2 M! o' z* R% _, b
  23.       }
    ) i1 @% R, k1 f: i' n
  24.     )1 |' d! v: g+ d% W" w9 |: ?4 Q
  25.     # h& Q" {/ g# a# R9 T& H
  26.     //
    1 i; W, h' m, M. D, @
  27.     // If the image returns, exit it through Exit()
      C& Q" ?% S- Q2 q" F1 _
  28.     //* m1 {- I7 F( p
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    / |  z/ I; r5 Q) Q' Q& U* q
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态: b; ^- S! O9 D+ t& w$ y
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
' C& I9 P! {8 B2 d) V8 H而且目前来看driver只会返回Status而已,根据这个就可以做处理了.* k) ^$ W4 Q) l9 b2 G" a* c

0 B8 H) r' d/ O) P" L/ B5 K& x5 H我感觉有点多此一举了...不解
发表于 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 S) v- l! m) N! U! n" v* R8 r# k& H0 o  z/ W8 M1 \# ?
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.3 L2 I3 f: ^# f2 T! T/ ^1 @1 s
没有用过,暂且记下了.
% N6 u) `  r' M. ?& e8 c& k
8 @' W3 A2 L- K+ x. T非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-4 14:45 , Processed in 0.166567 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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