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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,8 X# a9 }/ b- L2 E3 m
一直都不怎么理解为什么要做出Event这样的一个机制?
. Z. Y+ n0 z- |, B
8 E# {) J$ M6 f8 H0 cTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
; Z: f0 k7 N! t4 x. a" ?Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;/ r: v! _- H+ O. K
还有Group类型的Event,用于处理具有相同类型的事件
$ j+ H! k% c' Q) H一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)" n( u; b; s/ p' V' A0 }
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
6 V. s8 ~7 ]% S不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
3 ~" {* p# Y7 y: s, g# Y' Q2 z! v; W因为我看到有很多地方有RestoreTPL,很频繁地,
  v4 H8 |8 j5 {9 D# C8 g所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
* l$ V. p# x" S: z  `! y0 n6 b5 ^- @: S
TPL的控制,$ }3 Y& W8 j* F5 R- B& R/ ?
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)6 c$ u9 V4 `7 m) {& _# |: U7 g* d
不想被一般的事件打断时就会RaiseTPL来处理,. p; G# T% U% B$ j( E
处理完,就会RestoreTPL了,' Q: Q" o9 S8 C5 @( I* m
当然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.8 o$ b  j8 b- E6 \% [& Z+ g
: h5 l  u7 t2 i; K2 a1 E
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6); C$ h1 B9 B. {9 ^- D
所以,就可以"认为":2 ^& B% }0 M4 R, m9 h8 m8 C
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。! B# n  ^" U  M( a3 e: ?7 {

3 t# x) H7 T: p而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 , [6 k2 H4 {% E2 M1 {2 U% f
# R- L' i4 ~% x' [  p9 i
我个人理解,每次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属性。
- g0 H# N9 }' @1 I9 dtypedef, n% u3 m- r- i
EFI_STATUS
8 k) g5 O' I) B2 s8 yCreateEvent ($ R: t  W- Y3 o+ i  ]
IN UINT32 Type,
- t! T9 E7 }! m3 o# H; {2 g& ?IN EFI_TPL NotifyTpl,
+ w+ c! x6 J7 y& k( T5 i4 tIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL. G8 a' A- R9 E- M. }
IN VOID *NotifyContext, OPTIONAL
( k( Z* @+ C, m; DOUT EFI_EVENT *Event) U& x0 U1 D  M! s6 _7 e' [% Z
);
5 Y& X5 \- Y6 p( \中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
6 T7 _' p3 }4 G( V( O; h! j! U5 D使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?+ D# a- N2 Z7 H- ]4 W" F! V: E2 N7 @
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
/ R$ q5 _4 u" p% {% z( y* b& oNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。2 X4 o: Q3 t0 I+ s% G
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:. [( o! O; a  [& i
如果是Binding Protocol的Driver,在自己的Driver里面: x( Y# Q3 R" N5 K8 f
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)" |6 f9 A! B; w8 H/ g2 Y! s
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
; @0 R2 Y3 F2 S+ g8 i/ O在Event的NotifyFunction里面
9 B0 x* p) E% T& _) L* k. \还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
! h& _! T  w7 x6 G  s4 B0 x这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!! N  n' G. T. k/ x- ^5 p0 r; P
可以Hook到所有后面的driver!!!
8 d: b; _( n! k0 L
, K) S  S+ m- ]$ {1 T0 r9 m回复 13#的帖子9 [8 n6 b' @7 V8 Q% D2 T5 p* s
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~& S& ?% ?9 ?. S) q% H
2 J# s; T; H8 A& [/ V
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
/ A- J/ i$ R0 ^. ]  ^! }! Hxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c3 Q& Y2 k5 d: S" e! q
CoreLoadImage()-->CoreLoadImageCommon():
! y2 |* @: T. D4 X0 t/ H& J  //
2 N& c; I. o! U  //Reinstall loaded image protocol to fire any notifications
: `% c1 f# B/ }+ l: x8 N  //6 j# ^+ s4 A4 e6 g8 g
  Status = CoreReinstallProtocolInterface (8 z, w+ n8 O- w( K" [/ u4 _
             Image->Handle,
* w$ E  k% S+ n) d/ d$ @: l             &gEfiLoadedImageProtocolGuid,
, ?6 j/ G7 \# G4 r# {- H( {             &Image->Info,
9 _) Q% B& ^# L. w  N8 O  Z! X( \  `. p             &Image->Info
- X5 f0 e0 B7 j             );
5 ^" e& }3 N+ j0 B1 T& c* h
; W6 j8 Q' Z! ]; E! zFile:Notify.c
& x8 j9 f9 E5 ?% [3 Q% _3 f- |( WCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
1 x, ~" i5 C- b3 [CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
1 `" t+ L1 B  p1 [* pFile: Image.c, E3 m+ m) M; F3 C: c4 s) h
CoreLoadImage()-->CoreLoadImageCommon():3 S( o) H. p% a1 F7 ^7 [
  //- c6 j# u9 w& r
  //Reinstall loaded image protocol to fire any notifications: y0 t# \( I# |
  //2 j* P0 h2 x0 ^8 ]& S/ h6 q
  Status = CoreReinstallProtocolInterface (
1 n3 W& r( G/ I- j" B6 ?             Image->Handle,
1 U* u% d" W7 S( f1 t  ...
# s( _  N5 x4 N% q; J+ z3 i( }

/ k2 g  l7 ^* `: y" z感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
% D( J; }, e1 x0 q9 H9 w- BCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
, m) c' U# T% {  l% a' d0 F, y$ ^/ ^0 |! F7 m7 D; j
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?5 w8 R7 N% \0 m5 _+ }
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-20 05:42 , Processed in 0.127714 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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