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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
* m( l& _( R1 X8 \$ A一直都不怎么理解为什么要做出Event这样的一个机制?7 S5 I$ ]$ v+ d9 c

6 m' K$ z# s( i9 C" W" R! G5 A2 WTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
5 C; u, S5 U2 H  u: {6 s( F5 ~5 VWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
8 [# u7 y6 l: O2 L3 K还有Group类型的Event,用于处理具有相同类型的事件
" \9 E/ k, A+ q: Q4 H) _一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
0 U& T' U0 i2 E6 f5 l: D$ ]这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质," p# h( ^, [) h1 a4 M' d1 J, I
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
, h" s3 Z- M! E. \9 X+ {3 K2 p因为我看到有很多地方有RestoreTPL,很频繁地,
: w4 Y/ [3 F& f6 t+ U" ?% j所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?) I: H( q8 ^" o* ~7 K+ b

( d: ^0 U- \$ M: F1 MTPL的控制,
# l$ \# o% r' B+ W, O& D我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)- h8 h9 H5 x8 b, L
不想被一般的事件打断时就会RaiseTPL来处理,6 I% P1 l3 a( M" [* E- Q
处理完,就会RestoreTPL了,3 b% B: _: s2 R* {
当然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.$ H( ?  x/ y3 I2 q& `

- k5 J5 D5 t; l) i  \1 T我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
. h- |* u7 J8 q7 h! I所以,就可以"认为":3 k, Z* z% D5 I
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。: e  K) ]" C' b8 _

$ w/ a+ M- i+ ~& u- E4 {而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
* y' P. G% V/ \2 f% N# |6 L; h) ^% z7 y: o! D: d5 S9 I
我个人理解,每次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属性。
/ u) Y( ?, J8 Z) }  Etypedef
6 l' @% a) m# j! xEFI_STATUS
7 i0 j2 c' ?6 K2 W0 g6 x3 BCreateEvent (
4 {2 \* A2 b/ j$ ?IN UINT32 Type,. s0 p6 q$ S; F1 S. U
IN EFI_TPL NotifyTpl,
# `; w- k. W2 g2 R2 {9 R' a4 sIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
7 Q3 D& B! w4 B0 g! w, |' [& [IN VOID *NotifyContext, OPTIONAL) O* e8 u  f$ T- l/ Y$ ~
OUT EFI_EVENT *Event
. O- k5 N. s2 k3 [, g5 s' E) y);) [+ ?$ ^. j) [8 J- r5 l
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。' B$ c7 r+ D$ f+ }7 g, d
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
9 C! I: v# {$ C& H谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
) `7 g# v  Z% e5 u# |& ^Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
6 P7 ?7 R( m3 n9 a: n# [我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:. \8 i, l; E3 K
如果是Binding Protocol的Driver,在自己的Driver里面
$ j' Y* a- k3 v7 K2 C用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
0 g# ~8 W# W) \# G2 S记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,* z' c! a. q& h
在Event的NotifyFunction里面
3 w% [7 D) g* s, q- P2 m; E; `# `还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles8 @* B5 z0 G/ z8 c8 |; {
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!7 p; l+ {$ _4 t! \1 Q+ |" \
可以Hook到所有后面的driver!!!
; O' e* |% D6 g: T2 p8 d5 v8 m- s7 l, W" E& ^$ F  d5 I
回复 13#的帖子) V$ F6 B( Y8 E5 V3 _2 f! r* s
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~8 M  A6 S9 v& Q
* |+ F$ ]( E) z
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
+ c. F, u: k1 E+ E+ y+ Yxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c* O' O6 q# T$ e. [% p
CoreLoadImage()-->CoreLoadImageCommon():2 b  \9 T# n7 }5 o# q% [: D
  //1 [+ Q/ `  `; O. ^: j4 s: f
  //Reinstall loaded image protocol to fire any notifications8 `8 S7 I: {; P5 W* q
  //: e+ V3 D1 ~" q7 m2 c2 Y4 ]3 _* g) ]
  Status = CoreReinstallProtocolInterface (0 r$ `7 B* i2 ~3 G
             Image->Handle,
- p6 i( _. e: ?" H; s) {             &gEfiLoadedImageProtocolGuid,) K  f/ a% f2 r; k
             &Image->Info,- O2 b5 r' M6 `0 K
             &Image->Info
) _: L! e7 k$ X- j  U6 G+ S             );5 [4 y: n% N  x# D; x

7 v, C- D- q3 J6 [& cFile:Notify.c# {  f3 a. k& h3 {% n0 b
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()7 H# a; u; w/ V. F7 [2 r5 s
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
7 |3 j4 L! ~, z0 N# q7 T( E4 b3 OFile: Image.c
% W2 c3 K8 z) m7 hCoreLoadImage()-->CoreLoadImageCommon():
, X0 Q# Z: [0 J4 `3 C# y  //
+ y9 T0 _7 v4 Z, ~; e) }  //Reinstall loaded image protocol to fire any notifications
7 u' A& A% U% c$ K7 y' e  //
/ J  n+ v( F' D  Status = CoreReinstallProtocolInterface (
# n6 I# t5 h4 j  d( ]! `             Image->Handle,3 E9 D. `6 a9 R. H
  ...
' R) f1 o7 P0 p0 {6 R( n4 x

% ?1 c7 t& p, T' C4 O( y感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
$ q; ~) d3 o3 W. ?( I) Y0 A1 xCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
9 d" V1 ~, F) n% t1 v2 m; `: `, e( m: O" S9 j3 x6 \3 O% b
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
" D! z8 M9 U% ~谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 08:34 , Processed in 0.401857 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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