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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
& t! o0 `+ @. m7 S% z6 H一直都不怎么理解为什么要做出Event这样的一个机制?  T( f; h, D6 L* ^% w: A1 g) D
  G/ E8 z) K, t
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)) Z: G( i. M- Q! {
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
  L$ w0 s5 ]. s还有Group类型的Event,用于处理具有相同类型的事件  L1 I5 |! K" D$ |0 K1 v
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)' o4 V0 b6 T& t' W
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
2 v, R2 [; }) p( M5 `% p. H不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
: u% f5 M' h8 q1 u3 j" Y因为我看到有很多地方有RestoreTPL,很频繁地,
7 u6 }0 @& I% }. l5 X- T; l0 e所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
# N. k2 H$ J5 |$ |2 A
8 @- p; \& |8 B+ \4 P6 v* ?% YTPL的控制,
1 X' M; @+ j2 }3 F$ e我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等): y1 K0 }$ d4 `. P- A' _5 V
不想被一般的事件打断时就会RaiseTPL来处理,
$ Y9 t4 u0 S6 Q" X' M$ s* @: |处理完,就会RestoreTPL了,$ B- X1 S7 W+ s# F' Q9 p3 A. J
当然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./ r: ^- v  ~1 v1 D/ ~0 \
; E  _% _4 Y/ G6 @  E% M0 _
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)- ?# U3 M, @* ^$ @7 k; t
所以,就可以"认为":' @$ P6 g% [& \% k  |  Z
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
; _8 Z- |5 c% C  l/ V9 Q
7 p! b4 f+ z  j  S. I& H而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
7 a$ \* h3 I) N
# j3 W& u  W+ 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属性。; f5 z. X' f1 T7 J* t/ p
typedef
& p8 \# [! C8 p; S) MEFI_STATUS- g- B4 q( A( L  Q' l& l- p9 g) B
CreateEvent (4 t% @$ j, B$ _% B8 q
IN UINT32 Type,
+ @" F( n0 Z% k# nIN EFI_TPL NotifyTpl,7 ~8 a0 I/ G  H3 U1 m: M$ @8 t
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL% U+ H. {( `# g9 Z( X: B& E
IN VOID *NotifyContext, OPTIONAL
- P5 }1 ?) o/ b9 W# O, QOUT EFI_EVENT *Event
9 i$ C+ \$ @( }8 c6 U- i2 I);
8 S' V: A4 U  `4 T中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。/ i( M' d  L7 Z& b/ m
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
3 ^7 {* {9 B. |! l+ a9 D谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:$ i- O2 ^1 z% {- ~
如果是Binding Protocol的Driver,在自己的Driver里面, q, o* c: \: H" `! o) \
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)! i( V5 X" b7 i! Z
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
4 V+ S: v2 {9 z2 a7 Q在Event的NotifyFunction里面: m$ L) M5 K( J6 Y8 _9 H
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles3 ~1 o4 _2 J) i1 a- w: N1 h
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!! o, D0 W! L4 N9 }
可以Hook到所有后面的driver!!! ) ?% i: f' K; F

! T( O  N. U+ m: ~% W8 j回复 13#的帖子( X9 V' v! [( N! H6 M
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~$ F# s) x, }; J) i8 t" W
. V1 k5 k! N5 @4 D
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加* w1 l1 x6 i' |  k0 V. E
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
; ^  k2 s1 j9 RCoreLoadImage()-->CoreLoadImageCommon():% ]% r* A& F8 O
  //
, t1 H8 T1 z7 t3 B" z6 g, f$ w  //Reinstall loaded image protocol to fire any notifications
8 \! c/ ^9 ?5 q  //
0 Q! Z& n* a  U" [4 u' i/ p  Status = CoreReinstallProtocolInterface (1 [5 e7 p# ^9 r/ t; D2 C' E/ @
             Image->Handle,4 i( r2 R, b% r" K8 y' x3 ~
             &gEfiLoadedImageProtocolGuid,
* B# k& _. L0 Q& ^             &Image->Info,
$ p8 K6 x" z; P0 l             &Image->Info
2 l, V2 h, ?: u- c( k( k1 t$ l             );2 K1 S/ a4 p' t$ L

, ?' |* x+ J6 {File:Notify.c
1 k3 j$ D5 P3 U8 f2 KCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()! j" ~* J8 Z- O6 {7 P. \
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
# o+ N9 F  L# d+ d1 A5 H3 nFile: Image.c
1 b& o* s; e/ z, K: w: p; ?+ z2 jCoreLoadImage()-->CoreLoadImageCommon():
  {  Q: T6 M4 d/ v  //
: p# a+ [0 [  ?6 n  //Reinstall loaded image protocol to fire any notifications1 U' F$ V2 h& U. @
  //
% T$ v6 z3 g: U: a6 I  Status = CoreReinstallProtocolInterface (% n! n5 v9 ]6 e2 U6 \* I
             Image->Handle,; [2 y) z2 {1 t! ^+ r
  ...
( C! }, ]  W& Z- i
) w# S4 K# ^. `1 E$ G& X3 R
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:1 N4 k3 o2 B1 i4 v
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
% v% q7 z! i8 b1 t% M- m) y7 K, d; l0 b4 O- r. |7 i6 c
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
( S/ b( o. z( O5 p# L谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 09:19 , Processed in 0.118879 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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