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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
% Y. \2 W4 K$ o0 G* u一直都不怎么理解为什么要做出Event这样的一个机制?
9 z% A5 d9 M- B" C, Y  F8 F) |/ U  o& k! z9 c
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
6 `& A) d! f* i7 K) m  kWait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;  [0 O1 B7 s* R6 o
还有Group类型的Event,用于处理具有相同类型的事件( _# M5 x/ F: j8 V7 a. `8 A9 M
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)+ e0 C. D8 F" r; T
这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,+ P& A  K, K. ^! N  ]
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.& y. y- W9 z* ]; I% U: t
因为我看到有很多地方有RestoreTPL,很频繁地,2 ]: U( A3 H; W
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?) O( {# A0 ], t" B

1 G9 y+ \: u, e" d5 TTPL的控制,$ x; g$ F3 x, o& z) i# h' I
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)& P+ r; ~. c9 z# v- y
不想被一般的事件打断时就会RaiseTPL来处理,
+ D" T5 \. Z/ d% F处理完,就会RestoreTPL了,+ P+ G$ I0 v+ Y% X, C, d' m8 b
当然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.
) a0 |& d# P# {+ T% ~$ A' m/ \$ }) b% s1 K9 L+ R
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
5 ?; f7 k( e& s6 }6 E) Q所以,就可以"认为":
, e( x) y. n2 z: V       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
' G3 p) w6 c, u/ F) g. `7 J1 D6 h
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
7 u! ^* f5 G! b/ j- w" D0 R1 x5 T; i+ Q+ ?! [# s5 L
我个人理解,每次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属性。
: x. y6 a# k/ b& wtypedef
, X  a0 B: [3 A9 @  P( Z% dEFI_STATUS' J( \+ q# i8 \6 @5 I* V
CreateEvent (7 b9 {4 {, E' K3 I. G
IN UINT32 Type,
5 x8 w; k8 b7 q2 h! t* u7 j% LIN EFI_TPL NotifyTpl,& G( I  L) @+ N7 L
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL9 _) ^* X& `% V2 }* |; t
IN VOID *NotifyContext, OPTIONAL
/ O* x, Q& s. i) L$ d: ]+ iOUT EFI_EVENT *Event1 z: u# c3 n9 k9 _; ?" ~; K* |! o7 z
);  Z* ?1 O1 |' u
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
+ I) p* d4 O. J# }+ t  g( a使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
1 n% `. t% n3 o; q+ M) i5 X谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:
- l1 Y. \6 L$ O9 u+ V4 |如果是Binding Protocol的Driver,在自己的Driver里面
; s2 j1 v* K* c用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
7 b5 P+ N1 Q- T3 b$ @$ r记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
  b: [, q3 s/ o2 _# H/ Z. y在Event的NotifyFunction里面# P# F4 v, b5 A$ j- S+ I+ m" b& j
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles! _! d) a1 X  B  X
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
/ o: _3 W. H' y. A可以Hook到所有后面的driver!!! 2 d3 ^3 z+ v! h5 Z! M  n

8 f4 S; [, |. M4 m9 P4 m+ U回复 13#的帖子
4 p5 s% i+ P* }% F+ s3 |( h在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
6 Y+ m6 p' U* ^6 G/ w: ^
; A% e; w3 Z  K: _% w% Y+ g在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
% [. H" Q. ^7 ]8 U2 n* |xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c/ h- Y$ v7 H8 g3 M2 w$ C; F
CoreLoadImage()-->CoreLoadImageCommon():" d- J# [% Q& A6 X
  //$ E$ x) {- K, \7 {7 g/ k
  //Reinstall loaded image protocol to fire any notifications
* e- d- L2 E  P  P/ B; ~" r  //
; w5 ?# U# b0 ^/ H6 h: A  Status = CoreReinstallProtocolInterface (
5 w* f9 ]& C; T* F7 q  S: i             Image->Handle,( k2 k, ~: K) s8 s
             &gEfiLoadedImageProtocolGuid,
2 q: c0 }5 L2 _3 F, p. v- y( ?             &Image->Info,/ t$ a# h4 C  {1 r( q
             &Image->Info- T$ n2 o7 Z( S1 u" }2 ~
             );9 L; I! w# D: ^' r( A# @/ g

; g) y0 j+ P- o. iFile:Notify.c. }" e( E9 _; q' W" Y
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
: {6 `( Y9 _1 `; w: b% L; xCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表
) v. f: F. F* Z0 E# C6 u$ ^File: Image.c
  r$ w9 c# R0 F% w3 O( L/ z1 HCoreLoadImage()-->CoreLoadImageCommon():( y! f, {; F% O) q% i5 E
  //
0 w2 v5 I4 C: S( U3 L( t. m6 a8 {  //Reinstall loaded image protocol to fire any notifications
# x% W! x9 Z3 J  //
' R9 o& a3 d, g: G. |  Status = CoreReinstallProtocolInterface (
  \( }% I6 b6 L7 x             Image->Handle,
! U; B! y, L+ T, d. W  ...

  u) Q8 n3 t9 U$ c, [- G0 u $ U$ C& ]0 o/ W, q
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
8 U5 \8 R  O" rCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?
! ^/ r. F- w' q$ o3 c% D6 F
" A2 f6 n. s, e6 s[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?3 J& r5 {" l3 S9 p+ Q- ?/ A: S
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-19 04:00 , Processed in 0.031756 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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