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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,' H1 t: i* J) v  @1 h' f9 x6 C# R
一直都不怎么理解为什么要做出Event这样的一个机制?
( O, r7 @1 R, j2 g) P
# V( K( _4 C+ Y  K1 TTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)1 }7 |- ~7 {% V
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;6 y1 n2 d; @4 H$ g) {/ _# J
还有Group类型的Event,用于处理具有相同类型的事件2 d; E+ N5 y1 [( h- @& r
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)' |4 y! {7 L( M6 \+ e/ I
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,. r, u! X# y+ q: D2 p1 r* @
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
: Q) }( P; \8 D) |因为我看到有很多地方有RestoreTPL,很频繁地,
0 ]) V. l+ ]$ q) v所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?+ e3 K( g$ L( M6 o
& _  Z- K6 {& m  p! z: e4 u
TPL的控制,
  K# @( P2 o& y! G2 o2 g我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
' C* p* j/ I) Y1 t不想被一般的事件打断时就会RaiseTPL来处理,
" v, s! d; T/ w5 @$ W0 P处理完,就会RestoreTPL了,
2 U# F' o7 D" u, [. k5 o当然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.
2 D9 o) h/ b- ]' N* q! _( J# Q! e8 o
& p) I7 w- G8 u5 r+ ~) ~4 z我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)0 F  d& C1 r. U7 r; e
所以,就可以"认为":* U  }# U  T9 Q6 D, Z2 o
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。# b6 r3 k! {& Q4 ~% g# R' H0 c% G
3 _( \8 j) @2 U5 l' j% h
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 , v( m' Z# E- }4 z( T- y, F
/ J) f/ J# g! ]/ x) M7 O: e
我个人理解,每次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属性。
: T. k, A. h$ a3 K+ A4 @typedef: K8 b- |, d5 F4 P" U
EFI_STATUS; W$ v1 W4 J* F' O6 K$ _
CreateEvent (
/ O7 l' O* f, {' Z6 S2 [( i6 FIN UINT32 Type,
6 F. |/ ~# `4 X- s; T6 UIN EFI_TPL NotifyTpl,
/ [3 c+ t8 r( ]$ A6 eIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
0 m% ~. a. Y5 s  _+ c- X8 iIN VOID *NotifyContext, OPTIONAL  L6 Q6 w* Z9 b
OUT EFI_EVENT *Event, l/ _0 p2 F6 U2 _0 ~
);
. _. n" a7 k5 ~( t3 D0 A4 ~' n! g中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
- R6 Y% _  T- ~: }3 b$ z使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?- c4 U/ l  z7 R" c
谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:  D1 Y: ^5 K# W# X+ k) n& v( [5 f
如果是Binding Protocol的Driver,在自己的Driver里面3 G- J: \2 x: D% Y1 j& s+ t+ r2 X
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)4 y! M& p% x- p# }, l6 F6 r- d) q* Z
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event," G. F( n+ g  a: r" W
在Event的NotifyFunction里面/ g) l2 _" f! e6 |7 T. W" m5 t
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles; g7 \4 w! i: f8 o4 O) T
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!2 T* n- s' B1 H: @
可以Hook到所有后面的driver!!!
( h! ]- i3 M: |4 _# s4 x- L, u% c. G8 j5 `4 f
回复 13#的帖子% {' p, o% ]( c3 E7 R# S! _7 _6 k
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
* ?. H' A# M! F" K' W( A2 i7 u7 }$ L( o
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
. S* j% ]/ Z3 s2 |2 V' d8 axtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c9 U& k5 k3 b5 }
CoreLoadImage()-->CoreLoadImageCommon():
* S* r5 r( g. h/ C: u  //
% u. B: {* D# Z, M3 J- d  //Reinstall loaded image protocol to fire any notifications* A4 Q% b) ~/ F! w/ ]7 c
  //
! R; C/ T5 S* ~& K- ^' [, G7 z  Status = CoreReinstallProtocolInterface (
6 y) ?7 |. O& ~, c1 v9 `4 `5 w             Image->Handle,
7 S8 _' A: n* y" h: ~# ^# g             &gEfiLoadedImageProtocolGuid,
5 z) r; f4 E; P0 X5 K  D; u. O1 }             &Image->Info,6 h+ e- W* r" Y- ]% a
             &Image->Info, H) s" \2 X" i* A; k- m: I
             );
! m; P) k, v! V4 Z% \- R" Z- _$ B. m& P& F
File:Notify.c1 E! L& ~0 A9 z
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()# ^3 t8 h/ N7 u$ @, K
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 % e- E" q* w' i( {" L  L  w7 I
File: Image.c9 j/ W. f" v- j: D/ D& ^
CoreLoadImage()-->CoreLoadImageCommon():) l. K3 \5 W  h2 L8 M
  //- b7 I% o5 q' _, U
  //Reinstall loaded image protocol to fire any notifications. s+ o" t  ]5 L
  //) a2 A! o) k% _- Q0 @* X
  Status = CoreReinstallProtocolInterface (
. P7 E' o; U- n0 C) x$ G3 d9 P             Image->Handle,
. z; O' }; D/ f- x2 v  ...
( K$ w$ ]/ {8 G
8 L. @5 x6 _7 O. }/ k
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
/ L& C# g# o& _# ^CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?" I4 U/ w' [7 |8 F' G0 ~* o

& p& z6 k4 F9 e. X; {7 ?) C" K9 o[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?* N/ R+ ]( N7 u* K
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-25 03:41 , Processed in 0.042778 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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