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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,: s3 d4 W( Q+ O' U5 r
一直都不怎么理解为什么要做出Event这样的一个机制?: R( I! _! m/ H* R

! O. \4 W) R( H( C. }Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
' D3 {& r) T4 }3 P# R! jWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
- T5 p" P' K- i+ P; G还有Group类型的Event,用于处理具有相同类型的事件! f, C/ a) m4 e( T. P# _; X. [
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch), C' B& s/ D! q: m  D3 L! G* c
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
* o* H6 P6 N& |! C& \( \不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
9 j# D7 k! J) S7 w6 C: D因为我看到有很多地方有RestoreTPL,很频繁地,/ k5 b9 H- b) F/ \/ W2 d  @
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?7 Q8 a/ B& \# Y5 F# i. a* \- C
+ N; J3 {, g3 A8 p% e) a
TPL的控制,: S+ x( d1 F, @1 \( {: y9 ^' t
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
; H& p9 o+ y/ D不想被一般的事件打断时就会RaiseTPL来处理,8 y8 n9 B' O8 M. l) ~. P0 ^) ^
处理完,就会RestoreTPL了,
, d% R! G8 z* v9 ~6 O* P% E当然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.! G, m- A5 _9 v$ k& K. G% e3 s
1 r) \5 p" H, D7 P- H. A
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)+ O, T8 a1 C  W* |6 S
所以,就可以"认为":7 x: m' [. Z5 x3 W8 {# ?$ l
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。9 R- }8 [" m4 v
8 w# G* X8 q7 L$ M( U6 {
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
- Q/ w% `5 w. G: K- T! k5 D! [3 Y
0 [, O* x1 ?+ p* A! a我个人理解,每次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属性。: y/ B: v( y0 M, x; L
typedef# t  f% O: _; c. n6 g9 f. N
EFI_STATUS3 B/ h, F7 h7 F  l! F! T2 F9 H, W
CreateEvent (
9 B/ q7 Y: z  U6 q1 W* _3 k' ?IN UINT32 Type,
$ q! ~/ o' T6 ~3 rIN EFI_TPL NotifyTpl,
! k! b. V. s3 t/ F; X* D8 S1 GIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL$ O& Y( C( q4 a) ^
IN VOID *NotifyContext, OPTIONAL
; e3 I  o4 _3 v7 k' D! YOUT EFI_EVENT *Event
0 I/ J6 e6 k, |& F3 e. c);
& K. H5 f1 K7 ^1 l/ k) M中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
  {1 Y9 g) S2 F9 K使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?+ t9 M8 X$ d. ~
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
8 c' a4 }$ k" Y8 Q7 ZNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。# Y% ?/ m8 ?2 b) M4 H+ M9 i; F7 q' f
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:7 ]3 X4 X& S$ Y  _8 u3 E- Z
如果是Binding Protocol的Driver,在自己的Driver里面4 \  L; b/ y8 A& r$ O  @
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)' Q! N) }6 c/ |! z% g( r
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,, |/ n$ [5 F( }( Z6 ~  u, N
在Event的NotifyFunction里面
7 z9 q: k. E: w/ C7 p还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles2 G8 Z& [& P" g% a& b) t
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
+ A& W/ Z7 l  y3 @: M6 G$ {可以Hook到所有后面的driver!!! 0 R0 H* j8 S6 [, X! R3 g, x
; c% i. {5 [* }/ G) F8 ]" n
回复 13#的帖子7 D3 F( f+ s. M
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
- q( O% [1 p: d5 e3 w4 v& U) N, c6 ~- k4 a) K  c
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加' H# T. r8 ~$ k. y5 v0 L; G
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c# r; g3 A% W: t' g5 [$ b1 K
CoreLoadImage()-->CoreLoadImageCommon():
" I: W9 f4 @' W7 y! v) F7 Y. k  //
. h5 _( e0 T/ N  //Reinstall loaded image protocol to fire any notifications" L6 a! O* h6 J1 o
  //
" M9 T  l: J& U7 e" F  Status = CoreReinstallProtocolInterface (
/ D. a' ^2 x5 |2 t. p  R# P             Image->Handle,
% Q6 ]9 Y1 u  E, `5 \: T             &gEfiLoadedImageProtocolGuid,7 o1 o& b7 i0 B" ?" S
             &Image->Info,
+ P; G! g' e. n8 y; \. R             &Image->Info
' n- z7 `* ^8 b2 b; h             );8 ?' B* Z6 W3 Y
) O3 s7 R9 `; i
File:Notify.c. @8 D# S8 R1 V7 J% I4 B( A
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
- c- x' U2 y8 \) ^3 M) XCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 ' v) ~; y! t" ?1 I
File: Image.c
! @& h" ^+ \+ [3 M# }; u  d% }; jCoreLoadImage()-->CoreLoadImageCommon():. {3 o4 \+ v4 r  m2 J) [
  //9 C! z& B1 N4 T
  //Reinstall loaded image protocol to fire any notifications
+ E: d: Q' u6 }4 H3 i* C3 x  //
; U9 s4 S# b+ U; r  Status = CoreReinstallProtocolInterface (
8 ^6 S8 w" m8 i) ^( R( r8 V             Image->Handle,
0 H4 X* v5 Y2 Z# s. |  ...

: O8 n5 t( Q$ H6 Z0 `
9 h/ T" Y2 ]* j1 E: D- v1 |9 C感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
" K4 L4 |) h/ L% u1 T5 R+ c. q* GCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
6 K' H) C9 @9 w" U! i2 B5 h3 u. t, I5 H0 c- `# ]: ?/ H! z
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
' J! ^+ [4 }5 C谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-20 05:43 , Processed in 0.043185 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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