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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,) X2 ~: S! l, q2 |% }: U: w) |. j
一直都不怎么理解为什么要做出Event这样的一个机制?
) Y$ F1 T/ }# a2 O; q8 D
+ L+ G, m' U3 Y8 u5 BTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)! b1 }' ]8 {' X. n" A2 c) ?: ~
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;6 @* C7 h. V, r; V  B
还有Group类型的Event,用于处理具有相同类型的事件0 `4 g, P- [4 V% c8 z0 E1 ?
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
& c  ?. N" J' ?1 a, j6 `* m" R这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
# `7 y+ p; j$ [) {, R' R7 V6 G不知道各位对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 m7 q% o: K+ e, S: C6 f2 h因为我看到有很多地方有RestoreTPL,很频繁地,
" t$ w! j! b3 d8 b所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?% N+ X  e- b1 q% d
6 C6 t7 v( ?3 @- R. M# b
TPL的控制,
2 G! @3 V. z2 }& y( }1 }3 T+ J我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
- e/ b9 i/ ]( F5 r不想被一般的事件打断时就会RaiseTPL来处理,
9 O- I& o! U& j2 [/ c3 A/ P) e处理完,就会RestoreTPL了,
: v5 l% i& d5 k- h) O当然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.
& F# _: D. X; _# R. s( F' E# i
2 o4 L3 G9 T% h6 K5 ?1 G* h我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
4 q7 q1 C; ]$ W: I4 e. Y- i所以,就可以"认为":7 v1 n- }4 M7 m, v3 c* a6 _0 N6 @
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。! H% u8 E. e3 L0 \) W; i

+ |: d, D' A& f0 e# F$ H7 g而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 + v/ U! p7 U; ?; \8 w3 s! @) x6 Z

; P/ c4 `% {" ~) G& }4 |我个人理解,每次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 [; ?" `4 Q1 I& {$ Z# u( A! _! E' Z
typedef
) G+ a1 n; ~! O/ q2 GEFI_STATUS
! u5 A! e5 l/ v+ V& N  WCreateEvent (5 G, K( E7 u9 x  P( G) y
IN UINT32 Type,: b6 x5 X1 \1 Z' K( q
IN EFI_TPL NotifyTpl,
* Z; ?& `( G: w( u/ hIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL$ O" ]1 a& L& s4 o
IN VOID *NotifyContext, OPTIONAL
/ `& I3 k' u& q. ZOUT EFI_EVENT *Event
$ M: f; w  q; B% b);
  c& M2 ?! g3 i8 `# B/ ]中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。3 D. O' e1 W6 T4 `5 {
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?: t' [* x7 H& R) d  r- p' f  r
谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:: Q3 l9 o3 `+ R9 t. z6 w% x1 z* J
如果是Binding Protocol的Driver,在自己的Driver里面
" [5 U) g% v; W3 I$ F用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
8 e2 n2 z; x4 ]4 _8 w1 O( j记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,& Z$ M% l7 d" s; i) D
在Event的NotifyFunction里面/ E% j/ B! b1 n2 K
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles4 I" F: E# y8 W0 T4 q7 l5 _; O
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!
7 p% k* D# n/ u8 A可以Hook到所有后面的driver!!!
' q2 e2 E  t: |7 @$ b
% v4 g3 D1 S! ]. m+ m' @回复 13#的帖子
% M+ Y% V$ }% J: E' |8 @2 u在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~5 {4 l+ Q$ w. C$ T
- m% A; V- K* t% M2 P! v
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
, w7 _& Q" c& Sxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
2 G1 z* v+ \5 U/ bCoreLoadImage()-->CoreLoadImageCommon():0 _* T( }! I6 a! |& _) H0 ^3 L
  //
6 w9 n; M1 x, I/ o! u+ v! X# E2 W  //Reinstall loaded image protocol to fire any notifications
) E& a: s/ A9 u' O) t  `  //1 N2 d0 D/ y  }# K4 a: \
  Status = CoreReinstallProtocolInterface (
+ d; a7 c& _8 [1 U             Image->Handle,8 l4 d% a) _" f: y' X
             &gEfiLoadedImageProtocolGuid,
2 q1 U# ]8 y4 `$ Y+ P             &Image->Info,
3 b' u. n( X; R  Q( I5 k             &Image->Info
6 l& v- D+ y% E             );
1 z1 H7 M; d9 H" Z& C6 ]4 [7 k; W  v! \+ Y" r: l, Q2 f  e
File:Notify.c6 o/ f( b* V  j2 B$ y) L
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()" F2 C, F0 ]. ?2 v7 s; c
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 $ m& D* ]+ ^# q. N( J1 O
File: Image.c% D/ m3 H1 B# r2 ^
CoreLoadImage()-->CoreLoadImageCommon():, x& ?" I! a6 S
  //- j- }$ f4 h" W) H2 ^
  //Reinstall loaded image protocol to fire any notifications
- f9 I9 F7 ?. S. |  //. p: A0 F: ]8 b3 Z
  Status = CoreReinstallProtocolInterface (
1 E/ l7 O' g+ X, O0 ]             Image->Handle,
, P+ H2 ~7 l) H; J# F+ \  ...
6 {8 x  G. ?& ~5 R* _8 _4 \
3 G; i$ k! I8 N5 r. R2 J
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
( q% C+ |# V' PCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?; z3 K; O4 @: r5 Z( o
( `; o' ^+ S& w) P" k9 A; R
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?7 W  [% S0 F! e( B) R
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-17 15:19 , Processed in 0.042784 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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