找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10521|回复: 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);- Q  m2 _* g2 A1 S+ x! p
  2.   //
    8 I# U1 P7 b0 S- |1 I2 u
  3.   // The SetJump returns EFI_SUCCESS when LongJump Buffer has been armed5 V4 _" M/ D# e4 V. G0 U
  4.   // SetJump returns EFI_WARN_RETURN_FROM_LONG_JUMP as a result of the LongJump
    & g5 v+ X" ~" s% s: [  s6 S0 z
  5.   // All other return values for SetJump are undefined.
    * G4 B' U4 h. m( c
  6.   //$ {5 J. ~6 V5 N
  7.   if (Status == EFI_SUCCESS) {+ k5 \2 V4 ^  d& T

  8. ; z$ [6 B+ g( h' z6 a+ \% M/ [
  9.     //
    " i, ?. ^( K6 |, U3 n6 r" s
  10.     // Call the image's entry point
    0 ~& B. A3 k7 ^( v# V+ K
  11.     //, f" m- _. m6 Y% `3 ~
  12.     Image->Started = TRUE;0 U. E) _2 F- \5 i% g4 ]
  13.     Image->Status = Image->EntryPoint (ImageHandle, Image->Info.SystemTable);  O- C9 }( f5 ~( z

  14.   C3 T; I# w( n9 q! n3 {
  15.     //
    1 |' F, R: g) _$ m
  16.     // Add some debug information if the image returned with error.
    8 P! O1 h6 y2 M4 {
  17.     // This make the user aware and check if the driver image have already released
    % w8 E8 i# ]3 H/ ?
  18.     // all the resource in this situation.
    # [  p, D9 P& b, w, q
  19.     //
    : y% `; [; y" L
  20.     DEBUG_CODE (
    " D. {- ?2 i+ v. I' P- {) h
  21.       if (EFI_ERROR (Image->Status)) {
    2 `$ V; n) Z: m! o8 ]. x. P% E) c
  22.         DEBUG ((EFI_D_ERROR, "Error: Image at %08X start failed: %x\n", Image->Info.ImageBase, Image->Status));" x" b$ ^( v3 Y  W4 T, P9 e
  23.       }' T- @& @7 H; k5 m3 Z$ y
  24.     )1 d  ~/ q1 M% Z3 X
  25.     ' e2 K) w8 X. Z& @8 z
  26.     //
    9 h* s4 @( u3 D  s+ y
  27.     // If the image returns, exit it through Exit()
    % d4 b, ~) L: \' I9 g# Z
  28.     //( b& k7 r( ]  c- |' w" R- w! a) P& A
  29.     CoreExit (ImageHandle, Image->Status, 0, NULL);
    $ ]2 j2 w1 ~. u
  30.   }
复制代码
调用DXE driver前,为什么要用SetJump保存CPU的信息,driver返回后,再用CoreExit--LongJump恢复到SetJump时的状态
3 O5 A& Y( X0 J" Q( T) O/ w6 ]既然driver可以返回,为什么非要这样恢复到调用前的状态呢?难道在调用driver的过程CPU的状态可能会被破坏吗?$ {# z1 \4 a. `7 p5 Q' r
而且目前来看driver只会返回Status而已,根据这个就可以做处理了.& F# K& y2 z1 [7 k+ c+ X
; j. d0 B3 d; R2 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。, S, }0 }' w; _2 n5 |7 `) m
8 z& m1 a: e) f% G& Z2 X
EFI_PEI_TRANSFER_CONTROL_PROTOCOL提供的SetJump/LongJump函数就是支持Exit boot service用的。类似于C的setjmp和longjmp库函数。
回复

使用道具 举报

 楼主| 发表于 2008-10-31 10:03:16 | 显示全部楼层
有点了解了,Exit()可以直接退出返回一些参数.* a) {9 r2 w- ^
没有用过,暂且记下了.+ G+ V9 d! V. U
* H3 B$ E% y, e
非常感谢!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-5 15:56 , Processed in 0.134694 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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