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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,+ L$ d* {& m  V" @8 J* ]" n; A
一直都不怎么理解为什么要做出Event这样的一个机制?
  m5 c; X% r% j+ M/ y8 e  X5 M! r7 f: f3 L! t
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)7 D9 z9 A. D# M2 b( m3 D+ A
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
& j' ^/ q* E7 X3 _( W* Z% e还有Group类型的Event,用于处理具有相同类型的事件
8 e3 H3 I  A  o4 g* J0 v- S一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)1 B/ Y5 M7 h" T! I& _
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,: b# ?( p7 o' f% Q
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.* W. Z0 H. w) {9 r. R) ~
因为我看到有很多地方有RestoreTPL,很频繁地,
0 Q: V; _& u) K- M: \# }, v所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?1 r% |2 u9 _! j" v# O" l* S# S  b
$ j1 a" H3 J9 `4 B! _
TPL的控制,
: Q* s: b% A; T% i) l* E  W我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)/ \" z  O+ _! P' z, ?8 ]
不想被一般的事件打断时就会RaiseTPL来处理,
5 \  `/ J6 z) R& ~0 P& p处理完,就会RestoreTPL了,! N5 a7 r+ _+ I; 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.+ K! x+ O: t( k% n

7 v2 _( ]( V. k$ t我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
: ^# B& z6 q" |3 W; Q, Y$ ~所以,就可以"认为":' U/ `) N* k+ x& ]  x
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。# c& I. u. R# O3 ?- v2 f3 a! m

1 {' y9 i! U- ?9 w* d4 R4 f. t& H而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
) y* f9 _2 n, ?! P
6 `  D- u  X+ p3 L& x1 w( v1 T9 c, D我个人理解,每次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属性。% _# E/ P4 }+ J0 H
typedef
2 N( ~+ _" K1 e8 _2 DEFI_STATUS: m) K+ S- P1 V% d7 i9 S9 _5 X6 e
CreateEvent (
# j9 ^+ V; c' C/ e% |3 S9 D1 w8 JIN UINT32 Type,6 ^3 s% _  I! m; a4 Z" R  C. m
IN EFI_TPL NotifyTpl,
5 }8 @% Y* l: d: K$ MIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL- O, O' W9 C! u$ \4 M: \$ j
IN VOID *NotifyContext, OPTIONAL$ m; R& z8 Y' W' ?5 G; R8 T
OUT EFI_EVENT *Event' a# P; j  u3 f7 Z" {1 s
);
% }; x0 \* Z9 n5 L: G5 m2 q中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
9 T4 m2 U3 Z9 ?" o# R使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?8 v& y4 C/ }# b) \8 X2 Y, e  Y8 |
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。  u7 Y1 V3 k; h2 {  t, }
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
/ T3 l0 T/ e, p2 J我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
! y2 z8 |, m9 d5 W$ g1 B  [如果是Binding Protocol的Driver,在自己的Driver里面
. Q- I& T5 D0 U# q* G9 |; O' D0 l用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)& M& m: X; |1 i1 x0 p. F2 y+ O4 T
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
* e- V0 Y% Y( L! K, M; X/ H在Event的NotifyFunction里面9 p+ u: M; M& I) X3 K% W
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
; t- \$ i. c/ w2 u! F5 w这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!7 I# D# D1 r8 p" k! M9 C: P6 _
可以Hook到所有后面的driver!!!
- f8 t! q4 f% z5 T8 ]. v
' y  F6 i% ?/ w, G) a# I; U$ D$ M; u, m回复 13#的帖子
1 j5 R: t4 y0 s0 L' |在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
$ @+ O! H6 T, v; U$ d$ [% O9 y: g* G0 S; E# {8 |
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加& q4 p  p1 v2 U4 L7 I+ v* ?
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c3 X6 C, W3 m' W2 S
CoreLoadImage()-->CoreLoadImageCommon():
7 m, w( T. `# Q9 ~+ e1 R  //
/ |- ]) ]) t8 V8 h$ H0 H* k  //Reinstall loaded image protocol to fire any notifications( o1 m$ ?3 H  y* m
  //& J8 N# W( B& p- ?" U$ i7 n
  Status = CoreReinstallProtocolInterface (2 l' }8 P/ w+ \# f3 z( s# N
             Image->Handle,1 |+ t; Y2 g3 v4 f& G$ `, Z0 Z. h0 ^
             &gEfiLoadedImageProtocolGuid,( O" E. B" m2 Q  }
             &Image->Info,
3 r2 E  N# P5 h) ]0 w             &Image->Info/ i" R1 P: i3 L7 W& M
             );& X% k+ g9 r4 }, Q3 k
( c& G2 J. ^2 e
File:Notify.c
% z8 m& o) X9 \- N7 _( T$ nCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent(): o: Z) b) o4 G; r# K
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
% @/ g* A! i! x2 V1 C" v, q) s) WFile: Image.c
' W, q# ^% N2 g! m% O) wCoreLoadImage()-->CoreLoadImageCommon():
1 J  s) }/ r: h! D( S  //
& o% B3 H  E1 i$ u% B  //Reinstall loaded image protocol to fire any notifications
: e- W( f2 R7 O  //
, Y2 f9 W6 r4 G8 f8 S, b; k  Status = CoreReinstallProtocolInterface (, e5 Q; N4 A- `! z9 a
             Image->Handle,
2 j  O! t2 Z9 d; z6 o3 ~* F% [3 X* B  ...
! Z6 C7 j3 o4 X& e) `( K
' c9 {# S$ a% ]/ g7 W  i" C$ e
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
0 q' F) ^4 m, m. F; I# [2 JCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?0 l4 H: J$ ~* j

  d+ `; a( h1 \7 N) o! X; g[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?7 y/ k7 {& ~. k7 \/ h' x
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-5 17:34 , Processed in 0.065789 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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