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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
4 o9 R7 a8 ^6 r# B; @- C一直都不怎么理解为什么要做出Event这样的一个机制?9 e/ S1 f0 P" {" M$ Z3 b1 Q# f! T

0 K9 E6 y( m6 }' v3 j4 R2 `0 N2 MTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
* D1 S! z4 x8 [- t: u- b7 M+ ?Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;9 z1 }! i- ^$ G- |/ `: i
还有Group类型的Event,用于处理具有相同类型的事件- C8 N. ~4 J. v: ?+ U
一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
) E7 h2 z4 {- E! i* K* D( \这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
, i0 J1 H( [8 }+ v4 [& N1 p不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event., C/ A; Z6 h- u4 g" S6 Q, X( u
因为我看到有很多地方有RestoreTPL,很频繁地,  k+ i0 V5 C  S8 J+ o2 Q% N$ x
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
: A/ V& r* H: b
2 O- I) }8 I! ?( y( a. t$ N( RTPL的控制,+ w) v% E% Z* b" |% s+ B4 y
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)+ W- r( r4 [) I3 w
不想被一般的事件打断时就会RaiseTPL来处理,+ @2 P5 e8 v0 Z4 j
处理完,就会RestoreTPL了,. L' L' b& D1 S: ?& R1 q& p
当然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.7 y4 d6 Q3 F. w$ X, K1 i' f
! _5 g1 }; r& k. [
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
8 L/ |, v3 L& [! k所以,就可以"认为":" n# t5 b/ `) u0 |' V
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。) X( @" R! f) K6 u, v) {

4 H$ n* p( z8 q. Q而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。
% ^# |# z/ I$ M# ?, j/ w
  z5 O5 N0 P; I, {) n我个人理解,每次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 K& s3 _; Z8 ]typedef
4 y0 {0 p* F2 k% b2 \EFI_STATUS
* `' H" {9 W+ V) cCreateEvent (" F$ n" e' A5 E
IN UINT32 Type,; q3 x8 u8 @4 h
IN EFI_TPL NotifyTpl,
9 {9 J4 I  W# \' k+ f% u! K4 Q! CIN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
, ]. [- w" L' I. ~$ b9 BIN VOID *NotifyContext, OPTIONAL8 [' k' }/ v& s! @0 |; O& m
OUT EFI_EVENT *Event
, ~$ u$ m+ q; m1 M- [6 Y);
# F3 N8 ]. Q' T6 q1 g# C' V中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
. w* R5 M0 g* y2 P* e2 x6 I- T使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?8 G* S1 ^8 J" X9 u
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。; }4 z% K0 ~" ?% ]. P" _7 ?: o
Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
  z7 K6 U5 S% v3 U3 y# O; n9 Q  v  A我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:5 c+ E! I  l4 X0 @) w* Z3 O3 z
如果是Binding Protocol的Driver,在自己的Driver里面
- [8 A( D5 q) V6 @* D* d用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)6 [- ]2 |- O$ p. q7 U" q
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
; E7 }6 h- w( g- w" E4 I在Event的NotifyFunction里面
2 P/ G8 b2 N* D: f- b还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
& i- E& Q1 e  f" M  l: y这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!9 w" O8 z" I2 m3 w
可以Hook到所有后面的driver!!!
0 ^+ q. `. t/ I' u7 Y& @# e# ^4 T  G' e6 g: l
回复 13#的帖子
; Q5 {8 g  u2 o$ B: h. Z在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
; B% k6 j, Q( M! |: E. L: {$ \1 P7 G7 C( F/ M' d
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加, G/ S# c+ F8 y4 C" K
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
) z! @$ \" L) O" `CoreLoadImage()-->CoreLoadImageCommon():8 a7 j! ^0 n6 {% @) r( ?) \: x8 L+ L6 C
  //* k# ]8 T/ R; p9 w/ t# Y
  //Reinstall loaded image protocol to fire any notifications
; \- {$ W7 D6 ~6 F! }! c( r7 a  //
: m# I5 d: a" s( i" }3 w  Status = CoreReinstallProtocolInterface (
) `: g' }+ j- P9 m8 u$ L             Image->Handle,
/ z2 G1 n% J3 D  p" x* F             &gEfiLoadedImageProtocolGuid,8 d4 ?, L" U- J6 V% T  \. [
             &Image->Info,- ]7 p8 y% p9 w! s# O% y9 o/ q! L6 B
             &Image->Info
) o+ Y4 W# C% H) y             );
# j4 L/ r8 T0 O- R2 z* q- K0 h! ?' J' p- n9 V" b
File:Notify.c
  K8 r; ~- j) T( T% S- u5 \CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()5 G% y5 |  w, A- q3 @; U
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 0 y0 k" B- R) r% U; q0 r$ K$ O2 ~
File: Image.c
$ J# U  g' K8 i/ I) O9 [0 ?CoreLoadImage()-->CoreLoadImageCommon():
0 G+ x- q8 u7 i6 U$ q* t2 n1 ~2 r  //) [/ k* @5 E6 b- I
  //Reinstall loaded image protocol to fire any notifications* Y7 I; F$ M7 M. v
  //
4 ~' }  G# \; ]$ q- N. H# m7 t  Status = CoreReinstallProtocolInterface (1 P2 y; u, `3 C, R
             Image->Handle,
: O2 s% x8 ~* R1 y+ r* C; r  ...

" Q! s- ]$ G6 J# F
3 S5 N. a, ~0 d; e) t7 c感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:2 r/ e$ G" f: _- A& Z9 v9 ?
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?, ]0 x+ Q; o+ D0 p% r4 V9 X( n2 ]

9 y% }! G5 \9 t5 q! z[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
  D9 Q5 M; t/ p谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-14 21:41 , Processed in 0.044071 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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