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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,; T- D. }! G( S! @! V/ O2 C
一直都不怎么理解为什么要做出Event这样的一个机制?
- W; ?) D. `! Q% @8 e
/ L. N) a1 g, e% _8 q, mTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)1 L2 L" m0 o" ]* `7 Z! r/ f
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;4 h- S" r/ w  J0 {, S1 D4 h
还有Group类型的Event,用于处理具有相同类型的事件* W* u( u6 ^9 S" w0 G' N! L8 f) S
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)' N2 i0 G) N5 P0 [. Q
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,/ ^' }7 J) o; a* [* E- L* B
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.6 @/ {# f2 D  u3 j8 t
因为我看到有很多地方有RestoreTPL,很频繁地,
1 f: d# Z( R  L0 ^7 ^% Q0 u" F8 ]所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
- p! |% s% r/ J0 |0 S9 t
# f  F. u- ~. @TPL的控制,
+ Y! k& ]6 C& H/ ]1 U2 _; [我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)* }6 \/ I$ Q7 w- c* R2 f
不想被一般的事件打断时就会RaiseTPL来处理,
, N  N$ I, X6 R处理完,就会RestoreTPL了,0 W& \( A9 G# ~8 F
当然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.
: w& b- z6 B9 l
* b) n' Y: i6 L, s$ P0 C我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)* ^& N1 [. F, \! b! h. v% L0 }+ e
所以,就可以"认为":
1 n; b- T$ A2 A+ _2 |, r. ^5 Q       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。' k4 Y7 o" u7 a" o, I2 |; W

6 i* B! Y* Y! C1 q1 {. F* v. ^而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 3 K" K+ u- s1 `

8 ?5 k6 c- X; Q, \# 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属性。  `" N: L: \+ Q5 |1 G/ _: q& R9 r
typedef
+ }& k( `! E; }EFI_STATUS
' W6 h: D% L, @/ z& @CreateEvent (
0 j1 U9 d3 Z9 a2 F# _IN UINT32 Type,
( [% t- t# r2 D# zIN EFI_TPL NotifyTpl,$ b+ b& U0 E/ Q# }
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
% ?1 F8 z. t1 p' i- `IN VOID *NotifyContext, OPTIONAL; v6 q! o, J" z( |  g% j$ i
OUT EFI_EVENT *Event
* t" r1 `! u8 R' I. d);
4 C. f# W0 M, T# }) o- S% W中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
) [; C6 I7 H: v) ?$ d使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
, H$ t$ D5 j5 a+ P; k9 E9 T' X谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。5 z& X! L: R9 [
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
9 B1 U( k: x4 d; K; V8 H1 S$ J我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:. n) I3 e% \+ s$ e
如果是Binding Protocol的Driver,在自己的Driver里面
& m+ C6 `3 v: w6 e用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)5 H- X- ~* w1 F8 \8 T* G& ~
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,( F' \0 I' {$ \& A3 I9 R- @2 n
在Event的NotifyFunction里面& s8 X5 j7 s/ A9 O  x
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
; h: \2 Y( @) x! }8 C* O这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
1 Y/ b! X: \  Z4 ?+ F; S1 ~" I6 A7 @可以Hook到所有后面的driver!!!
" [4 x# W7 {, M9 n$ E1 v
! I+ Y. q! N: {回复 13#的帖子
0 c5 e4 @! P1 A1 l8 f+ ?+ `5 q8 d( V在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~/ Q- o% L# S8 z3 p8 d

7 n  K$ L- n7 G: ]& J) T2 `在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
4 r1 b1 k! Z5 W. Q2 L" Sxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
6 d' ?' m" z8 p3 XCoreLoadImage()-->CoreLoadImageCommon():
6 f$ C/ z- Y: Y* m  r4 N" \% s  //- H4 M- I4 c$ x' L# u6 w
  //Reinstall loaded image protocol to fire any notifications7 O' {/ T2 q* d" ?
  /// C- ^; \1 X( d4 W5 O; W
  Status = CoreReinstallProtocolInterface (0 Z$ W% G4 L6 R2 z6 u, S# B7 O1 k7 P8 U
             Image->Handle,
3 R' W$ j  v7 O             &gEfiLoadedImageProtocolGuid,
2 B8 `( X: F% S# }) y             &Image->Info,
) ]( n+ Q8 r; {* j' i. G- l2 B             &Image->Info/ A/ Q6 y, D+ X5 P- B
             );
: T8 H+ y% c  |1 L3 B( [5 a+ v8 k% X9 C
File:Notify.c4 D$ \- h" d: R- Q4 T# Q! M
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()8 M& g: D/ a& W# W) B7 C( j
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 & p6 C8 T8 y: a) y
File: Image.c
; ~8 _3 M4 M* [. Z; ]  d3 C. FCoreLoadImage()-->CoreLoadImageCommon():; w* b& Q; f/ O$ _1 y
  //
* A- \0 U$ e- k* c( _& F, j# U* s  //Reinstall loaded image protocol to fire any notifications0 f+ h5 k8 _1 ^5 n& j4 c
  //+ b$ K* L3 F8 ?# w, s9 l: z
  Status = CoreReinstallProtocolInterface (
/ v: t( t7 ^! v" c: d5 s- [             Image->Handle,2 e8 _9 x$ V& u. }- S
  ...

0 z& O4 C6 G# w
4 J4 z" @  r$ r4 b感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:( M7 l4 x0 _7 o4 d; ^& p: j( m
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
5 `- h& H# d- I; o2 q" b
( Q( x, e' h: R0 h[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
& d% L/ f/ ~8 |/ L% r谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-24 01:25 , Processed in 0.038704 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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