找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10780|回复: 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);
    ! u7 v& g! u( S5 }) i, R8 }/ L8 M; U' g
  2.   //
    2 @; h. M/ S0 l7 K- i7 S# V* J5 v
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed1 R% O2 P1 h' C  _( E
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    7 k1 P  d0 E6 M" R, b# B+ b
  5.   // All other return values for SetJump are undefined.
    ( \2 R7 K& F* }3 Y$ `8 n  [  T
  6.   //# H; j/ S7 q- j
  7.   if (Status == EFI_SUCCESS) {" d, n3 G2 p! {

  8. / w; `  l& q- l4 z
  9.     //# ~: o, O7 f$ u7 Y5 B# i/ s
  10.     // Call the image's entry point' Y* A- z8 e1 o, @
  11.     //
    / J. j% L- {5 S# }2 H
  12.     Image->Started = TRUE;. k) H  {1 b! L- c- t& X# `
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);2 d  y( i0 ?/ G% @% N

  14. % a' c8 G  p) L7 x' ~1 B
  15.     //. l  G) q: H  T
  16.     // Add some debug information if the image returned with error. # p: c, o( i# n. F1 `
  17.     // This make the user aware and check if the driver image have already released
    " m  N/ o) L2 k, w0 R
  18.     // all the resource in this situation. 5 [4 p: N8 f8 C) t1 e, U
  19.     //
    ) D% X) k( T; B; @. P' n
  20.     DEBUG_CODE (
    2 m( N  E0 t- z  H  t; r
  21.       if (EFI_ERROR (Image->Status)) {
    / O) b6 I- ^# F7 y
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    2 {: p/ w+ w8 Q0 S1 m, D
  23.       }
    3 z6 K7 b0 I9 I9 l. P
  24.     )! b$ ?2 ~9 M9 N8 x% E
  25.     3 K' d+ d& a/ u1 e9 x0 u; Q9 j) p9 B
  26.     //
    5 w8 ]' M6 \3 S- z
  27.     // If the image returns, exit it through Exit()+ G, p- D, q) p& p, p( s
  28.     //
    5 ?! J( z# H9 ?! y% j; z
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);- _4 ]/ G! B, N
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态5 G2 C* E' }* L) `+ X. U
既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?& Z: J3 i/ c  `- Y5 l5 }9 a
而且目前来看driver只会返回Status而已,根据这个就可以做处理了.2 S# n  j9 M& d. m" U
0 F. j) L; G1 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。
; D7 P3 _# D, V. ^. _" c
; _/ g) f1 D' I$ Q- E9 ]EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.
4 P2 j) r4 C3 d0 x6 _4 c3 R没有用过,暂且记下了.  I, K9 T9 A2 p8 b+ i

* F' K, S6 Z( P# }, L非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-8 08:35 , Processed in 0.164784 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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