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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
' x3 u! h0 G0 R% f一直都不怎么理解为什么要做出Event这样的一个机制?8 s& M7 I3 n5 Y7 W* e' z3 }
5 y% a6 p# a: I6 R* e
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???): b; D  [' }, g: U+ e  z8 f
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;  C# G5 S9 L8 p+ d( x
还有Group类型的Event,用于处理具有相同类型的事件  j1 _  A. S! i# `: \% V
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)7 t" C8 E3 p7 w6 _9 E! W5 \! Q$ x5 c
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
( @! l# ~# t  A6 ^2 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.0 \) L" e1 h' y+ r0 _% I: Y
因为我看到有很多地方有RestoreTPL,很频繁地,
, Q0 C: c! k, i/ I所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
. [3 l9 m2 z3 O+ o9 q0 z
$ N7 O. S( M# n7 S8 _4 z, rTPL的控制,
/ V& t5 a; {7 m3 A我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
- x4 }& _: l0 i$ i$ {! @3 t不想被一般的事件打断时就会RaiseTPL来处理,
; R+ ]' e- ~% M. }  ]处理完,就会RestoreTPL了,
; Q- z6 m6 [8 @8 K# G: x7 t+ O当然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.
2 y/ y" d& U6 U% w- u, c1 _+ e6 u& H$ b9 @& s
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
* Q' W/ m4 V5 `6 X9 }所以,就可以"认为":
9 h9 F$ C9 |9 C+ L# W' M# E       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
2 C2 P6 A2 m9 m" O& x  q) c  S0 Y" }( ^5 Y' G5 }
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 : m8 X7 d* P* L: z5 f; B/ A! c

, b2 U1 ?/ J4 t! s: K" N' {; ?7 \我个人理解,每次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属性。% r) H3 G' v$ s$ u* \
typedef
* O* x$ [8 ?$ k* Z0 y/ g2 fEFI_STATUS& D/ m5 Z! M2 r  w% ~( H
CreateEvent (# ?1 N0 L: h5 l5 _6 o! D8 c
IN UINT32 Type,
* \" O, ]/ D$ Q* ]% u7 v) q2 IIN EFI_TPL NotifyTpl,5 V2 _" {4 J9 u. k# r
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
* T5 P6 n: ~+ L5 m3 mIN VOID *NotifyContext, OPTIONAL4 Y( T, S" `" J- N; L
OUT EFI_EVENT *Event
- g: }" h' v5 s, j# J+ u" X$ f);: I3 o# C. K7 T
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。5 w1 s; F7 g+ K- A6 W  B
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?( a- a+ a) `/ I' y( A& \6 ]0 N
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
; f9 ^3 t/ F+ l! c) Y$ ^Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
3 O& g+ d6 C( b; w& F/ n7 l我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:( f( D' m/ O! @1 j3 C
如果是Binding Protocol的Driver,在自己的Driver里面
5 c  D) t4 i5 ~3 l用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
4 M1 B; j' p, V1 ?7 b7 _8 I记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
# I5 ^+ B2 p1 s7 l! R: _0 o在Event的NotifyFunction里面3 {6 x: c4 P) `
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles: |* S9 z; _" e
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
9 ]9 a$ H* \1 q2 @" B可以Hook到所有后面的driver!!! 6 g9 @) t! Q! T* C0 _$ ?: W! V

+ X9 R! P; z4 U+ {, u" R7 i回复 13#的帖子
3 h; p! L  o; D6 i' R在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
3 a! l# \, {1 f( G+ S; [
& u; d# X7 N. P$ p2 r! r& @在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
$ G, U6 G, [4 i) v- Y" W! Extdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c& k3 X, p' ?1 V+ }8 Q
CoreLoadImage()-->CoreLoadImageCommon():0 Y  J2 t2 p# W/ n
  //* W6 S& H" [' ?. x% `5 `6 {" Q
  //Reinstall loaded image protocol to fire any notifications9 |$ W; I! Y/ [/ Z1 t
  //
% q* B7 b( [4 C! I3 U  Status = CoreReinstallProtocolInterface (
: t+ z7 }* T/ ]1 {3 e             Image->Handle," A: s. ~" I/ T* f5 F7 X8 l- G! S
             &gEfiLoadedImageProtocolGuid,1 Z. q, X3 M# }0 g
             &Image->Info,; K9 \: m9 A" ?6 B) S
             &Image->Info
4 V0 m/ ^1 E3 g             );
3 q; s4 D7 ]- L2 T
5 a: K/ L$ Z2 s( b  e8 F. _7 _File:Notify.c8 o$ ?7 l( M& g( h8 d
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
) ]$ Z8 v# |( G6 k1 ACoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 ) q; Z9 V7 R" J. j" _& \
File: Image.c% {9 Q4 {1 M3 D6 o; v
CoreLoadImage()-->CoreLoadImageCommon():- }- }) C. }# z) H9 K
  //. g6 K9 n& m2 C1 V
  //Reinstall loaded image protocol to fire any notifications4 V# h- F& Z0 _! D
  //" f# V) U$ K' K' _4 i/ W: N) t  }
  Status = CoreReinstallProtocolInterface (8 O8 f  r1 [* k5 B' G
             Image->Handle,
/ P* P# e- ~/ N: \  ...

; y* a& f& A' H' O  F+ g5 y  Q' u * s" V# Z9 M$ k7 E# w8 L" H, i2 s
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:- f6 P; d& ^. U8 R8 t
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?7 K; q. i/ Q. U/ h7 w; u% {

( x( g& D. [' Y+ O9 ~6 ~[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
% d6 R& ~$ `8 l. q2 d谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 12:29 , Processed in 0.024565 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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