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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,$ \4 \9 ?( r$ H. h# E
一直都不怎么理解为什么要做出Event这样的一个机制?# ^$ n1 a1 [+ x: \

. D! j  Y; d- l; ]Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
/ O1 r4 J( P- Z, xWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
7 t0 [) X  k3 }2 j1 m还有Group类型的Event,用于处理具有相同类型的事件
, f( Q# o9 z( t; L2 F0 c一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)" {( n7 \9 p# W  u! x" a$ i
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,) R$ _4 G9 z. U. R
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
+ Z& }9 F' {3 c0 e0 Y6 ]( @( {因为我看到有很多地方有RestoreTPL,很频繁地,
3 ^; ], E% x7 P$ A; y* ~  A; N所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
# s* j. l4 h: }' O% p/ |7 h9 s  i/ ^- i; B* b  T& \( F1 \1 U2 S$ y
TPL的控制,
$ w: d: t2 ?( e' t4 \% Q/ w% w我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
8 _9 X. A! D3 B: @# G不想被一般的事件打断时就会RaiseTPL来处理,
, v6 ^( V$ z9 B8 E1 f! J& W处理完,就会RestoreTPL了,
& u$ y1 c0 [2 \" T9 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.
  d6 I$ p2 {# T4 y
# K  J0 F4 S0 a" z& Y, ]: D" C9 T我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6); X" U* Y' k9 i2 V( f1 w2 C
所以,就可以"认为":! |; n2 V, p* b
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
$ m' m" |( e6 i! U8 F) Y% x* T* J1 y6 E8 ~) g
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
) S! A% e( [  a, g- z+ Q1 I
! Z5 C( n1 T/ F我个人理解,每次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属性。, j2 y3 p2 b" D: Q7 u! M0 P' @
typedef
- K& @# e+ o% ^. u2 m: Q" |4 rEFI_STATUS  N3 d1 `& E! U  H4 }
CreateEvent (5 g; U; r4 Y. A, X. @
IN UINT32 Type,
, a8 B  T0 Y0 fIN EFI_TPL NotifyTpl,( g* j' v) O% u4 g
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL) b( d6 @* `  N  h
IN VOID *NotifyContext, OPTIONAL1 O8 c2 W. p4 a* X. \. O8 i6 t( {6 U
OUT EFI_EVENT *Event
# b) w2 v8 M6 q% V/ N);0 N8 |- @! e$ x$ c% J. f; }- r' a
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。9 b: C- h9 _) q
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?% ^% z; h1 K8 s* F, X' X2 |
谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:+ k, x! f7 {: z# e
如果是Binding Protocol的Driver,在自己的Driver里面, t% a3 ]* L' ]+ n- H6 w1 A& O
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
. }9 @2 j+ _% G4 l$ e0 Y记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
  y) e% r* g1 `在Event的NotifyFunction里面7 u( j+ X8 I* L" ~+ e; s
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
$ k( s( i3 U) ]. {% {& X6 L. k这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!0 L1 X, B; L0 e# r1 H! o
可以Hook到所有后面的driver!!!
& W% h& [; Y+ v8 k3 ?
7 C# [- ~1 ]2 x3 A, A( j, i回复 13#的帖子
  z- {! d$ l. t* e# {6 N在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~8 F3 s8 e( H# A6 t

" Q( b/ q  I  H( i% \- o- w# _在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加' H2 n/ g. y4 X) P; `( c( K- e' G
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
7 D" q$ S7 v6 a5 a/ \6 dCoreLoadImage()-->CoreLoadImageCommon():
1 K: b0 g% A( V  //$ x3 X; ^: I( {0 t$ w7 R
  //Reinstall loaded image protocol to fire any notifications
# l! e: x* u3 L7 o8 g/ F  /// k0 f  W6 {$ Z  t# N& o
  Status = CoreReinstallProtocolInterface (8 p# T6 h0 b2 j7 W. J0 i. x8 }9 B
             Image->Handle,
5 B/ P! Q4 F  [* I$ {# p             &gEfiLoadedImageProtocolGuid,) Q! S! q& d% D" ~! Z
             &Image->Info,
  `8 G7 g5 Y7 \0 p             &Image->Info
- z* G2 b5 H! H6 K             );+ u+ @4 f3 h9 C! u
/ o% T) M2 x. u- X6 k. l% m+ q
File:Notify.c9 J( ]8 t( i' {7 v& k# p
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
% [- K$ X+ y' b$ j& M) ACoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
( G% w& k8 |: r3 M2 F* HFile: Image.c5 g; g( H: Y! H. H
CoreLoadImage()-->CoreLoadImageCommon():
: B6 Q" z  I, u, R  //+ f: Y! I9 i: I) o; S% X
  //Reinstall loaded image protocol to fire any notifications) F- b% e. v: \0 C3 J- V
  //4 p) F, @* X' ~  L. }4 ]
  Status = CoreReinstallProtocolInterface (
% m6 W/ ^: F9 V' K/ U8 k             Image->Handle,
! w, B& X, t. w$ r$ C: [0 B  ...

9 d8 W1 j! F9 v8 E/ k! |
$ o$ n  _: b$ A感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:/ p. @, X+ v9 h  B6 B
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
; F5 v/ l. h8 A. n! e/ m9 Q$ R  t0 ^
7 O7 D2 C" R, H/ E4 ~[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
; n% w7 c' w5 F6 \/ K$ l" z谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 04:54 , Processed in 0.027733 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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