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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,- z+ H/ \; ~7 @' k2 J" p* m: Q
一直都不怎么理解为什么要做出Event这样的一个机制?
2 L/ h5 r! l' }* S9 f: E- C- X  \9 I. |. y+ z# x7 r" @
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
& L4 k1 l+ v/ YWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;7 O/ Z4 s6 ^0 ^. |/ l0 |2 R
还有Group类型的Event,用于处理具有相同类型的事件: |8 Y8 V; x( C; ^8 W0 h6 J$ q
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch), T+ o! \+ m: K* N. u2 ?
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
1 }8 ?& W' C9 g$ y' p( x不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.% w% q4 G& v/ T- n$ ]2 l8 d1 {9 ?) q
因为我看到有很多地方有RestoreTPL,很频繁地,4 S; c6 e9 B/ A
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
. C  a: p' l; L  v1 H
2 n$ x5 `, _7 U5 k: ?7 STPL的控制,( i) K2 z; L0 T3 b( N1 Z
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
; t; P0 |& Y7 B6 `8 U! d4 ]不想被一般的事件打断时就会RaiseTPL来处理,! E4 U8 m* ~- X/ z( G& r5 f
处理完,就会RestoreTPL了,
* k/ x0 {# e' P& U6 c8 H: ?当然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.
, K3 ^) V$ Y+ H' V+ W) |8 Q) r" f8 X3 a
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)3 ]& d" w; }1 ]* D4 {" ]. c
所以,就可以"认为":, k9 l0 v2 J& c& j
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
6 b' M- h! x0 Q5 b) U6 m" P" w  f% W0 Y# n5 j! T3 P4 ]; U1 ]
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
0 e3 c$ p! A& F# n) q
$ g6 h1 t$ N& i' a* K9 i( }  W我个人理解,每次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属性。
5 u: {& P( z) L5 i; ^0 k3 mtypedef0 H: G4 f2 n0 I) O1 D. k
EFI_STATUS' Z0 T1 L0 v8 P* n, Z4 \% R- C8 @% O
CreateEvent (7 R1 V2 e) ~( _+ Y1 K" p
IN UINT32 Type,* F# j$ C2 ^; F3 N$ n1 t
IN EFI_TPL NotifyTpl,
3 Y1 I1 Z% u1 a7 Y5 oIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
7 N8 z; K- |5 O/ YIN VOID *NotifyContext, OPTIONAL0 Z/ R" S5 |) N1 i0 K" x" X2 {; u
OUT EFI_EVENT *Event0 r; u9 p1 z/ ?2 A& C' ^8 Q
);  z+ `" Z5 [  ?. g
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
* v: u( S- c: a; @. w' ]使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?& x! }4 V+ I3 A
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。2 {! D0 P% {+ i0 \. o+ B8 f
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。+ ]/ ~" d( b% S: s5 O5 U
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
5 {7 F, Y- K2 p如果是Binding Protocol的Driver,在自己的Driver里面
: y" m' i5 ]& ]6 R# d/ i' C1 M' b用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
4 R) I" j: G0 r) ?3 e# ]- G& @记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
& x9 i) m# K( F6 s2 F9 S在Event的NotifyFunction里面. i% y2 n- h+ y  b/ j6 Y9 d! u7 Y) ~
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
/ P* V; k7 m# q( U: m这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
+ D& Z' F( K4 _6 O+ e3 l& g% p可以Hook到所有后面的driver!!! " p8 N9 b. }1 l: Q

5 ~1 N2 o% {% ]: D& m回复 13#的帖子, J' ~2 Q, o7 {1 o& H1 @% c' b
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~4 \$ E; e- x! ?! f- c; R
+ G5 W) q$ y: v* M; m! A9 g
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
2 p$ }, l" W# F6 n  U8 @0 V* X# ]1 Xxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
9 }4 ]/ ?' ]8 H- p' U. R1 hCoreLoadImage()-->CoreLoadImageCommon():5 s8 N" y2 r3 C& @
  //
, j0 z# C+ W& b& F; {  //Reinstall loaded image protocol to fire any notifications6 [/ R( k, G. o. D" p6 I' J. E
  //
0 R# F* [  R- I0 S; @; g8 y  Status = CoreReinstallProtocolInterface (
6 k1 _6 p% m3 K' ^0 P: Q             Image->Handle,& d5 @# n' F! O5 y; w. P
             &gEfiLoadedImageProtocolGuid,1 M6 b0 \- M( a4 G( [; j  ^
             &Image->Info,. b# A2 O. ~& U
             &Image->Info
! T2 {& j9 c" ^+ }8 e/ g             );$ a! @1 `  ?% _0 \" z
* a2 I; ^0 L) p8 i& p, }4 @5 e
File:Notify.c
5 |1 x( ~" I* n3 f; nCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
+ S  Z. y4 N0 [CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 " ~" @; f/ a! w4 f/ G
File: Image.c
6 H/ \$ I1 f  _! S+ LCoreLoadImage()-->CoreLoadImageCommon():# d/ n' W& t4 M- M
  //$ u! }1 w# {5 [( f* N
  //Reinstall loaded image protocol to fire any notifications8 J& O. `! [/ {# y( Q
  //
! {, n, }8 i# Y. |: x7 Y* u: v  Status = CoreReinstallProtocolInterface (
" w3 L9 N% a1 N2 r5 V1 C             Image->Handle,
$ Q- D# @. ?4 W1 D  ...
) G$ {/ o. p% n) z  c
, F8 s9 E/ }' e$ @0 d( a
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:: a# \7 z( n. [: X( _% \, h" K
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?, I  T: w2 o( |1 X. M- ~3 Q
, Z! c- m  m2 H# f& k" a
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?3 X/ T2 u7 g7 x! G4 ~" M
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-21 18:33 , Processed in 0.043686 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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