找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10765|回复: 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);
    * `; l# b, j- O& G
  2.   //" Z5 |+ ?+ [9 Y6 P) a" l+ B
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed
    % P* d8 L+ {8 [% g6 a# T7 K1 Y
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    . C5 g1 v, p5 a6 y/ w
  5.   // All other return values for SetJump are undefined.
    1 Q% ?: J: W9 s2 v6 e+ S3 D
  6.   //( }6 j' v& F) |; b: b  b# G
  7.   if (Status == EFI_SUCCESS) {
    # N: i+ i+ D0 E% }

  8.   I8 x" A/ h8 F6 S
  9.     //
    / B! z/ k) N% R( o
  10.     // Call the image's entry point2 I3 p0 q( g+ f$ @$ f$ w
  11.     //' t/ ?4 A% c, z( _
  12.     Image->Started = TRUE;
    1 r& P' i6 \& g7 X$ i) y- i8 {
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);* H6 _4 l5 ^7 H# G( K, J: V) ]8 V

  14. / h) e( j; C4 d0 @+ F4 E
  15.     //
    + _5 @1 u% i9 x; c, p
  16.     // Add some debug information if the image returned with error. % z* h( Z5 `) h, z) U3 u
  17.     // This make the user aware and check if the driver image have already released % z0 `7 N; x6 W) l5 d
  18.     // all the resource in this situation. 7 @+ c* F2 k7 n* |( \3 s
  19.     //2 _1 h) Q6 J" Y7 i" j& t0 d) a
  20.     DEBUG_CODE (* \* ^( W7 p6 g- V, u
  21.       if (EFI_ERROR (Image->Status)) {
    / f; l9 y: [& h& [1 D
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));
    3 L3 m3 s1 \- c; G1 w- u5 T
  23.       }% ]  C" ^$ B! p$ B: e% P
  24.     )
    # F1 ~, k1 ]1 ?
  25.    
    5 i% l* \& h" o+ I2 X
  26.     //) L; g/ h" }# h
  27.     // If the image returns, exit it through Exit()3 F1 n8 A7 w2 |; b
  28.     //% S# h1 o7 I* T# A/ Y/ x, {
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);! m- N- R6 U* h& _3 L: `5 b$ O0 v
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态
8 {6 r, B; T3 n# d: F既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?
% X7 z( @) h, {. J# n4 m' S7 x- k& X3 X而且目前来看driver只会返回Status而已,根据这个就可以做处理了.
2 h+ ^( u# Z. f" q( Z2 i# o8 p9 O1 u, e" M! M% ]$ P
我感觉有点多此一举了...不解
发表于 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。" O6 z2 [# E: q% A
5 ]% o" ^- |0 x; r2 T4 C) L0 T7 Q
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.* _( Z" E+ \2 E  C! {6 r. ^9 r
没有用过,暂且记下了.
/ ^' ]% J4 O6 Z3 Q$ h# N2 [& |* ?
% I; J: A$ t0 u2 _, F9 {5 n非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-4 19:20 , Processed in 0.041262 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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