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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,% }" B! G& m  ?, \) Q: O; V
一直都不怎么理解为什么要做出Event这样的一个机制?
4 @$ j. r3 i! i& u' H/ Y
. v4 x4 m9 h+ p1 N3 I% JTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
. Z$ F/ b/ o8 ]1 C6 A( V; `Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;) u. v" d! `1 B( B% y4 a
还有Group类型的Event,用于处理具有相同类型的事件
8 c. Z; N( V6 e* w) N; {一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
& C+ |7 v, Q1 H# c这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
2 o4 j2 ^( c% [$ U1 v不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.3 l9 x% G- h7 I
因为我看到有很多地方有RestoreTPL,很频繁地,
: r8 S2 g6 Q  K8 W所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?  i. Y% u3 G6 ~, Q+ G

) h6 p9 Q1 {/ K( R& G+ n, V) BTPL的控制,
  B  w: U7 v! c/ `2 P" B1 E我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)8 V+ n% Y9 T+ ]. K
不想被一般的事件打断时就会RaiseTPL来处理,0 b; U: s* K' m$ ^5 T3 `
处理完,就会RestoreTPL了,
0 `  f- j7 j3 m1 h- C0 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.
* B. k0 J( |+ P2 |8 H7 V+ J3 y- M$ A5 V
' {5 r# Z5 s& e$ R4 N: v我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
7 [8 q( ]4 P) A! D' G- _所以,就可以"认为":$ D8 T( U' b% c$ O7 M; W
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
/ a3 T0 a" X7 T+ e4 t# r# O
: e/ [: T0 i9 w" Y6 H而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 : ~" T. K. e" i" ]

: F; B& D8 p; x8 j我个人理解,每次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属性。7 x5 \3 j6 B- u9 B
typedef# v( T+ d' H! C8 P! R7 v, [4 N& d) T1 ~+ C
EFI_STATUS8 V1 F" y* C% z; C0 k
CreateEvent (
' ]- ~: b: Z& |+ p/ _3 EIN UINT32 Type,4 e: j- a1 _) |, e" f
IN EFI_TPL NotifyTpl,& j" h+ F4 z" T# J- o1 D4 \
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL$ O- g" e+ w8 J
IN VOID *NotifyContext, OPTIONAL# V7 U" |. U/ D  t+ q" q2 V6 T6 _9 ~
OUT EFI_EVENT *Event6 g3 h9 D1 f9 O' a: M4 j: Z
);7 r0 ?. t1 N7 R2 j
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
: c% F* [  k: d使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
$ L% H7 X( {9 W, u& @7 o: l' m' n; r谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。0 |8 H5 H+ M+ t) y* O
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
& a) F# G8 r4 D% `3 h- |8 X我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
5 y/ L* ~* Q, z  S如果是Binding Protocol的Driver,在自己的Driver里面! ?1 }  H( i: j! m5 R
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
0 W* N3 k! J/ ^: d6 `' _记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,0 y/ B8 T, c; m# W! {4 ?
在Event的NotifyFunction里面
8 S# n9 t  j) H; T还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
9 @. T) W" z( Z# b6 T这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!/ B: _9 F8 b3 p7 J# P- @6 ?
可以Hook到所有后面的driver!!! ( y. x' x, r9 [1 t/ c( k' G

$ h; [- h* e7 b5 v( W9 Y  O* F回复 13#的帖子
/ z+ f" k3 h) H! c' o9 O5 u+ n/ @在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
! @( ]9 t# j2 C7 z
2 T- l+ C7 r" Q0 e在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
5 D8 g$ U' e* x. O: R  qxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c3 j- i, x! C7 @, o4 M: b
CoreLoadImage()-->CoreLoadImageCommon():
+ p: |& L0 b+ |* W: l  //
' y% P) r1 t* H% \) O% o4 m6 k  //Reinstall loaded image protocol to fire any notifications
: i1 v/ U& \1 d, Z7 X5 j  //
1 x  j# e( |8 }- _' j$ N+ M2 g  P  Status = CoreReinstallProtocolInterface (
' k0 l$ A, b5 P( h             Image->Handle,! q& b/ B, i0 z9 n
             &gEfiLoadedImageProtocolGuid,
  |2 Y7 h1 H/ C; r; c             &Image->Info,# W, I6 B* I, r$ u2 L" `
             &Image->Info
) p' j' c7 N( \0 ^             );
' }8 I% S! S* ]
# ~" Z" n. g+ m. tFile:Notify.c* r  h! J3 l  x' Y3 B
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()' c# Y5 {$ P, }, x3 [
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 ' J! z% l8 d* l2 u
File: Image.c" s% g& M5 z" A2 M5 f' m
CoreLoadImage()-->CoreLoadImageCommon():- W0 H, Z6 p8 {( S( |1 r
  //
2 Z3 o/ l1 ~( k  //Reinstall loaded image protocol to fire any notifications
# M4 E( _% n! u9 V' ?  @  //9 s8 d0 d+ R/ ^+ P
  Status = CoreReinstallProtocolInterface (
; H  E& v& h+ f3 ?/ }             Image->Handle,
6 [1 s4 L% u7 N- l  ...
3 m" E8 ]+ F( k
: \* f7 S. Q- g
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
2 Q/ \2 s9 f* J, k( ?5 JCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?6 A5 w) N1 L7 b" `+ x/ F& B) w
: q! [4 j, H/ }+ @
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?* N- c9 l( O0 X3 i
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-5-16 07:36 , Processed in 0.041041 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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