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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,, j) w" D# Q7 c- {- J1 U/ b
一直都不怎么理解为什么要做出Event这样的一个机制?5 Y; `3 h( d  Y0 O8 M( o

* @! K6 Y& A( t6 R; c. pTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
7 x4 ]. ~& ^/ @2 i1 b9 g" Z; ZWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;" g) Z1 D3 m/ s+ O( c
还有Group类型的Event,用于处理具有相同类型的事件
5 U* i9 N9 F/ {+ l; a  a/ ~一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
; U9 m( H  q' c7 t7 s# w% W这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,- K' h/ _: _: h4 P# w% f
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
9 ~; z& G" I' J因为我看到有很多地方有RestoreTPL,很频繁地,
5 ?+ `" W( A3 m! R& k- R, I' X$ c所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
6 B& J; s' T* f/ T2 F/ `3 `9 ]
3 ]. E+ B) ~' \, X& e% M) t" Z5 U& O& eTPL的控制,
+ l9 @) o+ a; S  W# w. T, |我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)* c, Q+ k  h! Z8 ~0 v+ t3 Z( y6 Y- V
不想被一般的事件打断时就会RaiseTPL来处理,- w) l/ o9 s% A2 e. I$ h! l" @
处理完,就会RestoreTPL了,3 ]8 O& U9 R6 \; ]% 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.
1 P1 |( s6 Y3 o# T6 }6 i. K9 ]  H1 r- J% t6 d
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)5 |1 y8 w4 h9 {7 X; ~3 X% m
所以,就可以"认为":8 ^9 [- S) j/ [6 \- m
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
; f/ r. z$ Z3 q9 b% [- O
  Q' B# o  z5 O" h6 }0 @而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 , @* W7 L+ Q( N0 `* e& m

1 P: f/ C, y, ?; v' l我个人理解,每次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属性。
6 l& x0 i+ r$ @, X8 b# d( @typedef
$ b& H0 a6 n: U! B; pEFI_STATUS
8 K+ M, R$ r7 G% K. kCreateEvent (. a' _+ M2 o. ~  J) @
IN UINT32 Type,6 I$ {! M: O$ v4 a& ^3 T- K* }
IN EFI_TPL NotifyTpl,
3 e! C' b$ Z# }. N; r6 S3 ^* D1 @6 ^6 mIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL2 ^& R* f1 O7 N5 \" k& b
IN VOID *NotifyContext, OPTIONAL
; f( x- u/ k# _4 p* k" ^, POUT EFI_EVENT *Event
5 g( ]9 f- z1 b% F);
4 u$ q* r, G# U3 H6 K, G! ]& t: y中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
# J: o, @( D3 [* f: g% i/ U" e1 [# U使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
% q* Z4 g" {" h2 g# r7 W8 y4 l: L谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。2 J& X1 m! z: f8 h
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。+ g" \+ w9 N' P0 X- i. x6 @7 |" `
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:& A' C) z4 E" e1 j
如果是Binding Protocol的Driver,在自己的Driver里面/ Z6 a" e; M8 z/ f
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
9 H# h" N$ C& j- u* b3 a6 M记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
; b" h# Y) w) m在Event的NotifyFunction里面
- N0 _3 i) M7 H( }" h  R* y, D* z还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles7 q& ?7 W- G( z- L+ q" N
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!6 P. Y, ]' F- M) C: Z) ]
可以Hook到所有后面的driver!!!
1 y# Z: v5 T3 @! [9 |5 }2 z; I) J; j5 Y* e# t8 x9 ?2 o
回复 13#的帖子5 ?! e; H2 {# ~: N
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
( T, f( p3 r- ^/ b: ~% y$ z  |0 @* v/ `2 m: w& ~
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
/ H' l, N& q, t( Y5 Y* O+ ?  yxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
: u. k- U% A0 c3 H* X5 n( {CoreLoadImage()-->CoreLoadImageCommon():$ ~  F) Z1 j# s5 ?% R1 K
  //5 h8 }& u% g. z* Q
  //Reinstall loaded image protocol to fire any notifications5 F, p$ ^$ T/ s( H  a# M
  //# Y- V$ |8 `+ e; W* _6 ?
  Status = CoreReinstallProtocolInterface (: t5 t9 _& V0 b7 ~" c/ s/ g- g
             Image->Handle,
2 E6 \! P# }* w8 W; n9 }             &gEfiLoadedImageProtocolGuid,  ^2 q- H" T! ?+ n) k
             &Image->Info,
" S: X0 `1 A; S+ ~             &Image->Info! s  p% t6 M6 b$ J1 }
             );
5 S7 ?; |. }6 q4 q9 _# U% Z: F. F
2 M; ~( Y: J* P3 ?. vFile:Notify.c
& B, O( Q( [6 |& ECoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
3 }# j: _! O2 [, v1 S, D( VCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 % |: Z3 z1 }" O- A% N9 n
File: Image.c" u8 L! t8 z: o- G  ^' j
CoreLoadImage()-->CoreLoadImageCommon():
( L- J5 U; K. }, c) G0 a+ o  //% [1 m/ x  Q1 ]: y
  //Reinstall loaded image protocol to fire any notifications8 m5 Q; m/ [& `$ H3 |
  //
9 Q. u' A. A! H; ], T  Status = CoreReinstallProtocolInterface (& ~, o: i1 q6 d  M, i4 u+ a
             Image->Handle,
) s" x( @- y* ^: U' d0 D5 _: \  ...

- Z4 t  I6 s4 ^% y' S7 b3 q
9 }/ P7 U$ J1 k+ N  L, o! c' V感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:8 O  J5 p5 ~9 _  ~# C9 Y# S" n
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?8 B& d( v9 M1 y# Z3 }  N
$ ~' D7 Q$ ~% B/ c* J$ ^. S5 D4 i
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
  C# [. Z* l. n( J谢谢!
回复

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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