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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,7 m( i4 h0 b2 p/ ^2 H2 d
一直都不怎么理解为什么要做出Event这样的一个机制?
. M8 |2 O% y. C! S4 `) Y1 M! ~0 @* _3 Q. c/ ~# l, ?, D
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???): Q1 G! T! {6 l8 ?# {: c7 i
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;: d3 Z+ m- c7 Z. d6 l" h. q) ~
还有Group类型的Event,用于处理具有相同类型的事件
2 n5 U9 u1 A$ n" `' J$ _( T# ^( P一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)( e: e6 y9 Z5 q
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
- [/ b4 m7 I, q& w& Z% T不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.  {4 L7 r( b2 X/ g! `" g
因为我看到有很多地方有RestoreTPL,很频繁地,
& X4 t# z6 |3 f3 c$ \1 R% e所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
" T2 Z/ F; Z& T5 b0 H$ _+ T! p% M( b# [
TPL的控制,$ ]# N! o% o. r+ z
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等): K+ c: D, H2 L8 N! Y' m
不想被一般的事件打断时就会RaiseTPL来处理,  i) w5 X* E, [# ]* a, k. _
处理完,就会RestoreTPL了,
4 A  c! X8 R, ~! k/ u( K0 _$ 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.
1 a: i4 \. b+ ^# P4 n' \! r5 w. Q3 C/ R! g2 R
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)' e; T1 M5 T* F2 r' V9 U
所以,就可以"认为":. p5 w) g- ~4 t1 u1 `( i2 j
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。+ @4 J0 e* b0 R6 T$ Z$ g0 w0 p
' N. s8 V. A( I- Q; b0 ~% P
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 6 D/ T% E( v4 b' s% u# F
5 j4 X, L, {! V) D! `& U+ k
我个人理解,每次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属性。
, e2 K. D; E# O9 F  Qtypedef; z4 p0 i5 \3 o  Q
EFI_STATUS" [+ G' o/ B% ?: {
CreateEvent (
) c" z; t2 q5 W2 GIN UINT32 Type,
: r( h& G3 ]  v4 h# I" hIN EFI_TPL NotifyTpl,
( K# `, F9 K* p1 w- k& d: B) EIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL3 K5 [% Z" L; I( v" ]
IN VOID *NotifyContext, OPTIONAL* B; }9 [0 \/ A* L1 f
OUT EFI_EVENT *Event
, u: T3 ]% w: _! ^, A* P1 T  G; a);  H3 k  |! @  Q. R; N  ?4 \) g# y
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。) @+ i5 b% a, J, u' J
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
' {3 ~: s/ B( h5 I7 y" G谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。0 p6 m, V( I6 A9 A
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
9 e& F) G: H" i5 e0 g3 l8 _我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
5 K* ^/ f8 l3 e9 O, i" y1 Y' r如果是Binding Protocol的Driver,在自己的Driver里面
, z! A) r7 W  R$ U  n8 E5 J$ |用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)9 l6 P, B- k5 ]2 s0 N
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
- W4 h- V7 z7 v& A) S, R5 u在Event的NotifyFunction里面
$ u9 e6 O/ i( M9 X. |- ~1 o4 x还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
: `6 N: ^1 Y2 g6 M这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
2 H; B$ p1 l: m# q; m# ^可以Hook到所有后面的driver!!!
) R# p7 x. X: {  j- G1 X
- y. @# u1 x3 `& d回复 13#的帖子6 W( f% h! U, w
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
( G7 W  h7 H. E3 X% o- `9 L1 p' R$ l! G3 M% x2 {
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加& \  S) k" w0 b; b
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c- p& ^2 q* M* G1 Z  W8 R
CoreLoadImage()-->CoreLoadImageCommon():
8 G4 \- \' i& [2 Y  //; J0 D9 ^2 X3 E
  //Reinstall loaded image protocol to fire any notifications. _, y3 [. t" _/ E! p
  //6 V# V& E# w0 {
  Status = CoreReinstallProtocolInterface (
! N6 j. m- P; M             Image->Handle,
/ v. m2 {) G. a# j# w: I9 u             &gEfiLoadedImageProtocolGuid,5 P6 W7 s$ Q$ F6 M' n
             &Image->Info,/ y/ D) N$ R, ~) ^* V- V$ B
             &Image->Info
& j) r) T  {" ^' Q1 {2 {# B% n             );
4 T6 M: A) h5 h& o# j( T% b! A% a2 m6 H- M
File:Notify.c
- Z1 W& B7 s  @7 L7 LCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()1 _7 X0 M& x9 N& p5 u
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 3 Q, W0 [! d$ }$ n' _
File: Image.c# K. q3 ^2 x0 h$ s8 d9 {' [7 H" l8 z
CoreLoadImage()-->CoreLoadImageCommon():, M! b" t8 h9 O" @1 t0 \
  //( [( L! J: M7 E9 `
  //Reinstall loaded image protocol to fire any notifications
8 ^2 B9 X) ^; u1 b8 Q  //
/ a) ]4 l, G, M  Status = CoreReinstallProtocolInterface (
- L2 w$ D* }* \- K; W+ x             Image->Handle,
) E! y( i/ z7 S& k! j( y  ...
" \$ C% X& s; i4 p6 h

+ p8 c% H, Z5 p: ]& t- `6 K: M0 y感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:. o: n1 _  q( ^
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
8 c8 B# x% a- }
6 J+ [  N, q6 G' t$ k2 [% s+ Q! c) l[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?6 o% U7 ?/ V4 S. F; Q' w; V! o
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 02:18 , Processed in 0.068810 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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