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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
' p" j! ]9 R. T( K一直都不怎么理解为什么要做出Event这样的一个机制?
- H6 c* q" `! P4 E; f; a6 w  g3 f
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)% v8 S* ^, }) V. D" p' u
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
. E, w9 D! |' O# a' O1 J4 ?* ?( z还有Group类型的Event,用于处理具有相同类型的事件
# H' b$ Q- P; `6 B一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)2 O9 Q, @$ b2 N" }
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,+ z# k, e1 [! E
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event." n! S) K2 J) L; O. G
因为我看到有很多地方有RestoreTPL,很频繁地,
. p: W, z/ f3 T) K/ B所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?  e$ _& r1 H: X; C/ u4 I
& \7 S- G) m; u& \/ f) m! e5 o0 I% m
TPL的控制,( R, o0 ^  }: }$ ?8 W% r+ b
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)+ R& V8 }, ~% u; E5 I- R
不想被一般的事件打断时就会RaiseTPL来处理,% q5 t. K* Y3 a& j0 u
处理完,就会RestoreTPL了,
0 Z* L1 s( c6 m7 e6 P" }$ h当然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.4 u  k: e! b4 A' i  ~
: }5 t" M- I0 v1 V
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
6 O( H8 q% ?; t6 y8 I# t所以,就可以"认为":
$ c! [9 Q/ L& j# Z4 e1 C& z       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。& v, W" D1 V& ~. O4 n$ Z+ X
# B6 Q& N6 l9 f) u1 V
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 5 O" b$ v7 R) F- `; t

4 i: p& r, K! |! G我个人理解,每次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属性。
0 B( _( l3 C3 Z7 M! D+ a8 ktypedef
! j3 n+ X4 `3 v2 bEFI_STATUS
/ f# L8 j+ k9 d. \% L. tCreateEvent (# m! v0 o% y6 u8 w) |+ G/ s: ^
IN UINT32 Type,
! g! u  U2 q$ _; s3 J5 o# e" ?IN EFI_TPL NotifyTpl,- x$ |* j3 w$ m
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
! G/ r8 d& D6 y( L  h( pIN VOID *NotifyContext, OPTIONAL
+ U6 I: n( e+ H& BOUT EFI_EVENT *Event9 J2 Q* p8 M% p, p* R
);7 l, k! o) B3 R
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
0 M1 m4 z) @- D) Q5 M使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?+ r0 Q& E' Q- W- f
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
+ i6 B0 {3 h' C4 y* X6 s" ZNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
2 q# @3 [& l0 S: @! L我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:$ T8 ?4 R% G& y  {" P- x
如果是Binding Protocol的Driver,在自己的Driver里面! D" S8 G( P4 H1 y) M  ^: y/ c1 L  ]
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
6 G9 v* w- n1 H7 N2 T# u5 J# }, d记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
, {! Y% s: `' P在Event的NotifyFunction里面
1 l# R4 \* `$ u  O( u& O还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles  M! ~/ F7 K" s0 i
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!! E. M1 }- K! z/ R: M- N. U# q
可以Hook到所有后面的driver!!! " ]2 t0 i: F, t
/ T5 {) W) L4 N
回复 13#的帖子
) M0 h) z- b( X7 c* u- l* O6 T在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~$ H% f2 {4 T' P, g1 @6 |+ f% e2 @
0 m; F9 t  _1 H5 N) g
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加# d" E. F4 d9 d3 }
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
, I! _- S/ v: V; F- P6 Z" t+ v5 pCoreLoadImage()-->CoreLoadImageCommon():7 d( |) `5 m: W% J) \
  //8 f; Z; r7 p' n
  //Reinstall loaded image protocol to fire any notifications
% w$ o* u. ^8 O+ ?* A/ ^. M3 `$ j  //
/ b0 K2 M1 P  g. \- G; Y6 @  Status = CoreReinstallProtocolInterface (
# _$ W7 c' N$ a& l, u4 n8 N  q9 D7 V             Image->Handle,
0 y" c4 L' T; H" W4 T0 d% k             &gEfiLoadedImageProtocolGuid,
# D* X! O4 \! @: U/ z% Y+ M             &Image->Info,
) [. A4 f4 ~2 m             &Image->Info
5 j+ x/ L  O8 |: \2 z1 \* b             );+ x) Q: s# R' T0 l
/ B8 Q0 Z3 A  x! |  {6 D- {2 P
File:Notify.c
7 k& k0 `8 ?6 A; i, RCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
: E9 o$ Q5 W$ @/ q# j3 TCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
3 F$ s- K( z) T$ @( r* mFile: Image.c/ j/ T! a- c" k3 i( j4 R
CoreLoadImage()-->CoreLoadImageCommon():" i/ j% o, B+ j. t- C& d# l( v
  /// M" r; w1 @: I) a: b) t; d1 A4 P
  //Reinstall loaded image protocol to fire any notifications
+ C) M, ~4 q. s8 l. M  //8 b3 N" t9 n' T- w0 U. [/ M
  Status = CoreReinstallProtocolInterface (
) t; g& s. F/ P! p, c) P+ N             Image->Handle,# z0 k$ z6 C9 c: \* I' j$ Z( f# Q
  ...

% x* G: f( Z! t7 O3 h2 V 3 r. C. e, k" b9 b& M8 z9 w; S
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
+ C9 x; A" r4 q3 Y# eCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?3 Y. b% o/ d) c  g3 U+ z9 Q
: |# e2 p- i6 [, f) V
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
, O& I* s; z: V: M谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-4 20:17 , Processed in 0.086077 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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