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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,. V# p5 r4 g, b: y& H+ n- q! Y
一直都不怎么理解为什么要做出Event这样的一个机制?! O& y8 {5 |/ ?3 c' ]; M, L5 p& m

* |9 I1 @# ^! k- f" |Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
  D0 H1 t: u- x6 E1 r, \4 E) ~  YWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
) l; ]1 W1 t/ r- e7 r& j5 G还有Group类型的Event,用于处理具有相同类型的事件
, R) c4 M4 C' T一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)1 ?- [- I1 }$ F' n- S5 q9 _1 d
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
- v+ ]5 Q4 g! }! E1 J不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
4 F* Q7 @- s/ R2 e. A3 H% P因为我看到有很多地方有RestoreTPL,很频繁地,1 d7 G8 w5 Q; f3 v4 y6 G4 _4 j! |
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
: a+ q% g- ]7 y  j, `3 t7 J: z  {) }& F- T% m! s$ J' L
TPL的控制,
) g5 t1 O0 o* p3 i& R- L' V我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)* W! @, Z8 {7 q  z- Z  R
不想被一般的事件打断时就会RaiseTPL来处理,! l+ P5 _+ z) ?  @0 N
处理完,就会RestoreTPL了,
$ I$ [: a/ W3 `. S6 @0 J; e8 g当然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.
  J/ v- f  T/ N0 \9 \. L8 y, k
5 |& C, H* K, [" I( b我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
  D2 f1 {5 Z+ F* d! ^7 y所以,就可以"认为":: Z1 i- n4 u( g* X) s6 s
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。4 G! ]: B* r+ ~2 j; v" |
4 O; m& E. D5 s5 j: Q9 U) R3 W
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 " g- j+ D% }0 B, x% o9 f7 b

* Q- p$ w0 P; F2 ?/ V0 w; V' H我个人理解,每次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 S0 `6 @; h, ?' O6 Z
typedef" e* a1 v  u1 R2 x+ |7 z7 J2 Z5 y
EFI_STATUS5 v/ l4 ]4 X" M% y
CreateEvent (( N" P$ a9 a$ B& I8 o
IN UINT32 Type,
3 V8 A+ ]* f; }, m2 Z7 [) X2 ]IN EFI_TPL NotifyTpl,
- }1 H/ `& T2 O+ y, j  K) MIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL: K8 Q  J9 _7 G4 j$ G% c
IN VOID *NotifyContext, OPTIONAL
! B8 Z5 p; L# R" POUT EFI_EVENT *Event! {2 g& h8 D* g5 E+ t# r2 J* E
);
- H, x) D! |+ p+ @; P9 b7 G7 I中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
$ U" }9 [' {0 V; Z. I. L使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?6 Y5 O, E% t7 E7 A5 h- o; Y
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。% P; c5 c( O! N( R
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
; L5 i' G5 b7 a2 ~+ K/ @. B4 B+ V- l我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:% o9 z2 o. u9 x: A: V
如果是Binding Protocol的Driver,在自己的Driver里面
7 i6 a& ], g: D8 I) X: a/ f用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)7 U- Q2 y  l2 j$ `$ ^$ [4 @
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,8 K% }. m* T. C( X. G: V% N$ p
在Event的NotifyFunction里面
6 A  l7 i+ u6 p还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles# v. A# S1 n3 Q  ], ]
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
( Q7 f+ {$ U' ^& X可以Hook到所有后面的driver!!!
1 N: b" w, ^' n2 O( r2 ?8 q/ ^3 B! g8 A1 Y3 N
回复 13#的帖子
- W( X) g* ], [1 [+ v9 U/ X) r: q. o3 N在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
; s8 b% G2 U5 R; ?3 N  ~
# Z; v6 {$ H% c! m6 F在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加7 n8 o. F* |+ p
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c) ~; Z: s* E; r, I0 y6 ^# y' F
CoreLoadImage()-->CoreLoadImageCommon():& s2 g, @  L( W1 x& k
  //
  m+ v  q$ e- |1 e2 K  //Reinstall loaded image protocol to fire any notifications
- q5 e2 o# s2 I# y1 {  //0 [9 M$ G' W9 z# D9 O' Z
  Status = CoreReinstallProtocolInterface (3 Z. ^+ L4 ^. V* G1 {* [
             Image->Handle,# L, @8 t, V! N" o+ z  |1 A
             &gEfiLoadedImageProtocolGuid,
! Y  o. G0 j- Q' M             &Image->Info,
' j) ]1 s& [1 Z3 y3 @             &Image->Info* i; l. _, S7 O0 _' O# v' ]
             );: ~3 y4 }$ Q# m1 K& e; c

! A6 g- H; Z6 N6 i7 N% N3 WFile:Notify.c
6 E5 t  u( b3 e: B: W: eCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
, M1 n7 G  X8 \0 V9 d( ECoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表   u. U$ L8 g: ^' X+ l" y
File: Image.c
2 O4 n1 p$ i$ I& ECoreLoadImage()-->CoreLoadImageCommon():
# h7 I8 x) _7 v( F  //! B& o& Y! a4 T, n, A
  //Reinstall loaded image protocol to fire any notifications
3 m  L! m1 h; R( l) n/ ~  //" V& q# R( C' m! D8 \* I  Y
  Status = CoreReinstallProtocolInterface (
0 \# ~7 k# X+ k  u- O             Image->Handle,
$ L- M" t; [! t  ...

8 G& P. l, g. I8 e' } 4 h8 X; q6 G$ Q. S* {$ e2 p: b" r
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:& P$ t# j8 J, x
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?. o+ n: ?' ~8 m, z! P
5 \& M  V4 _! ~) j4 @& X  D1 h5 z
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
: v- G0 f; }2 f谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-12 06:27 , Processed in 0.047379 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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