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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,. r5 E: L; u# _
一直都不怎么理解为什么要做出Event这样的一个机制?. }4 _9 {( m. Z6 b& D1 x
7 d) b5 |: c# V* l
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)0 _2 F+ Y  h/ i  z8 P
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
  B& E  o2 W4 W" }) s% T3 a# ?还有Group类型的Event,用于处理具有相同类型的事件
  X* [; |6 W5 b. p一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
' G0 K  o! y+ M: c- `; {1 o  g这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
8 f6 t6 O6 ~4 R; x# f" F不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.9 U1 H2 [& G% f- _% Y( [( x  c" v
因为我看到有很多地方有RestoreTPL,很频繁地,2 H6 x/ l% E' m' `4 D0 q
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?* w/ u5 \" D% W
7 X2 M- N$ q' p/ s
TPL的控制,
& r3 J6 b6 @" x, K7 q$ M+ V9 j) z我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
$ C" P( ?( H1 |3 }不想被一般的事件打断时就会RaiseTPL来处理,# V; X  S7 }! E! L" {
处理完,就会RestoreTPL了,
- A: ~$ |. @; K9 j- A1 q, Y' q5 v当然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.
3 r( a* d9 ]& u7 C, {) |, H1 @
0 z7 R+ m2 y* S, s% L我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)7 q, ~& W8 {3 [3 v6 Z/ j% u
所以,就可以"认为":$ D6 M9 p. j3 ^6 P5 b
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
, X% U$ a$ C, D7 g( l. ]
, z2 a6 s4 e, z0 q& o而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
& \+ c$ s! Y2 ?* d3 {. z+ q% J2 v' s- c% e& A5 h# j
我个人理解,每次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属性。9 Z& A: y! l# M! i/ h
typedef- _- K+ m* N4 N1 ]
EFI_STATUS+ V. j  h: k9 K+ @2 B7 I
CreateEvent (
* C, I- j. S& l. kIN UINT32 Type,
0 o# {1 J6 L. WIN EFI_TPL NotifyTpl,* P/ @* s; l. G7 k6 Z, w
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
0 ], h* X8 e& {' y  J+ aIN VOID *NotifyContext, OPTIONAL) M4 e( y/ H! c7 Q4 x6 z+ f0 L
OUT EFI_EVENT *Event9 D$ d7 H( J% K0 U" n3 Y& [# J
);
; O4 \( |$ O' A4 p% G6 A0 n中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
9 q$ r2 i8 i" L+ n使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
% A- C) W' [! E谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
5 ~# v0 l& j5 Y1 u. j# |Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。$ j! i* Y6 c1 ^- W4 b
我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:# a1 a7 j6 ]: b2 b
如果是Binding Protocol的Driver,在自己的Driver里面; b) M" o3 M6 e( o# a+ ^: E5 \$ v
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
/ }" H3 A: Y8 L: ^8 B# K: y记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,8 v2 ~$ L9 G: T+ H
在Event的NotifyFunction里面
2 I0 q7 o5 `" J还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles, l6 e9 N: L( t
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!8 e7 _) a) L  m' |7 F' @
可以Hook到所有后面的driver!!! . u; e! H  c5 a1 v" Z4 e
/ W& O+ B8 Y& n. D/ B
回复 13#的帖子
  B5 b- C1 W$ n; D0 a  u) K- D在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~5 @( M6 E5 D4 P) m0 I8 K9 V

: j. F6 t5 U6 w0 U& J) w在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加' |0 v! k3 E' I/ L
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c$ T' `. m% R1 F( I# a5 Y5 c
CoreLoadImage()-->CoreLoadImageCommon():' B8 J5 Q- Q% f7 L! V
  //
4 p  }  A3 f. x4 k  //Reinstall loaded image protocol to fire any notifications$ ~& `' z2 Z0 h+ }# P1 P- b
  //
3 x# E" i6 d  e$ E* B% j9 ]2 _  Status = CoreReinstallProtocolInterface (9 r/ n! R5 r# F+ [9 i
             Image->Handle,
3 i6 p% m- {+ M# ~             &gEfiLoadedImageProtocolGuid,: _+ c- V3 m. i" L7 d5 A, L
             &Image->Info,: t2 g3 c; z& t4 G6 ^# D
             &Image->Info+ j, q1 K, c: J+ _, g$ U
             );
7 P% B0 J- }8 |8 E
0 w* P$ b% T4 U8 v  R4 vFile:Notify.c+ _  Y) [$ \% m
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
# d* o2 J4 q8 ~3 CCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 # j. M3 E/ [2 J, k) v
File: Image.c
3 R1 a# A; @5 y3 ^9 E2 o$ H2 o$ qCoreLoadImage()-->CoreLoadImageCommon():
; m" `" g9 E5 N- ~/ ]$ W! \# E  //2 W+ p+ h. n- W0 u* j; Q+ z9 u
  //Reinstall loaded image protocol to fire any notifications
- S' f& U2 r4 U  S  //
" |5 n1 K" z5 s1 ~1 }6 J  Status = CoreReinstallProtocolInterface (' W7 ~: r0 i" C/ F; E% d
             Image->Handle,
, v% u+ n3 G* F* B6 W2 N  ...
' }' Z; |. h+ |- _4 `! U, j' r

* X9 ?+ ]) X% n" x9 j感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:4 t- t- E9 q/ u" p" l8 f0 S
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?, M* u1 _0 j2 c, E/ {( W
4 ], J) \- \3 u7 c7 l& b
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
) q9 ~0 w5 N' t! \) r谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-29 04:10 , Processed in 2.304298 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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