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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,2 ^$ {+ r4 h& q( c: o  H- S
一直都不怎么理解为什么要做出Event这样的一个机制?7 [9 U* O1 p9 [* J# Y
) Q( f8 v& |; ^
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)( h/ c- ^: B8 v7 [) y5 D
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;0 c6 W- c6 z! d8 b" ~% `  j7 y
还有Group类型的Event,用于处理具有相同类型的事件8 Q5 z6 `8 X5 O! w/ o
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
8 j) }5 K2 K; F" q7 o这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,1 w" y8 H  {7 u$ l* Y2 D- 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.
2 @. `! |( ^( G" a; o因为我看到有很多地方有RestoreTPL,很频繁地,
7 c+ F& _/ @* h2 K0 |9 y所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?7 b# D* v9 R; j0 A! Y+ e. x8 P. x
7 g5 N3 M8 e: W8 V# F; L: ]
TPL的控制,
6 {* f( [: t" t) B我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)" |8 P4 b. c$ ^  o' V1 n& i; ?  T
不想被一般的事件打断时就会RaiseTPL来处理,
+ f" {9 e& o9 {处理完,就会RestoreTPL了,
$ w- V8 x- J! S) K6 M! }% s" ~当然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.
: R# M, @1 w& k- \8 z: i) r  ]* I$ f" W/ C
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)2 a7 F& |3 _, W* f
所以,就可以"认为":
+ ~/ s* z% P7 t5 R: w. r       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。( |/ c( U" d' O. v3 M
" `- C8 D5 G) R+ S
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 . O2 K; s% T" }9 S& I# g
* Y) I4 l9 d7 R
我个人理解,每次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属性。3 a' J8 \9 D4 B) G6 D6 _6 m
typedef
& m! c! A7 j1 }- o9 wEFI_STATUS
2 H# ]2 u- T: F  |7 G% ]" yCreateEvent (
9 U- l! M$ H- I, SIN UINT32 Type,
8 O* ]& @8 G( sIN EFI_TPL NotifyTpl,
( x# g$ h. K7 r% O5 R! Y9 ?IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL2 M+ {  f; I# F7 X& O* n
IN VOID *NotifyContext, OPTIONAL7 x& o9 q1 P. I
OUT EFI_EVENT *Event2 L( L* J( i, k5 X
);
, @% Z$ `  m1 P* V& a, K6 E3 o* e, `中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
- Z* e$ P& L* k使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?3 V) B0 S8 \" F) B' m, T4 _9 b
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
% @$ j: `2 M# D# B- DNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
3 A9 |1 `4 d+ w8 a8 k* F5 u$ N我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:' g) s$ u: n, s0 l/ e8 ~  ?' z
如果是Binding Protocol的Driver,在自己的Driver里面
; b# y4 B4 \' b! ?+ I  t用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)  R% R) @/ r3 Z+ i& t/ r3 d& r
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
. s. D/ O) U7 Y& Q& A在Event的NotifyFunction里面! L1 L3 r7 d9 P5 \
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
+ Z$ H+ s$ s* y4 h这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
2 a: f; P8 o( S可以Hook到所有后面的driver!!!
0 e2 C- ^1 Z# x2 p7 O* `# \; u# G, D% A' w; I9 j' L$ t9 d
回复 13#的帖子3 g! Z- b- {2 y4 h( ^
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
- J2 ^1 p' Q# F) T1 e. _) O0 o
& B. o! ^. O- X6 o/ c% U在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加' t: v+ \) s% {' Y" ?7 A
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c! }- l, C* ?2 X$ Q0 B1 M
CoreLoadImage()-->CoreLoadImageCommon():
, s  h  d. N2 U( j2 u8 b  //
2 [3 u. u2 C, k8 t1 d* o  //Reinstall loaded image protocol to fire any notifications# [, R1 n" x* x1 `. T
  //
3 C- g0 t0 l2 @  t4 B, N  Status = CoreReinstallProtocolInterface (
: E7 B! e; S, J% P7 h' p  l/ V' \' {             Image->Handle,
9 u* w+ l8 k- a2 T0 s, c             &gEfiLoadedImageProtocolGuid,
: T5 W: ]9 `5 _) s6 q7 K             &Image->Info,
( Q! R7 f5 N9 c% a             &Image->Info" [; u. b/ D& T# q4 B3 a: A
             );. H7 ]8 R- |* F& p. @% i1 W! z
( F/ t  o$ |7 _' F$ D: f% |
File:Notify.c
1 q/ {, y: L" E# ZCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
+ S7 U' T3 P* ], [CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
* D$ r  t9 j  F* t3 tFile: Image.c# f9 h9 c- \0 H  D7 D
CoreLoadImage()-->CoreLoadImageCommon():+ A. q0 E, D- s" c* X$ |8 h  L6 o  n
  //
: L( {0 x- T+ @+ j  //Reinstall loaded image protocol to fire any notifications
- I6 Q. r/ y7 D! K  //: v8 d) I& x4 y
  Status = CoreReinstallProtocolInterface (( b# O6 W" K/ A* n* N# q! d
             Image->Handle,# N! k7 g: V# s4 c/ N$ B4 K* Y* I
  ...

& i+ j% r( |/ s6 P2 y
' L1 N1 J2 H2 K9 P感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
1 N" K0 `8 |9 s5 h& r" WCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?" D1 N1 X! r; |, i- }3 \! ?  b8 z
1 b: g& Q9 h; v2 q$ R* d
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?" D  {  ~9 s/ B- f( |/ L- G; i' M
谢谢!
回复

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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