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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,
: C$ t, P, a' Y# \& r+ y一直都不怎么理解为什么要做出Event这样的一个机制?
4 r* K3 @( R" N$ r
0 ~4 v9 v; g0 r/ `; T5 x0 t) C* tTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)% V8 ^* G4 V  g6 y& e
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
' h- g  C* d  P4 D. `4 v还有Group类型的Event,用于处理具有相同类型的事件
; u% K6 o) d  j) P2 I  ?' v7 K一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
3 `3 ?- H, v$ r5 V这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,/ o% c  D# d7 R4 g$ h, S
不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.* K+ b0 u) l" U' T6 a9 S
因为我看到有很多地方有RestoreTPL,很频繁地,
( o, A, B! X, L+ C' p( _4 p所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?/ l4 D) _( c  `* i: K- M! B% u6 `
/ L. J& O5 z) n8 W
TPL的控制,
  d$ a: z" k! Q9 i我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)3 H9 r5 H2 ^2 g* S
不想被一般的事件打断时就会RaiseTPL来处理,
3 }. |# y( m1 C处理完,就会RestoreTPL了,
" D# n, |1 S8 T( X# O( 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.& k. i5 r4 D' m
5 R% {, t! ?( e0 Z  m
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)% \+ M% R, D! A9 Q6 W8 B' n8 f& D. t
所以,就可以"认为":
0 G6 H4 ?. r7 w- A! V  N' @8 Q       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。. d. J: A) j1 ~

  ]# E$ n8 s: m. Q而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 ' D/ V. c% Z4 l5 H0 r

: r# A4 M" T' G7 S. F我个人理解,每次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属性。( _4 H( ~* u& L9 O7 i
typedef
) e0 M/ f7 h" D; aEFI_STATUS
- `, g& I% y0 ?+ ]; p# u) @2 eCreateEvent (6 s% U: ^% J+ ?% G) A7 Y. _
IN UINT32 Type,( J! B( f; s: C4 j
IN EFI_TPL NotifyTpl,, b$ J6 G$ K' H( a. o/ k5 o
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL8 ^/ J6 O3 J# ~
IN VOID *NotifyContext, OPTIONAL5 Z) q5 |; ]+ z! b/ k
OUT EFI_EVENT *Event3 i- a" V# y4 m' G2 c' j
);4 M1 i0 N3 b; w# F
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。' C. N1 z" w* p( Z9 v
使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?. x; u7 V% F; e7 y4 O
谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
+ N& E9 W5 V  W) H9 _Notify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
9 O3 J! f9 \  U( `) z我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:7 C  T; L; P: D+ S
如果是Binding Protocol的Driver,在自己的Driver里面
, w0 A0 j7 d9 d8 J2 R用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)
5 r5 J0 f6 P# N  ~7 h& G记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
: w1 D2 U# B" I6 z: j5 b( F在Event的NotifyFunction里面
+ w& K* O: O9 }3 |" e2 m4 \# d" q7 }还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
* w2 ~5 W9 ^- r- Q1 V这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!/ ]2 o8 ~, q$ E1 R' c% x4 B
可以Hook到所有后面的driver!!!
/ I6 r# L. W. m6 l) p* Y. H: W8 X, H" I
回复 13#的帖子  h3 B5 F7 A% y
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~4 {( }+ u% D! ]& C$ }* {  T: U
/ }, w" N8 W1 h
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
; v3 A  D4 U0 Yxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
! u( l( n' v; ^. [& {% C8 Z! OCoreLoadImage()-->CoreLoadImageCommon():! N0 W/ `2 O, h1 G, {( v
  //8 B  r& P" f0 x5 Y  V
  //Reinstall loaded image protocol to fire any notifications' V. I  {  N* _
  //' y+ |, S4 r1 r+ u5 Z) g5 v
  Status = CoreReinstallProtocolInterface (9 D5 e1 ]% C- o: S4 a& i- W( ~
             Image->Handle,% ^% G" i& D3 O. ^* w) M0 Q
             &gEfiLoadedImageProtocolGuid,# z0 p1 T! I  i" h3 n9 j$ l1 N7 P
             &Image->Info,) X3 r! s. n1 @4 n3 E; \: v8 r
             &Image->Info
; t( b: t9 @+ u8 u. |             );
5 j0 F; I) D, h  H5 j. n9 F5 F+ h8 t: \
File:Notify.c1 W; H, T. S# D# W5 |# I- H7 i6 b
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
) e! W6 _% a& y# f% Z* _7 @CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 6 R# [$ r0 z2 V; H, s
File: Image.c" K1 b4 C: |: I0 V* z
CoreLoadImage()-->CoreLoadImageCommon():1 |9 N# ?% \$ f# j7 ]9 G2 Z
  //: R* D6 A. Y* Y" N7 b, M
  //Reinstall loaded image protocol to fire any notifications4 X! t) r% b, y$ y
  //
$ Z$ t" K  e# ]' |, K* n  Status = CoreReinstallProtocolInterface (
- l  _( b' q  ~1 b: E             Image->Handle,- C6 I; L+ g! p9 Y7 B9 c# S1 v
  ...

5 Z/ B' w# J  Q+ e7 V+ Z) F3 J  K 0 n& U% B5 b) u3 j7 u1 y( e1 c' ~
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
" i  C8 U6 {- m+ I1 YCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?* u- i: b9 R& q& @' n8 q

& N* t  g7 E3 Q# Z# x4 B- ^8 _[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
" |' m2 v# W5 a* p' @# C谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-17 01:52 , Processed in 0.067804 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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