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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,% @; A9 N. ^2 A
一直都不怎么理解为什么要做出Event这样的一个机制?
( M+ c2 k8 j, r/ R' G$ r. L
: R/ R6 d$ o$ W0 bTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
/ y) v, @1 x0 p' Y0 N/ GWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
. v( e, X; A7 x- _还有Group类型的Event,用于处理具有相同类型的事件
( d0 V7 _3 L' B9 s: N! B一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch): q) e. |# s) ^
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,8 K- s- y" R& R- @& B
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
2 K4 f, @& T8 l# [因为我看到有很多地方有RestoreTPL,很频繁地,+ r+ T" R2 L0 o( @
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?$ o- n, i! g: [
, O3 E' q5 M; [$ a# Y
TPL的控制,
& y6 `' D7 g3 H8 u8 m# r我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等). H. N" A. T$ F4 w+ K
不想被一般的事件打断时就会RaiseTPL来处理,$ O% q2 Y, h1 `: s+ V
处理完,就会RestoreTPL了,
2 c7 W1 V- W! A) s$ L6 w+ D当然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.' G2 P+ _" M1 T9 a% W% M4 s* s6 A
/ h) a! [; O: l4 r8 I" z
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
( K2 G# K! d% {/ _, ?% S) S( `0 u所以,就可以"认为":
" \/ i4 U  m& I       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
+ r! j5 x  U1 X" X+ O3 x4 H. B6 o+ ?
8 q* u" F, E! J" D7 b而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 3 }3 `, G- Y! h* @" S2 N

9 d8 I8 B5 k; z% f' ^( X6 Z& r% A+ f5 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属性。
) _) U% `; c& ?typedef6 N2 X' \7 y% N" I
EFI_STATUS$ E/ S8 ^6 A2 Q' R
CreateEvent (' f9 U% B7 U4 e4 p7 B
IN UINT32 Type,
6 V3 t8 u- K# \* Y- w- u1 x2 |IN EFI_TPL NotifyTpl,: R% ?' F. _" ^
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL) P* X" q" E  Y
IN VOID *NotifyContext, OPTIONAL
8 X: {' U- v$ o3 R1 sOUT EFI_EVENT *Event- }" L9 M& T: S9 Q0 [8 [8 r
);
# I! \1 a) |5 V中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。% H$ f; P: Y( v
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?) }1 N* X- }1 r( v5 P" `
谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:/ Y( K# J% g5 P# L/ o
如果是Binding Protocol的Driver,在自己的Driver里面$ {- N( E, B; @1 J2 e
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)( V4 v5 p  L1 g4 H0 C, D
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
  N3 u: P0 c5 e# C5 ~8 r) Y在Event的NotifyFunction里面* c* `9 t: o4 H$ a- B+ m2 \5 O7 Q
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles2 F0 d: i* ~/ E" R5 _
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!$ K2 p& P" A0 s" a
可以Hook到所有后面的driver!!!
0 X5 s( @  _- ?* N" j+ W
" c2 C% W; u- l6 m$ ~  t回复 13#的帖子
1 i, l- z+ C" S5 w在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~, v+ i+ ]$ G3 ^: Q
9 b9 Z, h7 w1 O! w2 k& G
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
/ N7 U3 f  K- L  i# |xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c! D% u" J  z. p3 V3 E
CoreLoadImage()-->CoreLoadImageCommon():2 V, r! p  N9 i
  //
& O5 U; O8 C! P3 |1 q- E  //Reinstall loaded image protocol to fire any notifications3 h2 M& F8 i7 J% I
  //
+ r- e1 l( F) t: a  Status = CoreReinstallProtocolInterface (; d: d7 v1 e5 V! E1 Y. }) y9 i3 ^2 p
             Image->Handle,
' d: ?$ l0 U+ u) @: S3 H7 s: ^             &gEfiLoadedImageProtocolGuid,' v! t3 e) {7 s( s" t
             &Image->Info,2 {( O* X0 _+ [/ l, Z
             &Image->Info$ B, l+ s$ v* I/ p
             );
; l4 R0 [) h; y/ `8 I) e& X6 ?- f4 M, X4 q$ g
File:Notify.c
6 _+ q5 H6 z% U0 `) J% iCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
+ d* q# ]7 N9 x# B7 J3 ~CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 # ?. x9 V0 n( g. P8 n1 o# K1 V
File: Image.c
: d6 k2 y3 @' u+ W9 yCoreLoadImage()-->CoreLoadImageCommon():* C: \$ z7 b9 k- \; e
  //
, U3 V* R* [+ \8 e: {4 V  //Reinstall loaded image protocol to fire any notifications
3 G& b& `  l- P: I: t: B  //# I# \* I$ `; ?+ R4 B; O4 z  A
  Status = CoreReinstallProtocolInterface (1 `1 [, k+ A+ X7 N1 V$ h
             Image->Handle,' l. J) ?) [* Y6 p: z' Q- I( O- y
  ...
, b3 i# C5 k5 C% O

' X" J* A: m: e% L6 V3 \1 s1 q! [: W感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:; r; s6 E4 }1 h1 Z, u+ }7 w
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?3 A( F; L" w' C: l( E; G- S4 d

  D2 f/ w3 C9 W4 f9 D3 D4 l[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
6 q4 W2 R, c# b3 o" F6 r( I) v, K谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-15 06:50 , Processed in 0.131330 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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