找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10411|回复: 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);: {0 \+ k; s2 l
  2.   //2 O  Z/ \# U: p+ ~1 `4 \" O, ?" j
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed
    9 h; p5 U; ?3 k* Q. o; q
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump9 O" ~. x2 w3 T7 v, e
  5.   // All other return values for SetJump are undefined.% i3 c. T! z% p# Z
  6.   //) Y  {+ q2 l! X
  7.   if (Status == EFI_SUCCESS) {
    2 @+ l9 z" n: U6 Z9 y/ S  |
  8. & J+ @* P7 B5 g4 Z2 [
  9.     //6 @0 Z3 t3 K- X3 j- w
  10.     // Call the image's entry point+ ]5 [' t3 [- J+ V5 T/ N
  11.     //
    + m" y/ d# }6 X
  12.     Image->Started = TRUE;$ ^6 T9 c: {; N/ k  p  d$ p( N& E7 m
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);
    5 I$ X, I1 Y" c
  14. ) H; u" {0 _4 X# w5 G" A# D
  15.     //& B& I+ m" e6 O/ N0 k9 l" j
  16.     // Add some debug information if the image returned with error.
    9 o: l! G8 `0 Q# o
  17.     // This make the user aware and check if the driver image have already released - s" A* F) Z5 d! v" g
  18.     // all the resource in this situation.
    " G) a( N+ Q6 t* I6 \- t6 l
  19.     //
    7 P( {6 W' k- T  t- R" I/ ~# A& C
  20.     DEBUG_CODE (0 ~8 D' w3 d: o' U6 b
  21.       if (EFI_ERROR (Image->Status)) {9 Q6 Y" N" W3 `4 q8 M/ Q4 |$ M! c
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    ; D! m! t, A9 V2 y; d8 c0 [
  23.       }
    # R* d3 z6 E$ {) U' M
  24.     )
    0 M" Q: N6 d) j# [* n
  25.    
    . J% h" T8 R- F* S0 o8 J- _
  26.     //
    $ G; j) |/ P: Z* T/ B
  27.     // If the image returns, exit it through Exit()
    . O8 b9 ^3 f3 Q$ J) b
  28.     //
    9 w( k( y* O6 C6 U# G  k2 t' |
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);. {& @1 X9 p. c: b2 P
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态4 x' s+ `' N, m4 R' |, @6 v
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
) w1 e5 a  j; M而且目前来看driver只会返回Status而已,根据这个就可以做处理了.8 c# `! G9 c  \6 y0 o
( D& e/ ~2 v4 G0 l9 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。
7 o  E$ p+ Q  E- u( E5 t" h) A6 S" J2 S! m
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.
6 N; j& z: U$ f+ e* a, j7 y没有用过,暂且记下了." J- g* M7 G) M2 y
9 O& M& _/ O' L- z
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-1 05:37 , Processed in 0.089129 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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