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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
0 e% z- p4 s$ B5 Q' v一直都不怎么理解为什么要做出Event这样的一个机制?" n6 N5 i5 E! ]1 B7 f1 P
/ Y9 U: `6 q/ z% W/ S, D7 b
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
) M! B% Q+ i" g) `  D( PWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
; o2 C$ K& }& l7 ]还有Group类型的Event,用于处理具有相同类型的事件' o7 ]/ J2 T4 U$ G1 S- U8 p
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch), W2 W0 Y$ o6 D$ g
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,& D! g* ]2 p! \/ b# K* H% l
不知道各位对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 r+ a3 Y& W. V# q0 A5 S8 }
因为我看到有很多地方有RestoreTPL,很频繁地,% v, w, g3 j& Z( U$ H
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?* ]" L" K) v( h. b. x0 U
2 {! b  t/ X$ A  `# ]5 n
TPL的控制,
& ^; h. F' a- g) R) {: I我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
0 x" ?' I5 m! r% [( ~不想被一般的事件打断时就会RaiseTPL来处理,
1 B1 a2 a  w) |) F+ s* _/ x处理完,就会RestoreTPL了,9 N* Q& n; `" i
当然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.
* E5 S. I+ l4 Y# n
9 o& l, J9 n6 d  v/ U我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6): Z. y& l4 ]  a# ]3 k3 D0 d. p$ @! C3 ~
所以,就可以"认为":
* I4 e1 C9 r& Y       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。3 E5 P4 J! e4 n; |  u  A7 h1 K
6 }: p+ ~$ z9 j4 ~+ }
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
4 t3 g' m! V1 S
) F& @' E0 y. o; V* V+ S我个人理解,每次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属性。
: h2 [* @+ K# F6 @typedef) z; Q$ [. t/ Q
EFI_STATUS4 i) _6 |% Z6 C0 x' l
CreateEvent (! a2 x4 K# Z& E& @. l9 O& Y* W
IN UINT32 Type,* G4 P6 q% U$ U# G+ ?* u
IN EFI_TPL NotifyTpl,9 U: h5 n9 o1 L1 h3 _3 x
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL3 ]( l' K7 d- M
IN VOID *NotifyContext, OPTIONAL7 m, l5 J' T1 V- B, T- ?
OUT EFI_EVENT *Event( F/ v# O% w2 r" H8 x4 j  `
);
* [: M3 n1 r0 f中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
) y; H- g0 ~$ t& ]9 F, }8 x使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?( M8 d, d; Q. s  c
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。1 `5 A9 G- @2 k3 N  E
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。4 s% a8 s) Y3 d2 o" T/ |; n
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
  W0 T+ M* H# T/ |/ m" Y  S# B如果是Binding Protocol的Driver,在自己的Driver里面
- d+ l9 Q8 b+ e, K  O& b用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)/ V  A, ]3 k9 V# `: Z
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,& r0 d0 E, W5 \7 S
在Event的NotifyFunction里面. F5 u/ P0 w4 k! i8 \! l
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
5 D5 J! j" z1 [# f# S& Z. n# ^这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
' t3 ^( S' D( r/ h& b, L) k1 E可以Hook到所有后面的driver!!!
7 v& l% u5 q. l. Y. w" i
/ h( \; U5 o: x' s; Y+ L- D- T回复 13#的帖子
/ h' ~9 a5 Z! J4 S2 g在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
, P" l; w$ ~+ n# i6 X6 J" m
) N  B5 J4 S3 e5 S在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加9 P) v& o3 z& U: X0 @, s2 i
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
, N/ f0 _$ U& T0 XCoreLoadImage()-->CoreLoadImageCommon():
; B9 c: A. [2 Y- h  //4 ]0 _3 ]0 Y- b# l' _6 c8 t$ ~2 l
  //Reinstall loaded image protocol to fire any notifications: W+ [+ x6 h% M! w
  //
& O0 {% G! R- r, ^/ i6 w  Status = CoreReinstallProtocolInterface (/ h# P8 R! e. e
             Image->Handle,
+ k" d9 s2 w5 j, H' d( u9 n             &gEfiLoadedImageProtocolGuid,
2 X5 Z3 A  x: U7 j             &Image->Info,
# Z7 f+ M+ P: ]* e! z             &Image->Info6 i' E  }  Q3 J! g) ^
             );
4 y5 n( C7 T7 W6 m( j  A' l# ]6 O- i  r) e' \8 _; j
File:Notify.c
' e  Y& I" ?4 A! X9 |& C$ z9 ACoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
- T/ t. n; g9 e$ G/ f$ D+ ~5 nCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
1 E, T8 b. H, r) H* I- r( QFile: Image.c6 N! \- x9 h* v1 G0 b
CoreLoadImage()-->CoreLoadImageCommon():
2 I% W4 M- ^/ A! v  //
( ~/ Z8 @7 S, @8 J# U  //Reinstall loaded image protocol to fire any notifications
# h7 ^' w1 k* k0 b6 J8 l3 ?7 C$ C/ T2 Z  //
/ F, a9 y, D1 ]1 a- K1 @/ D  Status = CoreReinstallProtocolInterface (# E0 f$ P8 M/ j
             Image->Handle,) i2 B# Q" I- K0 {
  ...
* j1 J% \3 b3 j! k

/ J$ |: J2 v3 `感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
, {* x4 F6 ?0 k& X0 aCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?1 h% Y. f* z( e% R
$ N5 V4 K0 o2 K- u4 n
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
# X7 a/ h9 v. I" ]谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-19 00:33 , Processed in 0.134979 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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