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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,. R- g  y. i% b1 Y2 X8 y/ d+ K: _
一直都不怎么理解为什么要做出Event这样的一个机制?
' a, X+ H" d1 t3 t: ^) D% u5 s4 n8 G5 m- U1 Z2 |8 u  D2 d: a
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
" o: W6 G  d& r6 R* qWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;- m  y( ^  }1 _$ G" [, E% t
还有Group类型的Event,用于处理具有相同类型的事件
+ |9 N/ m& n  \  c" G$ m+ l一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)7 ]8 }3 v' |+ z' z
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
3 G. m# X$ g, t) P不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.) A) N' Z2 g3 k+ k0 w. |
因为我看到有很多地方有RestoreTPL,很频繁地,: T5 s) m7 Z- C
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?7 i% t' B4 C. s9 n9 w0 J# z# d
2 c( ]: A! \( u/ q' ]
TPL的控制,
- q0 K. D: C. _' t" f: F我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
2 ^' c# B/ N" a+ L5 V不想被一般的事件打断时就会RaiseTPL来处理,$ r3 H( v( R  t# }9 o
处理完,就会RestoreTPL了,0 j# p  K9 s' d+ A0 N+ M$ u( ~
当然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.) Q0 e+ ?( N: B" `% v( m' u
+ V$ ?3 n1 F/ m+ Q
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)$ @  E. |$ U) Z* B! E9 u9 b- t
所以,就可以"认为":/ l3 ]% \. c- z2 S- ~
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
. t' }" H7 n0 }' o! ?+ S
! L" g' ~0 J8 s' @而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 / J  y3 R7 H. Z9 o

0 I3 b& e# ?& Q, `; S% G% }! d我个人理解,每次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属性。/ Q4 e& X( c' g0 k* v+ @
typedef
4 ~* f% Y: m( ^" b& K7 ~EFI_STATUS3 ~. H' a! u% l0 y' f7 L
CreateEvent (+ u/ F- {7 b) w7 w0 U/ b
IN UINT32 Type,6 c) \5 {: d+ w1 t
IN EFI_TPL NotifyTpl,6 z/ N, [, f1 s& D
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
: F0 C# S1 ^+ q- kIN VOID *NotifyContext, OPTIONAL
5 n9 e! P0 |& }1 MOUT EFI_EVENT *Event
7 i3 e% Q1 S5 |: N% e);( D$ I' v( p) z0 Z' z- k+ B
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。" k/ W! o- b8 @
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
. G! o+ q# u2 \4 |谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
/ D, a& X+ d  k4 f( @4 yNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。9 l1 i" ?5 [4 ]4 T5 K! f, c
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
& S% }8 Z2 a+ h3 @) f3 l  }! E如果是Binding Protocol的Driver,在自己的Driver里面
: x8 ^, s( ~& E+ Y用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
. l* E9 l. c& P# b! Y. T记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,1 S. y8 W9 b& p, g- p2 v
在Event的NotifyFunction里面
4 z, l9 R" X# o: A# \* S: H还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles% R6 A; L% z# g& R, j" W8 r
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!5 M# ]4 q* c2 \$ ~3 }0 w
可以Hook到所有后面的driver!!! ! P# y' Q( K$ ^4 E& j

( }. c6 R0 E1 M4 j8 ^9 }( ~6 p% h  F回复 13#的帖子+ J! b! |  X3 A& O9 e
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~' p9 ]8 M. L' F3 ]2 s3 t( W

$ {, f3 f1 H1 C0 l' }在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加7 [: j1 s4 i9 g4 z7 a8 u* y
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
/ x  o8 U/ i/ c6 l  v* V) zCoreLoadImage()-->CoreLoadImageCommon():
0 i7 b& R% d& t& b3 c* `7 N  //
' |1 C6 j2 K/ i5 L  //Reinstall loaded image protocol to fire any notifications
. e2 P, o0 [, r* ]8 c9 r  //- m* Z9 I8 w9 R$ M7 ^
  Status = CoreReinstallProtocolInterface (, o  ~5 N1 X* `. T
             Image->Handle,$ ?1 b8 w5 p6 q, G, _& B
             &gEfiLoadedImageProtocolGuid,
6 _) j& V6 h$ o9 R; S/ ~6 ~             &Image->Info,9 x/ j1 _' i) O
             &Image->Info3 g! |9 ^1 ~7 t5 J; D
             );
' z7 w. w: z7 u- l) g$ H
* A2 x4 B( {2 W' BFile:Notify.c
' ]9 }6 @! ~/ v% E$ C3 B) kCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent(): \2 G3 [: N2 C! M% N
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
7 H* ^' a$ M4 P/ V" Z+ z7 L! L5 gFile: Image.c) J, {+ _6 ]; c: \. g8 u0 Z3 Y6 _
CoreLoadImage()-->CoreLoadImageCommon():0 p# m+ O  B( F& k) k% a/ Y3 k* q
  //2 h% j) s. U# f: A4 D: z
  //Reinstall loaded image protocol to fire any notifications1 X. {) l) f6 V3 r" n' I
  //4 a. a' I7 y2 w8 C. D) T* w/ s
  Status = CoreReinstallProtocolInterface (
% E/ x0 a2 `4 S* X1 j             Image->Handle,2 d. |" s2 z! u' ?! j$ R
  ...

$ o; t3 O9 f3 }2 I( }" d ; L+ P) r, X7 L  v
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
& M, P  v1 f+ u# U4 cCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
) e; U8 K0 Y- @9 |5 Q
+ @  W- ?" ~: x+ o. m  M! o[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
; F; c& o5 w, E. M/ ?谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 03:36 , Processed in 0.074982 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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