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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,6 _# S% B. z+ N. y6 }0 s
一直都不怎么理解为什么要做出Event这样的一个机制?/ [3 A/ X# j, v

5 }  U+ N2 M. d8 A  kTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)5 h% ^  L& s4 d- Q0 C: G5 g- k' E: G
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;$ c$ f5 H: r$ q! z! a1 E
还有Group类型的Event,用于处理具有相同类型的事件/ P* i  G, K8 e# B! A- s
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)( d$ y* _" y, V& {  w5 z
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
5 A! J* v, o( k+ \3 D5 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.
7 z* E% T& g0 ]+ `$ W因为我看到有很多地方有RestoreTPL,很频繁地,
3 V4 w1 g( Z, c+ e8 h3 m% Z7 n所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
' b9 D5 B; C  ~  B9 L; s8 i) H1 L- @/ E
TPL的控制," b5 P( k8 A; C$ v# Y
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)9 E7 ]" w: M0 g* w+ `
不想被一般的事件打断时就会RaiseTPL来处理,
$ e2 P# g8 w9 \5 W+ ?9 u处理完,就会RestoreTPL了,  v' r7 d' ?8 y( A* U" L/ p
当然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.
% c* P' `% E, A+ I( u5 M
1 p2 t- G- M6 o0 q( l6 K5 I' c# Y我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
, C6 D/ Y( U: O$ `所以,就可以"认为":
, M0 t, o+ _/ N7 F6 P2 y# g       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
* x. r& V4 n$ N! B' @1 N) O4 K$ z# m7 u3 B
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
* X" N( m7 G- I" X( N' n: w$ S( b3 a/ o. ~
我个人理解,每次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属性。
( r0 s9 c# E# h. X# E* ytypedef0 [3 W' f0 l8 v* R9 }! y
EFI_STATUS, D8 e/ X$ Z; V' a7 m- r
CreateEvent (* S0 I. ^* S" P# G7 c. g
IN UINT32 Type,: R1 J1 R, A  b& T  E
IN EFI_TPL NotifyTpl,6 O4 h2 S+ K3 Y1 q! U: n
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL# s2 N- x, L4 L  U0 V- k
IN VOID *NotifyContext, OPTIONAL
: c0 N1 e8 m9 C* G! w, COUT EFI_EVENT *Event4 @& p7 k7 f$ k( }
);( A4 B  k  s  r5 t
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
9 L/ W- R) a) W( d, L使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?0 j; u1 M6 h" p! h4 p5 M3 |7 d4 a
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
# r* ?# E+ m' u3 h1 @: u4 BNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
  ^) K: s4 O  V% ]. S我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
3 k! N/ s' s4 z! R$ c8 G  q" `6 q  Q! N2 A如果是Binding Protocol的Driver,在自己的Driver里面% R2 x0 U4 ^, j: }$ Q7 S$ b& |
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
2 O- y' j( u# R2 S记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,5 e+ {8 C  H9 d! }' J
在Event的NotifyFunction里面
. t0 R9 a9 V# Y2 L. `8 T+ ?" Q5 e还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles& d" K4 B: A. O
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!- e# @: i; O+ u( t& B
可以Hook到所有后面的driver!!! & I3 l! ~0 C9 v% e  e3 {

; I7 p2 b$ p: W4 c# `: a2 m回复 13#的帖子+ T: }8 J" c. @) W/ t; g) J- d3 m/ |
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~! k4 G+ p+ _1 N3 G- Q
, x- W0 h( E1 v4 I0 H: K  V
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
- r8 E  B/ u  p& m! Jxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
, M# o$ G8 {5 ~8 I6 Q$ g, J- ~CoreLoadImage()-->CoreLoadImageCommon():
! r/ ~: A. q  n3 k  y  //
( f8 Q1 o/ N! d4 Z$ C  //Reinstall loaded image protocol to fire any notifications
& q" H" @: x1 j& L  //" G' [, {+ R* l$ m
  Status = CoreReinstallProtocolInterface (
! K$ z# Q  S+ V* Y' [/ m5 M             Image->Handle,
8 x. G) d. `5 o# w# n6 M             &gEfiLoadedImageProtocolGuid,9 s. y1 Y) ^% X! b. C
             &Image->Info,
$ F! c9 T% ^' y7 B4 q0 N  y             &Image->Info
/ |/ f0 M$ ]+ Y7 l2 ]0 ?             );! r8 w; ~2 t+ D5 T. {! _: S9 [; o
! b' z- r- @4 M
File:Notify.c
3 O5 y4 K, ^1 P$ GCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
' f! r+ n  r8 Z( c- KCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 9 |7 ~# e7 K" x, Q0 p6 H1 s, x
File: Image.c2 w4 b. Y! o/ M+ |4 `" N
CoreLoadImage()-->CoreLoadImageCommon():
  A* ]8 p/ a8 w9 z+ A  I" ^  //
! n9 b& K! }# |9 T8 C  //Reinstall loaded image protocol to fire any notifications
2 s8 B* P5 P; G. _6 s9 o  //8 i/ d" w0 t, r) R- Z
  Status = CoreReinstallProtocolInterface (
, {2 b- Q5 k9 z, O             Image->Handle,
! N% |7 i  R# ^( A% G  ...
" `+ _; f- e# i! j! e4 q2 N
7 W7 Y# @$ f* o( ~9 I
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
: q& L% [) C; ICoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
, x" y2 C4 A. d$ `% M& \. m
+ H/ T+ Y  g. l" t[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
) u8 e) b3 m! d7 l6 t7 T谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-8 12:12 , Processed in 2.025088 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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