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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
$ d  s$ e; a( ]$ y2 X一直都不怎么理解为什么要做出Event这样的一个机制?
  f3 ~" H) m/ }( S! v$ d9 u+ a& h5 [1 g0 i5 M' E+ J
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)$ m! M/ C' b& w# a! r
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
8 b" I8 H6 ?) I; U6 C6 j' t/ L0 R7 Y还有Group类型的Event,用于处理具有相同类型的事件
$ q9 C5 l, e6 {" j一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
$ x  P9 G! [% O6 Q这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
, [0 L2 f% V7 @* z( ]不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
! t! @0 C0 ?9 y因为我看到有很多地方有RestoreTPL,很频繁地,  _! f  L  |. u0 U+ L% }
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?4 S+ N& N" o! h/ H6 K& s

  h$ T$ {$ g: G9 R; H& I" Z- H3 PTPL的控制,1 x# k2 e" }. j! g) J8 U8 Q
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等): }+ w8 n% t3 n$ D% v# Y
不想被一般的事件打断时就会RaiseTPL来处理,
' G4 ]0 m5 n8 {' M9 x5 B处理完,就会RestoreTPL了,
. [& m8 Y' {7 {. W& n& U当然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.
( @9 t/ z8 q& I* Z# b0 W
$ d: S% z6 p. E" [: U1 Y2 \$ ^. b我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6); r. X! g. X. V# @0 G, e% ~; F7 D: z& `
所以,就可以"认为":2 L4 P& p3 W' H- c5 ^
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。8 n# s; o4 R! X
! l# \# F: H( ?
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
1 D- d1 q7 z- J4 w8 _/ F! b4 n0 J& T8 G
我个人理解,每次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属性。9 p- h3 G" F# v& D
typedef
/ ~2 e, B: Z5 tEFI_STATUS
0 [* d/ p0 G3 r* ~- D% u% KCreateEvent (# b8 s" L- L  |. ]
IN UINT32 Type,- K  t/ r2 v: D4 N( b' L4 i1 P; b
IN EFI_TPL NotifyTpl,
" ~2 n/ e1 D3 |  M; D/ u1 lIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
' i. Y( ^8 w# \% S3 I' m, aIN VOID *NotifyContext, OPTIONAL3 D4 H" {- @- s$ m, ^' D" H
OUT EFI_EVENT *Event
5 V$ f- E6 Y8 h1 D);
* X9 B4 ^( b  O& u8 N/ k中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。" Z, ^5 T& E0 R
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?5 M9 Z$ D$ A* I. ]& {0 y- U
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。- E- f5 A1 ~$ N/ ^
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
6 g; B+ P* l7 b: y5 k我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
4 U2 J* M* e2 H* ~* D" M9 p/ P' ^如果是Binding Protocol的Driver,在自己的Driver里面
* }* X4 x! k9 y0 g' ]用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
+ l' Z7 m1 l8 V记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,% j$ s" Y( p1 v( M
在Event的NotifyFunction里面
3 {7 c9 _  Q  h: y还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles0 J* C) U5 U* v) H
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
( p: @+ s- i! X可以Hook到所有后面的driver!!!
. W. S" X8 X. C- p0 F0 @
4 M4 e8 Z" f/ D回复 13#的帖子
1 B+ [$ q4 M/ i! ~' h7 V在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
+ b: q# e2 G3 {  b4 C/ y" f
; c# E9 q- D* ]; x6 \  j2 H) c- T. p1 q在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
" a( z: u! J1 jxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c: ]! ]8 ^' e6 {
CoreLoadImage()-->CoreLoadImageCommon():
* _8 z. a( L% k, Q  //
' a1 J( s  |, h6 P" I  //Reinstall loaded image protocol to fire any notifications
. _) U8 G& l- s  //
& r9 _: Q9 _2 z/ o$ z' E  Status = CoreReinstallProtocolInterface (' R% I" v7 z$ k0 G' Y, X- M
             Image->Handle,
( t  Q4 l% y4 @' O             &gEfiLoadedImageProtocolGuid,
0 c8 v- U$ {( D' F& n; k; [: ^* j             &Image->Info,) f) z: K$ i; l1 x. i
             &Image->Info, X  _! C% K+ M: r9 Z! o
             );6 C' U8 q" h) H

- X" c0 O: ~9 O' HFile:Notify.c  A; G1 t6 b" c
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
0 d# K8 U  y/ D3 `CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
) \& q6 t6 H) p# U3 dFile: Image.c$ T( B% f5 {: @  W5 V
CoreLoadImage()-->CoreLoadImageCommon():
1 n$ B$ \1 o0 [5 a& v  //
% l4 e5 B" ^, d4 v4 G3 j& T1 D1 n  //Reinstall loaded image protocol to fire any notifications2 L- `  Z4 C( u% e* f0 ?# M
  //  Z4 h# I1 `, U& a7 ]
  Status = CoreReinstallProtocolInterface (
" B4 B2 t5 P* _             Image->Handle,
5 a$ a6 O0 C3 w) n- Z9 e8 [  ...

  K/ N" ^. G/ e# W4 P2 O# Z
: C3 H. r) l  a0 X' G+ m感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:% z8 A) B8 F, R9 @
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
% a* C+ b" v" h2 @5 u3 `4 ^* ^+ ~# d% S& N- [! k+ A
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
3 j- l, P- F) Z谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-2 10:47 , Processed in 0.031493 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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