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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,/ ]4 H* ~9 y$ D& t' {
一直都不怎么理解为什么要做出Event这样的一个机制?! I7 a& {7 j2 C0 M( G9 l

% I1 |7 w* E5 Z% K2 i1 V8 GTimer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???)
% \3 a2 Q) z0 |1 b4 ~Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;5 L# S9 `+ _" b3 d
还有Group类型的Event,用于处理具有相同类型的事件
, ~/ H5 H$ l4 ]+ |2 P' C. F一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
$ `: N7 T; W  e4 u9 J- b$ T# }# d这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
1 {6 K5 k* }  {1 O5 N4 p; W/ _不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.+ _! Z3 V% S" I% G# y& g4 f
因为我看到有很多地方有RestoreTPL,很频繁地,
, R( A4 r# e( i% l0 Z  Q+ C所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
( A' i# C% I' s' o' F- K! c5 ]) j4 g! T' t7 s9 K
TPL的控制,
" u! a9 D* {1 w3 u' Z- U, z我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)
+ ]; p) Q' q$ v& K. [不想被一般的事件打断时就会RaiseTPL来处理,( V- k+ g- C  L$ D  u% X$ S9 \- h6 Y6 d
处理完,就会RestoreTPL了,
1 Z& Y4 a( j/ H  Q" 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 G0 G3 v, o$ q& p( R+ C6 @! R& Y, X- h" o4 \
我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)& }' q2 R0 \% ?) ~8 ^0 e
所以,就可以"认为":
9 T0 L' X. A1 h7 M) v% }       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
" s/ z4 V) {3 l0 v3 O  \$ e: i$ O: h) ~' z1 o- P
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。 1 V1 {4 `4 B) m: D, j5 Z# E

) n. j2 ^" \2 ]- L" K我个人理解,每次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属性。/ c+ L+ C3 q( Y, ]5 H7 f" R  {
typedef
+ k  Y$ y, K; v& |9 e' {3 REFI_STATUS; y, ^3 p! ~6 k/ I1 f
CreateEvent (
' v0 m9 X* D" u# D+ S$ p+ \IN UINT32 Type,
% Z, \# ~$ R5 O) Q0 s4 T8 T) LIN EFI_TPL NotifyTpl," X6 i" i: X% X& Q9 X5 }
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL1 k+ J2 u- Z, p) _' P  K
IN VOID *NotifyContext, OPTIONAL, \- Y! O3 F& r% j* [0 o- y  G  x
OUT EFI_EVENT *Event: N- K! L$ ?5 e8 w( D6 I" w: Y' W
);& ^' d" \7 t" C( y: ~
中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
4 s" l. T' V3 C1 U使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
% D- U/ I, C+ _谢谢!
回复

使用道具 举报

发表于 2008-9-8 12:36:40 | 显示全部楼层
我写了个Driver,主要的工作就是当他之后执行的Driver被Load但没start前通知此driver。
7 _' ~" W+ o  R) g0 K5 iNotify TPL是EFI_TPL_CALLBACK,这里只要比EFI_TPL_APPLICATION大就可以了,因为driver的TPL是EFI_TPL_APPLICATION。
9 ~2 l/ ^% Q) H& _* j我在使用Notify Signal Event时的问题主要是有时候必须修改EDK本身的代码,我想了好久都没有别的好办法。大家看看有什么好办法既能通知事件的发生又不做代码改动呢?
回复

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:6 @* V5 j4 E$ }! X% ]0 Z1 y# p6 ]
如果是Binding Protocol的Driver,在自己的Driver里面! n' q# {2 u& a
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)9 e: x; f7 I1 T0 I
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,0 l) H3 e# d! N
在Event的NotifyFunction里面. t! {; f; Z& {! u) M. f$ f
还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles
% Z+ Z# o- w$ j! c' ~6 O) K& J这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!+ q: ?- c0 D- j0 m+ p  }6 @6 T
可以Hook到所有后面的driver!!! 7 b' a3 `1 M- p1 s7 o9 u

1 T3 I( r- {+ O: \2 [回复 13#的帖子
9 N+ {$ t7 N* i2 S" J在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
- L; L. j: `- Z6 C# A: ?$ T% d# Q! o1 Y) q: i& U: z5 W! `
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加# Q' l9 e0 B1 Z8 U
xtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c
) G# ?4 Z2 L/ m, O$ K- E  vCoreLoadImage()-->CoreLoadImageCommon():
) @! C+ W- Q0 m. R7 W1 }  //
" k$ W6 s) A+ j) c9 ~. s  //Reinstall loaded image protocol to fire any notifications
3 H9 |* W+ K  e8 l. N/ b) J  //
; z3 C& j) G* i6 s9 S  Status = CoreReinstallProtocolInterface (
$ D; Q8 _! y  p# [0 W& z8 M             Image->Handle,
/ m) X4 ~! T/ w             &gEfiLoadedImageProtocolGuid,
: y1 x* @- S; _) b* F' d4 o             &Image->Info,. @" o6 ^  e2 `$ W
             &Image->Info4 M! T; ]3 j" A! C  J2 D+ m
             );8 K5 o# Q3 ^+ |# N. ]

8 s' \- g' Q3 Q+ a, e. ]5 S8 MFile:Notify.c; Q9 C: v. r% T- }
CoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()
7 H" }. d; _% v, ~5 f/ vCoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 8 M# r' W5 a0 v5 E/ F/ l, v
File: Image.c" @# |( G8 R4 V  l
CoreLoadImage()-->CoreLoadImageCommon():+ x' [$ ]& U% {2 b6 f# @
  //( A5 S8 K5 Z8 s# J
  //Reinstall loaded image protocol to fire any notifications
7 }- d9 D/ R4 I  n7 S4 f; \! k  //2 ^3 D, Z# z2 b8 I0 z! f( L
  Status = CoreReinstallProtocolInterface (
4 O: J6 {) a* f8 A' p( r             Image->Handle,
2 h# a# K" |( J: g* o1 m& t  ...

* d! _7 P4 H# ?) Q1 O1 @7 } " p6 H5 u# E" I7 n# e
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:
, Z; s8 @/ `; F$ D6 LCoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?4 Q, k. \/ f5 t9 B8 i4 [

/ I5 K5 I" S, l* D1 @, l! C[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?
6 V) \% |1 Y: c谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-29 05:02 , Processed in 0.066012 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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