找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10374|回复: 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);
    7 @: {1 p2 J; t( H6 t  ?) [/ ^- p
  2.   //# A( q- S5 c3 u  E% P- @$ M6 O% U* _
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed
    9 b& M4 w2 [$ g
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    3 I# E' R1 M1 g3 p# A& o2 b' @
  5.   // All other return values for SetJump are undefined.
    ! o! d. A" I% Z  B# O
  6.   //9 `# o3 c; j3 J( r
  7.   if (Status == EFI_SUCCESS) {
    2 h7 q1 {2 T' K

  8. " k7 ~- |+ X- {: X& \% u$ U7 ^  ^
  9.     //
    1 }  ^# q$ G0 F8 s5 c/ S
  10.     // Call the image's entry point8 G$ P' z5 \) h) K/ F
  11.     //
    * }- B! J& y9 `' P5 a* m* _
  12.     Image->Started = TRUE;
    - q( G/ ^1 b# A0 s
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);7 ]5 b. _# n/ k5 c# _* g  o
  14. 7 V! m% ]* \/ H7 G% x
  15.     //
    * P2 N0 }  W" I, m* @. r) }# Q4 ~8 G
  16.     // Add some debug information if the image returned with error. 7 |5 T" K( p. h5 K  ]9 P1 J8 ]# B
  17.     // This make the user aware and check if the driver image have already released
    / C/ S- Q1 a! V3 M+ P! d
  18.     // all the resource in this situation. 3 K0 m( u5 D9 E1 S% l9 C# U4 s
  19.     //
    ! I6 V" m& y. [. H) G
  20.     DEBUG_CODE (6 R$ o& f0 N0 R
  21.       if (EFI_ERROR (Image->Status)) {
    & a" J) W$ `  j, E5 v8 w$ M
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    & F# H3 I- \! j
  23.       }% ]0 Q2 }: Z- Q9 z7 H
  24.     )! W( V7 L% x! h; }& m/ g
  25.     0 a0 L0 K2 p1 S
  26.     //7 I7 k: L* N1 }% s5 \+ D
  27.     // If the image returns, exit it through Exit()  g" i" r' p3 d( K: H7 F6 x
  28.     //( k0 C- m% Z' G* ?; y) t4 U1 \0 m: T
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    & r5 \" K* b; |/ m! V; }
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态. ]7 `1 G0 y3 C1 ^; O9 X
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
* w* |  C% s  k5 y; x$ K而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
, I% G, ?/ m$ }- g4 |8 x/ {: m; ^- g5 O: q0 x: y' [2 n
我感觉有点多此一举了...不解
发表于 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 x! D, v% ]5 H
) [7 ], I, ]# Y; y( fEFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.( [6 A' d$ {3 g% p$ Z  ^! T# r
没有用过,暂且记下了.
, R1 K# e7 }' q2 S1 r% H3 h: G$ A  c6 ~: i3 w
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-18 22:45 , Processed in 0.057809 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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