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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,- ?8 T" A" r& X7 l
一直都不怎么理解为什么要做出Event这样的一个机制?- E( G6 Z, n7 r# q( \
4 D4 s* k# V$ o7 a; [3 g' a
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
0 E" O+ }; e6 K# i+ eWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;& O- @1 g% J, _4 H. S
还有Group类型的Event,用于处理具有相同类型的事件$ X1 F0 z) i4 [, V+ C: r
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
9 |* O+ c- d% b这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
2 _( K+ C& s% [4 y- {  ^# 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.; [% ?) {8 H, o$ m
因为我看到有很多地方有RestoreTPL,很频繁地,& x4 A) y) y% c  G
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
4 J  q9 r( K+ ~8 n( a5 Y. c0 f: ^/ P+ x1 X
TPL的控制,
- S- j$ {! N3 {& i# p- I" m; N我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
. M% W, j, h* o6 F$ i0 N9 N不想被一般的事件打断时就会RaiseTPL来处理,
. ^2 s, a" E! Z& e3 I$ o, L处理完,就会RestoreTPL了," W% K/ ^- J  t% U7 p
当然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.# G1 W" y4 P5 S9 Z. x2 r

% R; k1 `# S: K6 G6 v" g我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)/ _- s5 T) R0 O% Y! U( \5 C6 f
所以,就可以"认为":
8 T  I! M- ]) M  T  o       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
& z- n, D" i0 P& `7 t
, }7 i% Q: X- K% s8 a1 n9 z8 K而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 * k7 v6 c" z9 H7 [8 T! u
  A" f2 V& s& W6 \9 p
我个人理解,每次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属性。2 m5 W- B6 J. B! W# p  F5 l
typedef% P7 y3 o1 d0 @$ ^
EFI_STATUS
+ K6 H2 Y& {3 iCreateEvent (1 l+ u' h2 X- B$ N& z9 M# ~
IN UINT32 Type,
3 h& i" z7 Z4 [. R6 kIN EFI_TPL NotifyTpl,& U' X( }- r& G) l' z
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL8 g+ m1 d; ^2 f8 t* K! c1 F
IN VOID *NotifyContext, OPTIONAL
5 d" b# [% y. }+ n, e) Y  L7 Y! wOUT EFI_EVENT *Event# x& S4 g$ ]! W( ^' v
);6 l0 D* I, }, _6 n
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。3 f$ I6 D0 z1 k. M) t* c
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?% ~$ a6 P& [0 Q; y
谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
  V1 v" M. K# {5 ?* E+ {- l如果是Binding Protocol的Driver,在自己的Driver里面
3 d+ `1 c2 ~* G: f* M用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
/ p, l8 I, }0 S记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,- _' N7 t) L& {# F
在Event的NotifyFunction里面
# B* ]5 d# r# h% J# R% q还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
: ^: N5 x% G% G1 |2 C这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!. a5 z5 n' s- E. o
可以Hook到所有后面的driver!!! 2 \# D0 f; G; j$ b7 k( d* l
% X4 J% w! V. [
回复 13#的帖子/ B4 J; K+ Z0 |* s, h: Z$ k2 V( _
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~% {3 c- N5 i0 p' W; F
  ?4 t5 ]1 W6 m" a6 ^* Z: s3 g/ e* y
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加$ E, T! Z& q9 D# `; u; K
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
& P6 w' U/ |) z/ O! nCoreLoadImage()-->CoreLoadImageCommon():
$ `1 A% x( `: x) i# h, g3 r  //
7 _6 x8 ~! _* M8 p( e  //Reinstall loaded image protocol to fire any notifications7 I$ b: }; k$ [& W
  //' c2 P7 l9 Q9 A5 y5 o% ?
  Status = CoreReinstallProtocolInterface (
9 \) f1 @4 Z& y% T; h             Image->Handle,
6 v2 m/ \+ \" ]$ m/ J             &gEfiLoadedImageProtocolGuid,
! N: g0 r! `* e3 h' H  t2 ?3 y             &Image->Info,
( w/ y' d9 m3 C( T, `$ M             &Image->Info$ G3 e' O- A" y% G- a5 M
             );9 X/ O* Q" ]; A+ M' z' f
" ^6 i) f$ h7 x( m, D+ u' S) C( i
File:Notify.c
8 l# l" q: l- h, G  F2 W8 ~CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent(). T0 {' _0 g( D* W
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 : w8 G, c( z- b
File: Image.c$ D, D5 k8 o! H/ P; z( Z
CoreLoadImage()-->CoreLoadImageCommon():
$ Y! U! i- [% `( Y, t  //
; z2 K% ~6 y6 G4 j( i  //Reinstall loaded image protocol to fire any notifications* E) i, A. Q" ]7 c+ O/ v
  //
3 l1 @9 X) R% H+ X: s; ?- o  Status = CoreReinstallProtocolInterface (  x/ `, P# D# u$ Z
             Image->Handle,
6 X* Y: e- L/ g; v  ...
0 _- H! n- a  n+ _+ f  l+ k7 Q
9 B$ d  J$ N( o
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
3 f" _: p  ~, j/ j! ^CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?8 V5 K. d) t: t, |. T  I
; ^- y" U2 D: Q* j- C
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?( t9 L& P' Z8 P. o( c
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 10:09 , Processed in 0.040265 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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