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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
: j. a; v# z; n  l一直都不怎么理解为什么要做出Event这样的一个机制?
3 l% i' m6 F! z1 f# _) T0 y$ |
1 ~- ~5 z" V1 }Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)* B) J6 X' k/ M+ d, k" H5 R9 W6 x
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;3 c5 ]8 c- t, Z# C6 G" W
还有Group类型的Event,用于处理具有相同类型的事件
- }4 `5 O  x8 @: D, ~& x0 b一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)# Q# l, w5 ^( ?& l6 s% D' r5 v
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,- E" ^8 N0 h+ i( h# r# \
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.4 l- }6 t* Z2 q) R! j. Q4 H
因为我看到有很多地方有RestoreTPL,很频繁地,
9 c: _! Q) |( \- j/ R所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?6 l  H6 {+ [( n% e; g- t
( e8 x; j4 _4 m- I# O
TPL的控制,# Z) O  p/ X# R# z8 L
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)' |7 w. W* G* b- u$ g
不想被一般的事件打断时就会RaiseTPL来处理,6 V; r1 a, I" p8 g( L) b
处理完,就会RestoreTPL了,
' V& i4 N* G: T/ A8 K当然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.
0 d! r0 {! k# J* V' F8 l" O& y$ p
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)$ k, I% Z) O4 d/ N4 ^( A
所以,就可以"认为":
- r2 W0 E7 A$ |' ]+ z8 s       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。6 z; W" @, N6 m
6 Z6 I; Q: F) T/ F  z2 t& G8 [; ~
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
+ B) F% K9 [4 c% }3 U0 G, Y; B- i6 Q4 T+ l% L
我个人理解,每次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属性。
. J+ y( P. q* i2 V3 ptypedef3 J; y. D/ w1 U! ]/ R
EFI_STATUS! f6 N$ E, u# }
CreateEvent (
0 V0 D9 S, e/ dIN UINT32 Type,& e7 t! e4 \: D
IN EFI_TPL NotifyTpl,
0 D  A  P, F1 l0 Q' r! PIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL1 c0 L4 C8 f$ i  I
IN VOID *NotifyContext, OPTIONAL3 S8 v0 a1 x5 ~  b% }
OUT EFI_EVENT *Event
6 J. u9 l) k6 K* B9 f, F);
! c8 b4 F1 t1 r2 I6 @% U中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。/ R9 M$ ?9 i& l/ [' k% ~
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
$ A" ]7 f3 K# }0 u* ?) ?谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:' s- P0 x5 s0 u  B+ @, i# w' X
如果是Binding Protocol的Driver,在自己的Driver里面
) X7 }4 D8 k2 N! c; i用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
1 v; ^8 V0 R5 j8 Q, ]+ ?3 O9 @4 t记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
+ m" w) k. w0 N$ }, O; S在Event的NotifyFunction里面
6 T. _, \* G2 [2 S* W( m  D还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
. w" U" ?4 Z- k+ h1 ~9 C- }这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
# o" D7 t8 ^; ?) p5 `9 G可以Hook到所有后面的driver!!! 9 w+ a5 }* Y0 `2 |# V
3 ?7 ]0 u. ~0 q) _
回复 13#的帖子! |6 B& C; @; H! ?) D6 ]* |
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
" t# v, M6 c: c0 L4 Z1 v0 @* B$ J# B! w6 a# m
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加9 D9 P7 w/ u4 m% _: N
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
7 @+ r; Y9 R: C! |CoreLoadImage()-->CoreLoadImageCommon():
* g* ^( e( K9 T! F  //
  O# j, ~9 ]; K/ k! ~5 Z' Y$ d+ J  //Reinstall loaded image protocol to fire any notifications
! r. [3 C4 P/ `; z" V: B, o7 U2 P  //8 \* \& K) w" l" O( f, Y, T
  Status = CoreReinstallProtocolInterface (. K& ]- }; o$ g; ^" h' \
             Image->Handle,
* }: R% D  A( q2 `* y! y             &gEfiLoadedImageProtocolGuid,
7 A& u- B# y# ?9 M, o7 E9 [# v/ d$ D             &Image->Info,' C2 x6 E0 \/ s6 Y# Z; O
             &Image->Info/ N; e) b; k$ {* w% l3 T
             );
: q+ F. M( \: [, \0 @$ F1 n0 E; M8 D! f4 J' |+ v4 z4 x- C
File:Notify.c
+ k1 f; A; }) a0 L& u$ k6 F" [CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()* c8 _1 a# M, D# G
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
5 x* K  G" ~! }' IFile: Image.c
( E( B# _! W+ M4 HCoreLoadImage()-->CoreLoadImageCommon():  Y8 \- e- J& |7 C/ [7 `% U
  //
/ B9 m! S4 t' j  //Reinstall loaded image protocol to fire any notifications8 Q  ?" O% S: I9 A
  //
6 {. B3 S' r: A  Status = CoreReinstallProtocolInterface (% G4 y2 E+ D: A6 p" w/ K0 z
             Image->Handle,
3 }# l8 C- k# k8 t! J  ...
, y# \) S7 _" n9 c- Z: o

8 g8 f9 v0 N6 }感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:9 M) W2 t  u9 l, T  Q% O
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?) Y/ s1 l# S/ v+ W5 e

7 n5 o5 v0 |- y, X8 A[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?8 P; U8 L3 H/ h0 g5 P
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-16 19:26 , Processed in 0.103046 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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