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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
1 l" j: R4 h* h! G3 _, L一直都不怎么理解为什么要做出Event这样的一个机制?! \! S6 W  d; B0 ^. c" n; c7 g
" A3 t! C. ], r, f
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)! A9 y$ x' C4 v+ I9 \
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;+ r5 I" u, K- g, B
还有Group类型的Event,用于处理具有相同类型的事件
2 m9 ?# D) ?/ k' t一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)& Y4 q/ t, }1 w# `& x, q
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
$ w4 U  l" p! N5 N不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
6 B8 H% K% y' Q" g5 T3 O因为我看到有很多地方有RestoreTPL,很频繁地,7 x% i4 c4 b( |% O' N( K
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
" u2 F1 D5 {- E4 S, ?, j0 [) w/ y
) D7 X0 w2 f" X. {9 Q; u% g+ bTPL的控制,
5 Z7 U" Q7 J4 K我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
$ N/ ^! }$ v8 T+ E8 m- @不想被一般的事件打断时就会RaiseTPL来处理,
$ _! k1 ?: j, D  ^; L处理完,就会RestoreTPL了,$ a) ~$ d/ S9 y( Z
当然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.* {$ e; |) p9 Z8 j& \" M$ M9 @

$ G/ j3 b3 f0 T+ B0 U我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)* r. i" r; U5 Z! e
所以,就可以"认为":
/ ?( h- N4 F3 Q  K1 J  J6 f       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。" w2 t" g6 K2 y
' ?% a; x: i3 z* v: z8 F
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
( x$ x7 s  ?7 I" ]% v) m
8 L$ S1 t# Y/ q. k7 |我个人理解,每次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属性。
( r; t1 l  R( e; ~% `# e. Gtypedef; i  e' w" L3 x/ x% K# [
EFI_STATUS) |- b! r6 T0 D; C
CreateEvent (/ h5 O  B, y% B$ ], ~5 B
IN UINT32 Type,
4 x9 c& t# ^, v6 sIN EFI_TPL NotifyTpl,
1 t$ p( |2 D, {5 GIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
' D$ \# M/ u% c3 S( wIN VOID *NotifyContext, OPTIONAL
# W, Q" r% E7 L9 UOUT EFI_EVENT *Event
, e/ U& y- \* P, s7 j5 A);$ {9 o4 Y  O. h9 F' @, ]% O8 S
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
3 x, I( J5 h) B- Y. }* B4 u使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?5 s" m9 J! H- @& S: m
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。+ }( ?$ f3 b6 @, [% ]! Z0 {
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
; M: ?, ~$ z! \我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
" v  T( _5 f8 a0 j如果是Binding Protocol的Driver,在自己的Driver里面, n/ K) W& B3 l% c% Z& Y
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
/ z+ W* W: T. Z$ K, O1 _" u记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
4 g, S* f9 L2 |在Event的NotifyFunction里面
" ^* x+ p& L+ ^/ J3 U还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
' T& b' J' H: s/ M( {" ^' b6 f这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
& \) Z! c# f# a可以Hook到所有后面的driver!!! , P: T5 d6 Q& x# B6 _
  b: J: `; c# D* a! o4 z
回复 13#的帖子. B: p0 ^+ f- C
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
9 c9 ~& y& b0 ~! G/ I  A  n0 F9 l6 v! A3 m$ q% o0 ]8 o
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加) z' ?5 G8 C( Y9 S
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c8 M  j+ H' ~1 {7 ?& w! m. h$ v
CoreLoadImage()-->CoreLoadImageCommon():
& m; A" }2 b) u  E$ G  //
8 y( D0 O/ b0 A; D  //Reinstall loaded image protocol to fire any notifications
* ]5 g- A. c/ ^  //9 n, W7 i% S2 N8 Q
  Status = CoreReinstallProtocolInterface (" ~" x  H, o: a3 W2 a  N; E4 w4 K
             Image->Handle,* n1 p$ ?6 G* b- k6 y& q
             &gEfiLoadedImageProtocolGuid,- D9 w9 f7 y/ L  \% J6 R
             &Image->Info,7 f5 Y, I; C) P0 T2 L+ E
             &Image->Info$ F3 X) L0 Y/ y9 c( `: U
             );
+ \. h8 u6 u6 l7 l9 N+ F% ]# Z* ^/ q3 h0 I' Y
File:Notify.c( G7 B7 f2 L* k4 ^% @/ t
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
( O( f: f* [6 A' R- ]CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 3 w) p" N$ w) n# h% m% V8 ?
File: Image.c% k% h; f* q! ~1 n9 O) q' l
CoreLoadImage()-->CoreLoadImageCommon():
9 o6 _+ c* O: w7 x+ C4 W  //2 x. N0 H7 {+ B' S1 @
  //Reinstall loaded image protocol to fire any notifications
& `3 V& u( u- K& J# T1 _  //* i  I  x# T) o' |
  Status = CoreReinstallProtocolInterface (2 D' z$ E( Z4 i( x+ v1 v! A7 J
             Image->Handle,
9 Z- M6 ]" h9 x* ]: E. L6 V$ P  ...

! B  p$ U9 L( p6 P' P
& G( h/ P, N4 N2 m( W* F" Z& r感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:2 s& a& q/ E3 T$ q7 F
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
5 @4 k% u7 \$ w& l7 O  L0 l
! _- d2 K/ x0 m# q/ `- M[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?( d( a3 f5 u+ t7 O- v: U4 F+ }
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-3-5 00:14 , Processed in 0.031784 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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