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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,4 @& c. j& i) W) `- C  D
一直都不怎么理解为什么要做出Event这样的一个机制?
* n) E+ J  y# e+ g5 b9 |7 u
( }5 |/ U, [, A. _/ JTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
6 J; g2 ]7 R- d; z; t3 ~Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
$ P- M8 |7 }) a* ?还有Group类型的Event,用于处理具有相同类型的事件# c6 l$ ~, C+ {& S9 j& O
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)/ m) Z, h6 e$ C7 i3 i
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
* G1 L2 E( x. p9 p; R% m8 ]4 @不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
5 h! B* J% z4 U& r# M" Y因为我看到有很多地方有RestoreTPL,很频繁地,
- N) y; c( A6 P+ M' \* l- v- R  G所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?) C% _& A  N0 G! D6 M
( z. Z0 M2 t$ ], }/ l
TPL的控制,2 w2 i/ k! h/ l
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
$ c1 A( R. A) \4 S2 C' O不想被一般的事件打断时就会RaiseTPL来处理,% p" {+ f) J3 I% r+ T; j
处理完,就会RestoreTPL了,7 I2 I$ I) X( p
当然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.+ {$ z: z# I; ~4 X# Z9 R' V! v* P8 i
2 O6 a* w2 l. s0 E2 Y: L) O
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)2 T2 M; m. q( y, g$ e8 `- t6 y5 r
所以,就可以"认为":
( R% l2 r" Q' |  d3 c; T       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。* E: t: j9 ~- F" |: I( W7 ?0 D, i7 I

) [0 |6 K* i! y  X而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 & y  q8 X; ?. Z) ^6 L# h; A

1 M. ^4 L/ z0 C* M我个人理解,每次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属性。
. y  V8 v, j2 i# e7 A) P/ L5 ptypedef; V* ?$ h% v  P9 b# H6 H: l* E
EFI_STATUS4 n4 }0 d: O, q0 c8 Q7 F7 `3 W* Y8 k
CreateEvent (, f' w8 T' s# |
IN UINT32 Type,+ l1 L. o, X1 u1 W# U6 W4 _
IN EFI_TPL NotifyTpl,/ o% [" z5 f, U7 Q9 g# s
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
+ O9 }  a- V+ Y* WIN VOID *NotifyContext, OPTIONAL
/ _* N0 @& x; L; F  P/ pOUT EFI_EVENT *Event
  b/ Y3 f" O: W);
4 X) Q5 i$ ^/ J7 ?0 \) x  W! x中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
& W6 ~6 A+ K/ j$ m# ?6 c& a6 }使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?7 g' q" w, y! S6 Q  b
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
! |/ C% N: K/ O" }- E) G8 f- ?Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
' u& q) A5 L7 A9 S5 S我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
% `$ m* j  I2 ~* o- l& P3 P) [如果是Binding Protocol的Driver,在自己的Driver里面
+ G/ v: F$ ~9 y& `: c- M用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)# ]& q* a6 g- W; v  d
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,1 u  q3 b! _7 ]* a4 A. F
在Event的NotifyFunction里面* F2 b6 G! N" ^' o
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
) u7 t& Y- L7 z; `这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
+ Q* F1 q* ?1 j9 L可以Hook到所有后面的driver!!! 9 J% }2 {- d3 @: f7 O" k6 b' U

' _. o$ W$ N3 Q' p* m回复 13#的帖子5 K: L3 ~! ~" @, ^# }+ w
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~# j% z* d  g3 [- U' e% a* g
! P* G2 |% a: }& [# w  }, x3 @
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加5 C1 a# f( t0 f& p
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c/ @7 c0 P4 a! h! U
CoreLoadImage()-->CoreLoadImageCommon():
3 P, a+ O4 R+ K( n: f) O  //
5 O. f! E4 Z- V3 X( P0 G2 W9 y( p  //Reinstall loaded image protocol to fire any notifications+ k7 \1 A4 e# O% Y: A7 P# Q5 G4 d$ b
  //
" m8 Y2 J6 G$ x. Q* Q" P  Status = CoreReinstallProtocolInterface (
9 t8 O2 T+ \- K3 h             Image->Handle,  b  M) J6 p9 P$ D
             &gEfiLoadedImageProtocolGuid,
0 {$ y1 o5 T% l! V7 ^             &Image->Info,
, E6 i+ J! F9 w             &Image->Info* R" S: F* H6 v  }' W  [
             );
5 Y2 K+ O; E+ V1 o; i8 A& H  W3 u% c* ^9 x* @* n1 z  P7 o
File:Notify.c; l# n' Q3 x$ i0 ?- G6 W5 n
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
. |$ Y( W- d& C  V" M6 L; JCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
6 ?6 Q& T) z$ W" ]+ ?- B5 SFile: Image.c
) U& b1 t, @' \, h0 J* r: n" JCoreLoadImage()-->CoreLoadImageCommon():6 X/ q+ C! o+ K% P2 a
  //
, P- Z: h! `! w, o# Y' |  //Reinstall loaded image protocol to fire any notifications9 c- M  d+ w/ @& E9 Q
  //! a" p0 H5 r! ^$ x* a) T3 y
  Status = CoreReinstallProtocolInterface (
  Y, S- P% p% {! K2 N7 R0 [3 g             Image->Handle,& V0 z) k( Z1 a0 U9 w' [
  ...
7 u3 C; S7 Y( N# e( [9 s9 n! T' h0 V
2 w: O$ i$ e" z# ^0 u
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:. I9 d; s; y  T( h$ G  i
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?, Y, @8 ~) ^+ u' [$ \' g

! l4 ~" b8 M. {8 |3 s1 e! ?) X[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
2 C9 s8 }9 z, ~5 _6 o谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-12 05:38 , Processed in 0.057467 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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