找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 46046|回复: 20

请教,UEFI中Event的理解? Why and when use event?

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
$ e/ V; @5 ]* d& j一直都不怎么理解为什么要做出Event这样的一个机制?# f# Q+ |0 i, l6 e% }) Z
) A0 N% [! y9 }7 x6 Q5 A. ^6 ?6 w
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)3 W' @7 Y) t- v; @# n
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;) }6 U$ F) j; I* u& t" a
还有Group类型的Event,用于处理具有相同类型的事件% b  {+ o1 L1 H5 W3 E
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)( L0 `; T$ i2 ~6 }% `* a5 |
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,$ c  y- L6 R) |0 D4 b
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

只有在restoreTPL的时候才去处理所有的event的notify。建议你抽个时间去把event的那几个函数看看,还有TPL的rise和restore大概看一下就能明白了。
回复

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
, ]+ y. w. @4 p5 M8 Y( O+ M& r因为我看到有很多地方有RestoreTPL,很频繁地,
. R1 x# d3 m4 c( P4 G  L所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?% Q. m8 A8 b, W
9 s/ u" J; n9 M$ C3 N4 b5 u( J
TPL的控制,
2 }  r% Y5 U0 e2 _+ p0 c% u, B我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
7 Y2 g6 ^& e3 w; G+ b- n" I' K8 E不想被一般的事件打断时就会RaiseTPL来处理,: r* p7 l/ c# U9 ?9 W& P
处理完,就会RestoreTPL了,
+ v4 b+ ^8 v; d. v* Q: t当然RestoreTPL还可以用于处理pending的Event.
回复

使用道具 举报

发表于 2008-9-3 15:13:21 | 显示全部楼层

回复 3# 的帖子

signal之后我想没有立刻dispatch吧。 xT你在好好看看restore的代码和notify的代码。
回复

使用道具 举报

 楼主| 发表于 2008-9-3 16:24:12 | 显示全部楼层

回复 4# 的帖子

对,Signal后只是将Event加入处理队列了,要等到下一个RestoreTPL,并且当前TPL低于Event的TPL才会被Dispatch.9 \# s+ Y9 R: f+ m

' p4 n7 z! i  T- T4 @8 ~* V$ W& p我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)+ L& r: l* A( D6 H+ {
所以,就可以"认为":4 R9 ^) {- _% Z, M8 |9 T. j
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

发表于 2008-9-3 16:36:33 | 显示全部楼层

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
% o& w* X9 \" I8 q  k; O3 D
) X$ I" F( i7 a1 z# Y而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
7 T1 _; e$ ^' u# ~9 Z& _
4 |  z  k% }0 z) f* ~. ^* J我个人理解,每次restore总是有目的或者到一定阶段了才restore,至于这些原则我就不知道了。
回复

使用道具 举报

 楼主| 发表于 2008-9-3 21:55:22 | 显示全部楼层
逻辑上对顺序的控制? 这个通过protocol的notify event可以做到,但是我觉得event的功能应该不仅限于此。
回复

使用道具 举报

发表于 2008-9-4 12:01:51 | 显示全部楼层
看到的就是表面的,背后的看不到。在黑暗中摸索吧
回复

使用道具 举报

