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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,4 `0 Q& \1 O( M8 N( L/ [) c. |
一直都不怎么理解为什么要做出Event这样的一个机制?
" I% P6 h3 k7 L! e
7 ]* Y! _/ E/ E5 L( G9 [4 dTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
4 [+ Z3 [5 S2 h1 n2 p- }6 o4 PWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
7 ?+ l' ]% T! Y6 Y( B! t4 |还有Group类型的Event,用于处理具有相同类型的事件
+ U1 C; a/ J1 f  t7 G' R# K一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
% \# m& v! r4 Y+ L这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,2 f, y: w% x" z1 X
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
' o9 U- l: N" `9 X- a因为我看到有很多地方有RestoreTPL,很频繁地," j" P( z7 K; i
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?6 [' ^+ n8 W9 D1 M; ?+ C( ?
# a9 u; K0 Q; a
TPL的控制,
$ m$ d' ?% E( X% k6 m8 |我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
: g5 x( c4 k. O% Y1 u不想被一般的事件打断时就会RaiseTPL来处理,
9 E1 H/ Q8 _% a7 C7 Q  O( X6 k) t处理完,就会RestoreTPL了,
" D8 j) Y6 j+ n3 r& 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.
. l9 j% z& g1 o; j! a
* Z, c  Y; ~; O6 K; A我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
2 S/ K$ \# z4 c所以,就可以"认为":
1 Q+ n0 q, y: _0 a       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。+ g- H  z7 j: [  ?
0 _- _; J: A, ^3 M
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
2 ?  s( Y9 b$ Y, s5 ~) U( _% V( @( \' q4 T
我个人理解,每次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属性。- V; V" |: p& l1 q/ W
typedef
; }0 Y! a5 c( x- iEFI_STATUS' B: U$ v% @, i- S8 Z& G
CreateEvent (/ F! _5 Q0 e% D$ V2 a: P
IN UINT32 Type,
, u2 l+ Q# i0 h5 W* J! \IN EFI_TPL NotifyTpl,
5 }: u. \/ C$ B# N( _5 h" a% _. iIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
6 W' `; ]8 I4 oIN VOID *NotifyContext, OPTIONAL/ f/ Y. k2 D0 ?5 R* i
OUT EFI_EVENT *Event. c$ t+ u9 Y# D+ Y' _( [) H& Y  ~. U
);
1 M5 N& e& S/ l! R0 D! A& I中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
- K: P0 p$ E* b% Z使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
- C& r$ {. ^/ B/ o谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:& `9 s* Y$ L, H/ U" ?0 w7 n
如果是Binding Protocol的Driver,在自己的Driver里面0 u4 S6 o; ^( Q# @- \7 Z& E4 s
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
4 W3 `9 F3 |5 A$ Y记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,7 E6 L# u0 R7 g+ @" e+ b% ?
在Event的NotifyFunction里面
  }8 Q% D$ N. O3 J) U还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
# p. \6 G% w" O) M9 @# N$ C这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
6 V- }8 m1 [- e( N6 A4 ?可以Hook到所有后面的driver!!!
; u* q" `& V* W  {0 J5 O- H' ?5 I4 h9 Z7 n5 n5 i" F# c  s1 j% J0 ~
回复 13#的帖子0 f4 D. p$ u. u4 {9 h/ d( D
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~) Z; B* F/ p" @4 h; w5 B, ~1 i* U

8 o& }) a& Q. W8 g: O6 X$ C在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加3 k5 B+ C  b3 V( v0 d- z; Q8 a
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c5 \" Y; G/ Q1 {+ E# T, [$ [
CoreLoadImage()-->CoreLoadImageCommon():1 r& L0 A/ R# V1 q2 F4 u9 X
  //
1 |0 p7 R! x' r0 e2 G& Q6 w  //Reinstall loaded image protocol to fire any notifications
% a  ~3 E, Y* }3 a9 I  //5 A, B+ t3 N8 E; a4 V( M, t$ |) E7 L
  Status = CoreReinstallProtocolInterface (
3 _  o$ E) P8 M9 D/ s  j0 D! C7 o             Image->Handle,+ ~, `' T1 U7 ]" k7 Q+ ]* G" l
             &gEfiLoadedImageProtocolGuid,
6 i  s1 t! k* g2 m             &Image->Info,
- x( ?/ c/ p# ^8 E( [8 l             &Image->Info
9 d# Q* L- d2 U6 [, n             );& S8 Q8 Y( c( i/ m
5 A8 t# e5 G  p( B! o
File:Notify.c9 c; X; u! O; G4 i* `1 h& _
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent(). {7 ^' s* x7 E% x& C3 h" h
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 4 e9 |# Y! [  z) H' l8 ^
File: Image.c
* ]% j$ G- Z1 }" p% @9 I% V2 lCoreLoadImage()-->CoreLoadImageCommon():/ @, a. N6 Y& v' A" A  T( V
  //  U0 J* K8 B# W$ F4 m- K4 q% f
  //Reinstall loaded image protocol to fire any notifications  n- [3 J  W* `9 c! v' j
  //  u* M5 }6 m( d1 P
  Status = CoreReinstallProtocolInterface (! ^; S* w4 P9 M
             Image->Handle,! P1 ]3 Y/ h5 F& h0 x9 L: c0 z) `
  ...

! ?8 ^1 b7 i' M1 |. ?   @/ u2 @2 A1 y" y
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:& x; s0 d9 P' N2 n( M* L# h1 B
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?0 {# S! ]& s; K5 Y6 ], O# U

1 l8 L4 H& b2 ?, s" f[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
4 x0 q3 U& A' u) e0 d( v谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-18 22:42 , Processed in 0.070114 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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