找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10763|回复: 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);. t. H( v! ?4 i$ S: K
  2.   //" v& f& y1 d8 }
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed2 X  N/ T1 r( V+ b
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump- j5 r( V. z6 I; ?0 Q
  5.   // All other return values for SetJump are undefined.! |  q- g& X4 a8 h7 Y" s# b
  6.   //
    5 L4 g2 }5 I/ T0 g8 A6 R
  7.   if (Status == EFI_SUCCESS) {
    0 h& @- }* t( p1 l- `" j2 v1 U# o

  8. & O) H) w; z) h$ I. a
  9.     /// N- ^1 H# V( c; ?2 l5 u
  10.     // Call the image's entry point( r) C/ h2 t6 ~0 I$ R
  11.     //) r/ S' L! u( J( c& b1 o
  12.     Image->Started = TRUE;! |# d& ?% k. X. w. a$ Q9 ?
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);0 o$ ?# w$ n4 P0 i1 i" A- F; N
  14. : X( l* W! e3 m1 D
  15.     //' R5 C% f1 |! B3 W; U& p) E
  16.     // Add some debug information if the image returned with error. 7 j9 z" d. F7 @& p1 h% T+ T- x
  17.     // This make the user aware and check if the driver image have already released / q! E: P6 |/ j6 f8 i) ^
  18.     // all the resource in this situation.
    & t) u3 b& k! c, |8 ~/ R6 S
  19.     //
    - H+ J3 K3 x! F) p: m9 \7 A0 {
  20.     DEBUG_CODE (
    5 \9 p/ a4 l8 ]; W5 S3 ?7 {1 I
  21.       if (EFI_ERROR (Image->Status)) {
    0 B! P# M# i6 U$ t6 Q
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));5 o& I( f6 y) G7 n9 e+ Y. {
  23.       }
    5 V" _$ J0 J- D0 R6 o
  24.     )
    $ [/ h5 E" S, @$ ?2 \* c
  25.    
    , W" b4 E0 m% R8 L( X. i
  26.     //
    0 z1 d6 b9 ?% |; [% t, S
  27.     // If the image returns, exit it through Exit()
    ) g$ q+ S$ S6 x
  28.     //8 c& b- b+ x- j5 ~8 V7 Z' r$ r
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    ' V9 d" D) E$ q9 H9 G0 a
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态
$ Y( h- i8 b4 d$ [5 z' N$ {1 [7 J既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?  Y: K6 ]7 X- b, Z% K
而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
. T( [" U! H3 W. q  a5 p
  d* ?, }9 r# o8 |; Q; ^我感觉有点多此一举了...不解
发表于 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。7 a( v9 U% r- M- a
( n# f: Y4 Q2 C5 A# Y$ ]) ?
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.: F: w9 u3 `$ B% j9 B
没有用过,暂且记下了.2 E% o) N) _6 c0 l5 |4 k- u/ u
7 [7 t. ]* F- E% [& N% O
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-4 18:15 , Processed in 0.075068 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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