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

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

[复制链接]
发表于 2008-9-2 14:45:45 | 显示全部楼层 |阅读模式
在UEFI的spec中,有定义event,timer和task priority Services,0 ]( k0 ~- D# D  ?: W' d: T
一直都不怎么理解为什么要做出Event这样的一个机制?
  _0 y4 [  U& @' N1 P4 ?$ `6 p$ Q) _' r. a6 d0 g
Timer类型的Event,用于定时或者周期性的事件处理,比较准时的,(代替中断???). e; K5 b6 x  [" u/ [. Q. Z2 Z
Wait类型的Event,应该算是查询或者等待事件的处理,如等待Keyboard和Mouse的输入,感觉像轮询;
6 ~0 l  U5 O, l' L3 \6 y8 _还有Group类型的Event,用于处理具有相同类型的事件
9 A9 h6 V5 k6 X一般的Signal的事件,目前就知道有Install Protocol的Callback功能,像PEI的Notify(Callback和Dispatch)
5 J( k" {5 J. |这些是我看Spec和Code的理解,感觉还是没有看懂,没有抓住实质,
8 v) W; P' A( ]! X, `不知道各位对Event有什么样的理解??
发表于 2008-9-3 11:58:02 | 显示全部楼层

回复 1# 的帖子

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

使用道具 举报

 楼主| 发表于 2008-9-3 12:49:50 | 显示全部楼层
嗯,只有在RestoreTPL的时候才去处理所有pending的event.
& {1 b, A/ @5 e% Y" k/ g因为我看到有很多地方有RestoreTPL,很频繁地,: G+ M0 c0 \8 L/ {4 f
所以只要我们Signal了Event,那么这个Event马上就会被Dispatch了吧?
2 ^6 \& v0 F! B3 |. n
. ]; {+ N+ ?' R$ F& s( v- sTPL的控制,( r1 c* s9 \( Q3 p6 m& i" ?
我觉得是,当比较关键的事情要处理,(如用于处理独占操作的,不能被打断的等)! X' [- P6 M0 o) b/ S% D
不想被一般的事件打断时就会RaiseTPL来处理,
3 M2 ?! e7 W( a4 N( w# ]处理完,就会RestoreTPL了,
0 b. K* d) w) S8 \! Y1 u# M3 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., M  {  f% D) ?: B

4 w* e6 F5 F2 {6 m4 |我的意思是RestoreTPL这个被很频繁的调用,而且一般的Event(callback,notify)的TPL都>当前的TPL(driver=6)
7 ?. D, O% d" X所以,就可以"认为":) f/ R5 A, e. L4 c- I) |$ [8 K6 }
       "只要我们Signal了Event,那么这个Event马上就会被Dispatch了"
回复

使用道具 举报

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

回复 5# 的帖子

我想应该跟ring0到3类似,都是逻辑上对顺序的控制,况且32个好像也没有全用,估计用了一半吧,我猜的。
  ]9 e+ h! n( g- D& G7 x: c  ^  E
而且restore调用应该不是很多吧,如果你signal一个就restore一个,那样设计这套代码的人也。。。。。。   r. f; T- m- g* o& z" B

0 |! [4 ]2 f% P5 G我个人理解,每次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属性。
1 ?0 V" D% w. p  L4 Rtypedef& f$ g+ J, ^6 t+ \! X
EFI_STATUS
3 e, ?# Z8 z( W" H1 Y, \8 ZCreateEvent (3 i2 h, v. C: P- i+ E+ E: e
IN UINT32 Type,; @6 k2 e' N  i* x, J, e
IN EFI_TPL NotifyTpl," f+ D9 r$ r( c+ e" z$ H
IN EFI_EVENT_NOTIFY NotifyFunction, OPTIONAL
7 W$ @7 k. `" s$ ~9 X# j$ [IN VOID *NotifyContext, OPTIONAL
; y5 a- k% b5 H7 g  |( C8 X9 jOUT EFI_EVENT *Event; c% B* z  E+ @" `; w9 Q
);
- h" j% I! W% O! ]- I- T; q中NotifyTpl的作用就是让NotifyFunction在NotifyTpl设定的level上工作,这样如果CreateEvent 是EVT_NOTIFY_SIGNAL的属性,那么在调用SignalEvent()后,只要当前TPL Level小于CreateEvent 的NotifyTpl,就会触发EVENT。
/ \) }2 Y9 m) K/ q) E4 N使用EVT_NOTIFY_SIGNAL只是EVENT的一种方式。
回复

使用道具 举报

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

回复 9# 的帖子

