找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10413|回复: 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);) K& P6 P( w' y# Z. }. M% |; `
  2.   //
    - J/ P  V0 q" D. U  I/ S4 s( s
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed. Y; F3 T  V7 m) q+ A' Q
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump8 P+ Q' @6 q% S' g1 [: n
  5.   // All other return values for SetJump are undefined.
    , \; G: @' A" y) o+ _* H2 \/ E
  6.   //
    8 D' R( F3 o- G* W: D  q9 w7 j
  7.   if (Status == EFI_SUCCESS) {" R3 h. ~/ D6 Y$ _8 `

  8. 5 E) r% u8 ^* @. y) m/ _6 v
  9.     //
    ' a5 r( |& _6 E' t1 V
  10.     // Call the image's entry point9 ~' ]& ~5 A8 B! X: X. J
  11.     //
    - w4 G, d1 O1 E' G" I
  12.     Image->Started = TRUE;
    $ K" ^2 Z9 O+ J/ }. h8 x! c
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);/ F7 h& u- z! |$ L! J) q
  14. $ p' c2 x* Z  j" `7 I! L
  15.     //
      w. I/ F  D. i
  16.     // Add some debug information if the image returned with error. / V4 b1 g0 F! j% x3 N% Y* P
  17.     // This make the user aware and check if the driver image have already released 2 W1 l" [8 j! F9 ^! G+ q/ [4 Y
  18.     // all the resource in this situation.
    & C5 H% x0 S5 H9 L" S! I/ {, q" O
  19.     //8 D$ a( r- N# V1 m- n- T2 {
  20.     DEBUG_CODE (: q' l! g; F  L3 g1 S9 {
  21.       if (EFI_ERROR (Image->Status)) {2 X+ g# j- x  \9 T; B9 X
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    ( W. X% n; s: ~( M, h, `0 H
  23.       }) K, W9 l6 v- G: K5 `) S
  24.     )
    ; V6 A( D! E" z- T2 Q
  25.     9 z2 M: n( K* g+ c7 ~
  26.     //
    $ [( A; [7 @& {/ z; d- h. R7 y
  27.     // If the image returns, exit it through Exit()
    . t/ b( m, m! _0 o$ T
  28.     //" o3 A) I% W, @; t+ O' z
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);, Z; G% _- k" @! P0 E; B7 b
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态
/ j6 I* M+ C' g; _6 S既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
. `( p  J! Z  p3 X/ a" d" ~而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
- s2 e# O) @) f9 y
7 Q5 R: ^, a1 E4 |0 c4 g我感觉有点多此一举了...不解
发表于 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。2 k# T  t$ H  F6 W1 S
! ~0 f9 n! M0 `! R' |. P
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.
2 @& A4 J  A$ @: k4 }7 Z2 R8 ~没有用过,暂且记下了.
; C# i- A: ?! Q1 O% Q% Q4 P6 @& O, U# v
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-1 13:59 , Processed in 0.329487 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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