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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,) r$ D" o7 w" w
一直都不怎么理解为什么要做出Event这样的一个机制?
7 N9 Z. z# p+ d8 B& m2 q' f3 J" [2 h' T+ i* r! R
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
9 i1 u1 i& ^! w7 ]Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
  _- \: B0 w, ~4 D/ W# A还有Group类型的Event,用于处理具有相同类型的事件0 b2 j& w+ R. i& L! G& R" Z
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)1 ^% w4 i+ D7 w
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,3 Z& n: W4 y/ y1 k
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
% o! `, ~5 o8 @) r因为我看到有很多地方有RestoreTPL,很频繁地,8 H3 f: U9 a8 z$ I& t. b
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
$ X. v; v6 Q8 f& W% [
  H6 o9 A3 Y. k% i8 Z0 B+ hTPL的控制,2 I" G( m. p" @
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
; b( I' S& t3 `$ m不想被一般的事件打断时就会RaiseTPL来处理,4 z. Z( b$ R, ]" v) Q! Y6 z6 O
处理完,就会RestoreTPL了,
% O. B) ^! b* t4 P: p0 s8 S; S$ 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.
2 W8 a+ K. l$ @4 a; C1 G  V1 E& j9 w3 P- _" D) `
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)5 F9 `4 G6 Q# k5 Y1 z2 ~% ^
所以,就可以"认为":" H0 E5 L7 q3 n, B
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。. J, p" h. J8 n2 s+ ^9 X: Q" i0 n
; h) n2 i  k* ]- o
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
. e$ v" N& g. v2 @' Z* V& a: ~) ]5 B* S# {
我个人理解,每次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属性。: A& W  |; F) `* N  H
typedef' j8 m' V3 k" w; U
EFI_STATUS) `! ]% h6 y# Z0 a; r6 w
CreateEvent ($ ?8 H( M9 F4 m' `
IN UINT32 Type,# q+ R, N, A! e" x1 z
IN EFI_TPL NotifyTpl,: X, I  a4 T& ~3 ]
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
# Z; p+ S0 W5 w+ d+ qIN VOID *NotifyContext, OPTIONAL
! O9 I5 a; P" e: c/ V+ `OUT EFI_EVENT *Event
0 X5 v4 l1 I6 d" a  B1 r: u" y( V);
) z* P* i& r" k7 u) ^$ j" L, Q中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。5 q4 T2 h/ w. ^( L+ _, g! ~! B
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
# w  Y2 l8 D; H! ]1 F  R+ m! d谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
8 k; S* ?1 d6 p% \2 f+ ]Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
* {8 j7 c0 V1 q* X我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:) l+ D4 c9 r* h; \% `" R7 e
如果是Binding Protocol的Driver,在自己的Driver里面
& L* Z% m& p% L! n( x/ M# D用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
; W' V0 m% |3 f5 y, O! v. ?9 T记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,0 Q  y8 U0 Z; Q, S
在Event的NotifyFunction里面
5 p, L7 Z) V6 z. d8 x7 d还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles; g7 F. ^0 B" j
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

发表于 2008-9-11 12:59:04 | 显示全部楼层
方法很类似,你是在对特定的driver进行通知吧 我比较狠一点 哈哈 是在Image.c中的LoadImage的相关函数中加的Signal只要LoadImage 后就触发事件到NotifyFunction里面,然后再回来执行startimage。
# K- O2 s+ q9 P" D) @7 R  z8 \* N- ^3 }哈哈 以后多交流 遇到能聊EFI的人不容易呀~!
回复

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
4 c$ x8 h+ e7 }: C- J可以Hook到所有后面的driver!!! # ?4 ^7 \4 B: T- L5 R5 h2 L, j1 a

/ y2 Y- n5 |; G$ n回复 13#的帖子
8 L) O/ @9 p. B5 a5 @1 ?) y在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~' \5 b" D9 W* c4 [

- _$ Q/ p! _" a, D; R& Y4 @在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
$ R+ ]2 |* n! C+ e& Rxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c* z& o. ^3 N* i
CoreLoadImage()-->CoreLoadImageCommon():
8 T0 F1 ]+ C: ]: G9 x# g  //# d1 G! ^1 a; x4 w7 ^; `" E1 f
  //Reinstall loaded image protocol to fire any notifications# j$ ?. q1 C8 M" ?
  //3 n6 G1 k9 d. J2 b8 }8 }+ \
  Status = CoreReinstallProtocolInterface (
# z. n( k: Q( b# z* O) A4 Q9 M             Image->Handle,% s& C" ]$ y# P9 m$ v$ p
             &gEfiLoadedImageProtocolGuid,# c! \% D6 U8 I
             &Image->Info,$ |& u, C' o7 ~; D/ E  C" K
             &Image->Info
$ F# j* }) Z0 H4 e             );
0 \4 U) _! ~& R/ O% u* P& S0 S! E; o( C/ t9 D2 C9 L
File:Notify.c
8 `; c! h: o$ h1 K/ t! n5 u( hCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
+ o- g, r9 w* @* o2 |7 {7 zCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 , ~  o+ x4 j4 V" E
File: Image.c
) ]  J5 f; E' Q: \  _7 x* yCoreLoadImage()-->CoreLoadImageCommon():
5 ]/ F1 Y; _* [  //# s5 M6 u7 a- L4 r  U
  //Reinstall loaded image protocol to fire any notifications
, z% Y. e2 O9 I9 x  //8 s; j5 h8 P, K1 `  c  l
  Status = CoreReinstallProtocolInterface (; Z/ ~  _* o9 m
             Image->Handle,
* R, f. g. K* d  ...

  K; Q4 B* C6 H
5 c$ n) G, i; h* _; ]0 S2 ?感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:! M7 B/ x0 a$ D# l' d, X" r
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?6 `7 i! o# t  y+ X5 T
  Y4 K/ ]$ s3 c' E6 ?
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
& L- P' y  U2 |" |谢谢!
回复

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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