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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,0 ?  L) ?. t. a% u* V
一直都不怎么理解为什么要做出Event这样的一个机制?
7 ~3 s. G, w! \4 g2 N, P$ R( _' t# ]5 q
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)% B9 n8 z3 I* N% n8 A; s3 k
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;' |. D* {! D# K" Y
还有Group类型的Event,用于处理具有相同类型的事件0 h$ t9 r. J) n" n5 H6 {
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)4 u2 M/ q1 {! V. |  L
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,8 Q% z" m- q: S
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
) o& l- W" v7 w因为我看到有很多地方有RestoreTPL,很频繁地,
$ a( w* A- F4 J' {所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
0 @+ L6 Q1 F1 H$ N+ W* g  X2 d1 _/ q( [6 L4 S
TPL的控制,
7 Q% H( R$ Q) Y我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)2 H1 _& j1 c; }7 @/ d
不想被一般的事件打断时就会RaiseTPL来处理,
+ F% v) W# y, D+ U处理完,就会RestoreTPL了,
1 g( a' d- R% _; 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.
, v) ?7 i( R+ I- I6 v1 {' r5 y8 a8 N* U$ j! n! S7 L/ n
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
8 J+ f9 x8 W9 K6 R% R9 {9 A所以,就可以"认为":
; D, N# \/ S) h" ?- ^1 d1 q9 _       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。. n  K- U& w6 [

1 l1 q! D$ w9 F0 u# O而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
( q: B" c# ?2 o0 L+ \2 v5 g" Z8 x) S. J3 C5 V# q5 N1 g
我个人理解,每次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属性。/ z2 Z! G. {# ?5 p2 Z
typedef- \1 B: c) D, Y& g6 a2 u7 l$ q
EFI_STATUS1 e7 P; h5 ?& z
CreateEvent (
& Q" f6 y6 e! \/ u% b- g( c+ aIN UINT32 Type,! R" ^$ W! b8 Q2 K: R0 I  a
IN EFI_TPL NotifyTpl,
& j% Y1 ]5 Y2 B1 _# `% B) jIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
' b% d9 n' T1 x" f6 z4 x7 JIN VOID *NotifyContext, OPTIONAL. ?2 M7 j) ]1 l( Z
OUT EFI_EVENT *Event$ P! L' a* J' ^% }+ G
);! s& M% ^: \: [
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
2 Z; F1 R- w9 S( A/ ~4 P1 C使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?6 X( m2 d# v4 V( v5 O8 ]+ O* N
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。2 Q4 O  u6 D5 @% I
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。; J2 a9 b9 V* [# y! Y
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:2 c. Y9 N6 m3 B1 ]: V% g: A
如果是Binding Protocol的Driver,在自己的Driver里面
* M$ O! c& e; Q8 {用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)3 k6 \8 N) Q/ g5 F# K: E
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
. O3 N4 R( q' p4 Q% H在Event的NotifyFunction里面
: i# [% x; O/ g+ V% u' F$ _4 r还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles/ Z* W0 k  k5 V- }1 ]: t
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
+ }& M0 E' F6 b5 w- E7 ?! f6 \" ?可以Hook到所有后面的driver!!! & Z* P3 Z+ B2 i  r/ _' w$ q

7 y% V" Q0 j$ k$ j回复 13#的帖子' C% x( c5 O* `/ h1 n
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~% I1 E3 K$ `+ r3 C7 k) e) N
8 P) @4 c2 ^7 m% B& p8 C4 h9 F
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加" A* ^9 J0 R& o6 G
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
% G' v4 o# \  Q; gCoreLoadImage()-->CoreLoadImageCommon():
0 W; B* M) n% r  //0 W+ ~- Z3 i$ i+ J
  //Reinstall loaded image protocol to fire any notifications3 ]! S6 s' L0 G8 O
  //
5 L2 Y0 L; _$ Q  S% N. B% V7 `# _' ?7 L  Status = CoreReinstallProtocolInterface (9 |# v  S5 z8 K- T) J/ j
             Image->Handle,6 `, P8 ?% v9 E7 U$ [/ m
             &gEfiLoadedImageProtocolGuid,! _" W. N( N. t; m/ @; e1 m- f% C- K
             &Image->Info,2 H  n3 n" o+ P) Z
             &Image->Info
3 G, ~  o, f( [% d. b             );
! B2 u3 |* V  ^! f( ]
( x9 r* _& l& ^; T. B0 zFile:Notify.c# u! q& m) w8 N3 @" `
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
$ E7 O- }, F8 g; R* i6 vCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
; g! {% Q4 e& _File: Image.c
. ]& `1 a9 m  M0 C; \CoreLoadImage()-->CoreLoadImageCommon():6 u/ W! l7 `3 e6 a# d5 _
  //
/ w1 x7 f' ^+ \) w) U  //Reinstall loaded image protocol to fire any notifications$ [* {7 T: ]& U# g" |
  //
6 E1 I# i" V, H( Q2 `, s  Status = CoreReinstallProtocolInterface ($ p. [: Q- ?& U" _4 B
             Image->Handle,
2 z0 V3 r2 v# ~0 G8 b  ...

5 j4 @( z; T5 r1 j" K$ j7 o - @$ ?. S1 \8 N/ ]& X+ w
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
: }4 `; j6 s6 z4 ^. |CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?5 o, Y/ S0 w! z$ c3 H3 i9 m  M

4 W$ X: T! \3 _  i) w: N1 _% `9 |[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?+ |- e4 A, r) l7 I8 J
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-4 18:19 , Processed in 0.074490 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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