找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 9880|回复: 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 d8 s6 f# n  g1 w$ g3 o4 V1 H  n
  2.   //
    5 o, u# R# V, a
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed7 T+ ~( n) `- E2 i0 a
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    $ H$ i1 Y4 f8 v6 \8 _& `( a: u
  5.   // All other return values for SetJump are undefined.
    ; d! i6 K1 H1 }& c
  6.   //5 ?/ }6 ~! _2 l+ b2 ^
  7.   if (Status == EFI_SUCCESS) {  S4 U  a- ?/ W9 c. o
  8. ( u: T; b1 w/ E
  9.     //
    9 m6 }! [' U' N6 B
  10.     // Call the image's entry point( n& ]" C% j' J* `* k9 S, _0 _
  11.     //
    * m' I* ~( _5 \) R' z, D9 I
  12.     Image->Started = TRUE;
    ! z+ Z) H; T9 f4 F% L
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);& ]2 P; e# B) e0 Y& i- G6 d
  14. " _: I0 `! r9 O
  15.     //
    * W4 w* {+ v8 F+ H
  16.     // Add some debug information if the image returned with error. ) c0 V& I( U) f3 d. J* d) G# I
  17.     // This make the user aware and check if the driver image have already released   o8 Y( K1 U5 D" `
  18.     // all the resource in this situation.   F: \# K# e0 L7 T' |8 l
  19.     //) g& ^6 ]8 z; N$ {* R
  20.     DEBUG_CODE (4 {& y6 T# H0 x7 _% H5 A* s) }
  21.       if (EFI_ERROR (Image->Status)) {
    7 b; e3 L- b, P$ R4 u6 m' y
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));, Q* J) x9 N+ R& S4 L1 Y2 e  h: W* }
  23.       }& D+ ^# ~* S$ r' r1 R
  24.     )
    / z  g  `  f4 z1 `3 v7 u
  25.    
    : y2 |' l. o2 U6 `
  26.     //# T+ I$ ?2 |, o0 ~  k& |3 @
  27.     // If the image returns, exit it through Exit()" J( c* g/ M  V3 ^
  28.     //: A6 n6 ~6 O+ x, B* r( B
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    & m6 }) o7 r9 T+ @, s% X1 u" m
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态
: b* z& K) ]2 k/ I: m+ b既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
- M. w. t  t  n. [. G( K: r) f而且目前来看driver只会返回Status而已,根据这个就可以做处理了.9 Z8 A. r% p& P' O; l3 Q

) r" |" V: [6 J. f( _. G. V7 T. X我感觉有点多此一举了...不解
发表于 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。+ I! W5 b# ^1 e* j
4 v+ `$ b% i& |% S# p7 f
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.# i# F- j/ r: d. J$ V+ R
没有用过,暂且记下了.0 R; l4 F. @" n# H6 j

0 q5 B" b: c, L非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-2 10:54 , Processed in 0.028955 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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