可以请问一下,你自己建立Notify Signal Event 来做什么吗?或者 Notify TPL是多少?
4 j( N+ A3 L. c8 `/ [谢谢!
回复

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2008-9-9 17:06:50 | 显示全部楼层
一个想法:% V+ ?; }" m" v
如果是Binding Protocol的Driver,在自己的Driver里面6 }6 }% e' z5 V, i. T& ?
用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)$ c* z; q2 H3 j% _. g( ]
记录下当前的BindingHandles,然后在InstallProtocol  gEfiDriverBindingProtocolGuid上面挂一个Event,
6 ?) Z$ y/ _8 P1 S2 `2 L' C8 i在Event的NotifyFunction里面
- O, [. n. f: ^8 v. ^# f还是用LocateHandle(AllHandles,gEfiDriverBindingProtocolGuid,...)得到此时的BindingHandles" Q6 H! O3 _0 e" g% W" x! U$ {
这样应该可以在Load新的driver时,SignalEvent并得到新load的driver的BindingHandle了
回复

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

回复 14#的帖子

你的方法很好!8 o# I4 t. i" K, n5 G; {
可以Hook到所有后面的driver!!! 7 t! b2 N. C/ B& W( E
# S0 t( e5 z# w0 W
回复 13#的帖子
% v+ F0 t, F. }4 w在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
回复

使用道具 举报

发表于 2008-9-16 09:30:22 | 显示全部楼层
srcore的rigister是个好办法呀~
6 x0 g. i* }+ x1 O. [; \8 `4 e3 q* V/ H9 [# T
在LoadImage中,会SignalEvent和RestoreTPL的,所以应该不用自己加
; i" {0 y8 R  \3 v9 R- Vxtdumpling 我在代码中找了一下 没有发现LoadImage中SignalEvent的codes 能说下在哪个位置吗?谢啦。
回复

使用道具 举报

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

回16#

File: Image.c: s' J" K0 X+ ^* Z
CoreLoadImage()-->CoreLoadImageCommon():: ]3 m! Y) ?6 _# ^
  //
5 b( E6 C$ l! z% C) v  //Reinstall loaded image protocol to fire any notifications( d  V9 X( |" y5 s! k0 i7 Y
  //! ]! R1 u1 ^# a5 N# w1 e
  Status = CoreReinstallProtocolInterface (
% z4 H/ ]7 k' w             Image->Handle,
) e( l- p0 ^* K, W7 Q1 J             &gEfiLoadedImageProtocolGuid,% T! ~% H3 O/ K2 {
             &Image->Info,' l6 j% \+ {- L3 G+ m' `
             &Image->Info$ ]5 G. o: K1 k
             );
; H9 i( Z* ^* a& F: @2 b' s- S  K! x' F# ?0 Y; P
File:Notify.c
: U4 |. t& `9 r4 v8 i9 BCoreReinstallProtocolInterface()-->CoreNotifyProtocolEntry()-->CoreSignalEvent()# p6 F2 Y4 x8 _- R& V8 Z5 j
CoreReinstallProtocolInterface()-->CoreReleaseProtocolLock()-->CoreReleaseLock()-->CoreRestoreTpl()
回复

使用道具 举报

发表于 2008-9-16 11:28:43 | 显示全部楼层
原帖由 xtdumpling 于 2008-9-16 11:01 发表 . L) e% Y9 g6 o( l- s6 t' T
File: Image.c) o2 Z) b; X7 |( e+ q4 G+ H+ t3 s
CoreLoadImage()-->CoreLoadImageCommon():
) H* e8 s4 E" p' s  //) D" Q8 c; N' f/ f8 a# S# ^5 N
  //Reinstall loaded image protocol to fire any notifications
* w" x' V, C6 E  //
0 f+ I$ N: ?  Y1 L& \0 N  Status = CoreReinstallProtocolInterface (
- m9 }) _/ w( H9 l             Image->Handle,, E/ ^& a- Z  J; i. ^# l
  ...

' a+ {/ O' ?3 P3 |: a8 K0 j3 R ; L$ {, ]3 d$ E. R0 {! A
感谢xtdumpling~!
回复

使用道具 举报

发表于 2008-9-16 12:08:01 | 显示全部楼层
有个新问题:0 c* L- q# H) B+ D
CoreSignalEvent()确实能通知Image被load了,但是如果要在自己的Driver中使用该Event,MS不行吧,要么还得改CreateEvent的事件函数? 好像还是不能不修改EDK的代码?xtdumpling有什么高见?7 x7 E' \$ _0 x& g  m
, O( i/ J. c- @. F$ j) {) h
[ 本帖最后由 lisen4 于 2008-9-16 12:12 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2008-9-16 13:34:56 | 显示全部楼层
请楼上的兄弟分析下BS的RegisterProtocolNotify也就是CoreRegisterProtocolNotify是做什么用的?4 O$ r- o5 D1 K0 g! e" p
谢谢!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-2 15:44 , Processed in 0.050437 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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