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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,4 J7 |1 O; H! O6 z
一直都不怎么理解为什么要做出Event这样的一个机制?
6 ?* l7 J: A! G/ V" v4 c/ @: w  S8 A  b4 F* A6 j4 {
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)( z9 Y8 W' e8 L) t/ A7 n
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
7 s: U$ f, ]' c, ^/ N1 l9 Z/ p) J还有Group类型的Event,用于处理具有相同类型的事件
$ s; z8 ]: b2 }! a! D# P* f一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)" U! V+ L; j3 V  P
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,1 H$ J9 t: s$ i& f6 i! F' O
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.1 B6 o$ k+ b  _# o
因为我看到有很多地方有RestoreTPL,很频繁地,
: k# L9 |) q2 I6 k所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
( q2 `, B0 v) b5 F; |: D* M5 d+ z2 i- V9 D" y
TPL的控制,
+ ~7 L7 f1 ^4 J9 A9 t我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
( \/ t, c# ~" o2 y4 ~5 I不想被一般的事件打断时就会RaiseTPL来处理,
4 U* d  u8 s, v/ p  c处理完,就会RestoreTPL了,
( m, B; V3 \, F: I- Q当然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.
, a* Y4 z: }( R* M- X% t+ [, |! R  U- T1 L, Z, Y, I
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)( ]9 h" t1 h2 S4 t& K) k  i) p, x9 j
所以,就可以"认为":
' L" c8 e8 H9 o/ }3 w0 i       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。' o4 U8 X, l' t6 S/ l* P
- B5 |  s: E. h  @3 T* d9 u% l, v
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
1 @6 B- ?9 `, w  u6 X  _- v& ?9 _7 g( P# O6 w; B
我个人理解,每次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属性。# B# T; L$ T9 M: I& V
typedef
, S8 ]8 b- r9 g2 QEFI_STATUS+ H* `/ n/ Z) K8 B
CreateEvent (- @, f9 t- z2 f9 U* l
IN UINT32 Type,5 \$ T; _9 D- @  J" O+ ^) v& o' l0 x
IN EFI_TPL NotifyTpl,
6 T# Y- m! P& I! FIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
- N. ~& b" G/ f# ^: m, N! x% |IN VOID *NotifyContext, OPTIONAL0 @  S; y7 B+ U3 y2 K
OUT EFI_EVENT *Event
- {& r" ]- T. J' |+ ?, j  |, B6 R) ?);, d( j$ c; u  e. Z
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
4 c4 o$ f2 f. m0 s. u使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?' K9 j+ |" [4 V6 d: M
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
. I/ ^, {' S  u! `1 l% ^5 u  \) sNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。) k) v# a4 c! r( ^" |" X& t3 E
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:1 h8 y. s2 H, F, x: k* \" G. Z5 n
如果是Binding Protocol的Driver,在自己的Driver里面4 s! f& f' g+ H' }7 M, }( l7 z2 A
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)) _3 J! Y3 |0 }$ E+ h  p" W
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
3 H- k  `* I/ h% D0 b在Event的NotifyFunction里面% W: T/ }" P* ]0 i& S: D
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
; y! m# |9 J- p2 \这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
/ t8 C2 S  B' V! R可以Hook到所有后面的driver!!! 8 R# _/ N  G  g6 Z

$ E3 r/ i) i8 y) w4 [回复 13#的帖子
1 g' r  C# W/ Z% ?0 i在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~* d# a* B5 a8 q3 X' S
* A+ ~/ L5 O# X0 e$ e6 ]
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
: A3 Z+ q, T& M% L8 @) c  s* xxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
* V0 e8 p7 B. _' i: {0 x5 gCoreLoadImage()-->CoreLoadImageCommon():
* M' I) u  Z3 R  r7 ^  //
2 }; C! E8 n4 ?. D7 N. i  //Reinstall loaded image protocol to fire any notifications+ c1 S- @4 f! i0 Z: x: E
  //4 m3 z- y2 m7 @. m/ x
  Status = CoreReinstallProtocolInterface (; j" N1 u) U; W# c! {
             Image->Handle,2 z* @2 w5 B# a$ t! p3 u$ D! H
             &gEfiLoadedImageProtocolGuid,4 W2 X% S7 \! z. O* G1 t+ f
             &Image->Info,
; t$ B" ]5 ?) d! e+ ]5 K             &Image->Info! i- B7 D+ i( Y4 E2 G& u
             );
, s! Z) s% c. L  Q( [
! y9 z. G" S! g) ~3 a# c: gFile:Notify.c$ Y+ f: q5 O  V# G
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()# [2 k- R0 D; ~9 s
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
! |! N" x8 a) O" lFile: Image.c
  C3 j+ t3 m  m( X# Z2 O; ACoreLoadImage()-->CoreLoadImageCommon():! L5 V' I8 F0 T" ]2 X7 C# J: b
  //. t' G7 ^2 J4 N- W4 R* Z, I8 T
  //Reinstall loaded image protocol to fire any notifications
) s' v$ _8 y6 e" C  //
2 Q* E, G( j; q  _4 B3 N  Status = CoreReinstallProtocolInterface ($ Z! D1 c1 H0 L; w
             Image->Handle,0 b; B% Z* G+ [0 x- i) A
  ...

" R/ K) W7 b: a: l! D
1 K) l8 F, p' ]+ e1 _感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
# l, X7 }, r; c3 _$ H3 |CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?& x+ h' G, O- ^% H4 u8 j

+ [% g* F- L0 C8 N: v7 G[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-19 00:34 , Processed in 0.312047 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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