发表于 2008-9-5 12:11:32 | 显示全部楼层
前几天用了EVENT的EVT_NOTIFY_SIGNAL属性。) D' Y9 [; A! j5 a
typedef8 ^. ~4 G/ j' X3 H( p" ~
EFI_STATUS% s2 k& N, k8 ^4 z' E( o
CreateEvent (1 P3 P3 q8 f  b  i% M
IN UINT32 Type,
! x9 y" i# f3 {. XIN EFI_TPL NotifyTpl,
5 g! H( i" D  N5 SIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL  ]. o6 t0 s8 C* i9 S
IN VOID *NotifyContext, OPTIONAL( q+ A9 g% b; J" U; P% [
OUT EFI_EVENT *Event
5 l- u5 r) \5 y' G# K. u" K& l$ x9 ~);' a; _' B+ i$ o7 s4 r" ]2 s
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
* c/ j/ A# D3 F& I使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

 楼主| 发表于 2008-9-5 20:24:10 | 显示全部楼层

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
: o& v6 D" O: J3 @, [( U1 s谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。) ~; i2 a" q9 j, I6 y+ S. [
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
) r4 |5 ?( v' g* H+ b. s我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
% H) {" u5 a$ }如果是Binding Protocol的Driver,在自己的Driver里面( K! Y; n! }, L6 d. {: [
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)+ R/ g) @' s5 \* {
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,: X  u+ v) f, {7 Y# B1 K) D
在Event的NotifyFunction里面/ N/ u8 ]* [  ~1 l$ Z- X8 m
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
# }3 W  y+ }* i  D3 @2 q这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

发表于 2008-9-11 12:59:04 | 显示全部楼层
方法很类似,你是在对特定的driver进行通知吧 我比较狠一点 哈哈 是在Image.c中的LoadImage的相关函数中加的Signal只要LoadImage 后就触发事件到NotifyFunction里面,然后再回来执行startimage。6 \# B  H) Q. o% ]
哈哈 以后多交流 遇到能聊EFI的人不容易呀~!
回复

使用道具 举报

发表于 2008-9-12 10:02:06 | 显示全部楼层
register EFI Loaded Image Protocol的notification如何?
回复

使用道具 举报

 楼主| 发表于 2008-9-12 11:06:24 | 显示全部楼层

回复 14#的帖子

你的方法很好!/ ?1 E! H6 |. N
可以Hook到所有后面的driver!!!
+ w: D; T8 B5 [3 Q* e/ v# f& h9 N7 i4 w# }3 y  t
回复 13#的帖子
9 A' M" Y. l# h: L8 J& L  z& m在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
2 R  u" o, U! [+ t8 P0 b4 W
; w' U* M0 C1 u: ?  d在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
0 n/ U4 L$ ?& xxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

 楼主| 发表于 2008-9-16 11:01:49 | 显示全部楼层

回16#

File: Image.c; I! H. b3 y2 R; e& c$ X
CoreLoadImage()-->CoreLoadImageCommon():$ Y/ y) A8 [' w& @. g
  //
# P" p( `$ Z) E3 z- |+ V  //Reinstall loaded image protocol to fire any notifications
) F8 E# ^6 P* c# ~0 ^" ?* ^- V  //  ^  ]7 X0 n, A; B4 z) Q% w& q
  Status = CoreReinstallProtocolInterface (
5 d6 [* x+ z; T; x2 L             Image->Handle,
( u* `- |( w4 W4 A             &gEfiLoadedImageProtocolGuid,/ L1 f' J0 o. z, V0 k& ?' y8 s
             &Image->Info,
7 u* |$ F$ r; p6 b7 n             &Image->Info
$ Y# Z" X: `) L+ C3 y3 ~             );
2 F; X1 D6 l5 [/ e1 d6 Y! |  T; \  E; u
File:Notify.c* I- W9 T3 w) A, ~3 {7 s' o
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()& c+ l# N- T6 T% V& K% a5 ?. G
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
6 F% \! \$ F  P" pFile: Image.c
+ ~' ?- X% e+ `! yCoreLoadImage()-->CoreLoadImageCommon():- b. Z! q, J8 b- P, m' ]
  //+ z1 _, x  `9 k3 D- [* u3 k
  //Reinstall loaded image protocol to fire any notifications
0 V. V% U, }1 X$ }* @& A  //
# S. n2 q6 J7 E5 q6 J' j. N  b  Status = CoreReinstallProtocolInterface (
, L9 @% K5 m& @1 u8 U' _& m             Image->Handle,
8 w: w. J" V. M+ V0 Y; W! @- I  ...

$ ]0 q$ ^) E# U6 o $ [3 i% o. U* d/ @$ o% \6 k+ c
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:: n& D5 c" R6 Y  ?  n9 h$ P! r
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?2 y0 a. E/ ^5 C

0 r8 b4 y1 V0 z6 M& ^[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?  N$ r0 l4 k: _8 J! ~6 p
谢谢!
回复

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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