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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,% y3 J6 ?  D# ~0 I! M7 N" i7 O( k
一直都不怎么理解为什么要做出Event这样的一个机制?7 b! a* l9 q5 x& ^. `
& h5 F# Y5 P) y% O( ~/ V% s9 L
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)1 s; W; H9 h$ G  ]! x
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;- {7 Y3 ]! f# A5 `) C5 @+ ]  `
还有Group类型的Event,用于处理具有相同类型的事件/ F. @# x- o* R" e1 x
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)" [' E! I% P) j5 J: H0 v- j
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
  D' c: \4 C9 ]/ Z$ \  y9 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.
! k+ V! ~' x6 \/ l8 C% ]因为我看到有很多地方有RestoreTPL,很频繁地,
; t9 Z& f6 _+ M$ R2 B4 D所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
9 Q+ T6 W% d) M8 `' f) j. P0 ], T/ c$ G
TPL的控制,, J, F/ h. ~+ z/ M1 ?5 s  F
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)) @& S2 V3 D! g. c/ w
不想被一般的事件打断时就会RaiseTPL来处理,
- ?, W1 j2 y1 x; E# n7 S2 ~处理完,就会RestoreTPL了,. @( i% i. Y) U+ ~% `+ l- ^
当然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.
; d% b6 i9 [+ }0 `- ?0 B% Z5 v$ D
5 N0 F/ K; ^6 q我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)( k7 m$ Z# p" D3 `! h8 j3 J
所以,就可以"认为":/ F- y1 @0 o1 l$ N" I* u
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
$ l& v- O) t& Z3 I+ Z& x. _3 @- C& H4 K
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 & l# h! |4 u1 z( U! M8 f% ?: t
7 h# {4 A2 c' s$ e/ E7 H: t) Z1 K& u0 L
我个人理解,每次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属性。
8 ]0 O5 ?+ Z0 }( V9 H7 n- p/ i( ltypedef
6 ]# U7 x: ]' Z2 T- N) y7 PEFI_STATUS5 Y% ^  W! d1 C3 d
CreateEvent (
& G2 h  }1 o2 B/ eIN UINT32 Type,/ }$ e5 ?3 Z) L3 `6 f- O6 o" H
IN EFI_TPL NotifyTpl,
; l# o7 ~1 _' ^9 I: v- u1 P  QIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
5 I# B* v/ q0 ~7 VIN VOID *NotifyContext, OPTIONAL
6 P4 W$ A- \% E- S: g0 [OUT EFI_EVENT *Event
1 E/ [: v7 @1 k$ W2 f) l( p) q);
- I8 Y/ A7 A1 j% J! k' C中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。- n7 L5 v2 h7 {, @
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
; J! B0 g- |  ?谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:: I0 |& R2 w- X$ s% |* Q
如果是Binding Protocol的Driver,在自己的Driver里面2 [" ]7 O: |$ h+ o) B0 ^1 L! _
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
- b1 S1 }- r+ P# \记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
4 B: ]% o( P& F$ l在Event的NotifyFunction里面
9 P0 u" T8 R7 D还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles: y7 e3 Q1 m* ]
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
9 w, c7 s% J+ x可以Hook到所有后面的driver!!! % S& c" s8 T1 _6 C/ g- }3 d( b4 s0 |

& ~) l. k. C9 m" o1 r& L回复 13#的帖子
, h& I: [) P4 v3 R  U) I, u2 e在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
) O. k: U! I4 J+ T- y; _# ]7 V8 r& b' z% X' J" [
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
5 o, }# P' Q  N- H6 J" Q: q3 z- lxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c" T2 k! F6 F4 \4 P
CoreLoadImage()-->CoreLoadImageCommon():4 m3 F! j/ ^9 h8 Z: }% Z" L
  //
* a3 M, ]$ {; l; @/ B  //Reinstall loaded image protocol to fire any notifications! Y8 c+ z/ [! Q$ g( d, Z0 [$ u  u: g
  //
: ]6 v# Z1 Z: Q% V8 V$ z0 X  Status = CoreReinstallProtocolInterface ($ {2 p: e* O# g$ E
             Image->Handle,
3 J2 p; d) k8 p" ~$ K7 |2 y/ H) h             &gEfiLoadedImageProtocolGuid,
2 W6 O3 @) N6 ]* t( ?% T  Y             &Image->Info,
2 U9 ]* `3 T0 ?4 x  d# W0 s             &Image->Info
4 n% x3 w: d% a5 D, Z( }             );
$ p$ `) G! ~0 `, _7 P0 g) B9 d' ?8 B8 |" t4 `- G
File:Notify.c) v" G. t3 k" H7 o5 x
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
7 C2 E! j! X5 [CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 3 F& w3 b4 H" x+ F- N8 K- J
File: Image.c
8 I6 D" N: p4 P6 a$ h2 rCoreLoadImage()-->CoreLoadImageCommon():
" b$ }1 x$ b$ e& P3 A  //2 c) f* q0 P6 O2 t- M, i
  //Reinstall loaded image protocol to fire any notifications, P  e% h0 a/ S6 L1 s* {
  //
3 [4 u# r+ W5 |/ N0 A8 d  Status = CoreReinstallProtocolInterface (
: ]$ W. u8 n% s- [8 G- V             Image->Handle,
3 ?7 M9 b0 U# A7 O; c  ...
0 p! R$ r. X, s

" z5 d, h: w: z9 S2 x* g8 h感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:0 D2 X! [6 U4 t$ s
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
+ {' P$ @5 S- @0 R
) t- U8 {* |0 R[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
' o! g: _# N) l谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-5 17:47 , Processed in 0.064838 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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