|
PIC 、APIC(IOAPIC LAPIC)
( w1 H* l* ~" o1. Overview
5 x, V( D, ~- P* I& D+ C' l% x" g1 V: q
PIC全称Programmable Interrupt Controller,通常是指Intel 8259A双片级联构成的最多支持15个interrupts的中断控制系统。APIC全称Advanced Programmable Interrupt Controller,APIC是为了多核平台而设计的。它由两个部分组成IOAPIC和LAPIC,其中IOAPIC通常位于南桥中: b( g4 l, P5 x0 V8 u w
用于处理桥上的设备所产生的各种中断,LAPIC则是每个CPU都会有一个。IOAPIC通过APICBUS(现在都是通过FSB/QPI)将中断信息分派给每颗CPU的LAPIC,CPU上的LAPIC能够智能的决定是否接受系统总线上传递过来的中断信息,而且它还可以处理Local端中断的pending、nesting、masking,以及IOAPIC于Local CPU的交互处理。$ {0 y; G8 D5 V3 d% c8 @' F7 f
0 `) {: b# Z( O4 O
) S8 ]( Y6 g$ l& h; V
2. PIC1 {8 e' \" p w9 s/ u
% {+ n3 y) t* X' x
基于Intel 80x86的PC使用两片8259A级联的方式组成了可以管理15级中断向量的一个中断系统,下图是它的一个连接示意图。两片8259A,一片为Master,另一片为Slaver。其中Slaver的INT接到Master的IRQ2上。8259A有两种工作模式分别为编程和操作模式。BIOS初始化的时候会先通过IO port对8259A进行编程配置,在此之后8259A就可以响应来自外部设备的中断请求了。Master的IO address是0x20 0x21; Slaver的IO address是0xA0 0xA1。9 ?' [3 G9 [3 @3 x: Q4 N: J
4 W! U2 i3 X2 g0 C( }! e
! n6 i g! ^2 T$ \
|& K9 `/ z- r
2 Y; m0 p8 n I为了能够正常的使用PIC来管理系统中断,就需要对它进行初始化。8259A支持两种类型的命令字,一类是初始化命令字ICW1~4,另一类是操作命令字OCW1~3,其中每一个命令字的各个bit都有其代表的特定意义。下述是一个初始化Master的一个sample code:) h% D: u0 ]9 d' I; i
* {2 @& }" }; F6 K! s
MOV
9 |9 u8 V7 l2 b0 v, G% ?AL,00010001b! l/ p' _6 O2 u2 r
;级联,边沿触发,需要写ICW4; @; J- D$ N5 _! d2 q- D6 o
OUT
n" K3 R, H9 t: A! @) f2 i) {3 ^) ~- u20H,AL
2 i) m* H% f9 b0 p- [;写ICW1
7 F8 X6 a- I$ n8 g* \6 F, }MOV, A# k. j* ]6 i1 {! N7 ]% G
AL,01000000B ;中断类型号40H
9 B, B" I( L QOUT V4 b3 l$ q: K7 H, x$ Q
21H,AL
: I) c' C1 F6 Y( z& n; K! g;写ICW2 T/ F, s1 v/ N* z. ?% R
MOV
; e6 F% ] }8 OAL,00000100B;主片的IR2引脚从片; L/ z. ~" z" v' H9 ]) }# g1 i
OUT8 A5 y r. l5 r& W, L
21H,AL
6 y, X! a! {1 J, C% B9 O+ s$ n$ ?;写ICW3! @6 w* L% ? d0 z" C( ?
MOV
1 k$ m, Z* S9 r- W6 C: k2 hAL,00010001B;特殊完全嵌套,非缓冲,自动结束
/ ~7 Z- ~1 e9 o8 xOUT
+ N0 w0 L& b Q v" \- S21H,AL- `) j; O+ h' @
;写ICW4; e9 S& Y0 A4 i) v$ j
' N' b. r$ E a/ t+ H3. APIC2 b2 O! a' O1 c5 K. g# C( v" q
8 h6 O3 J2 U* f7 vIntel APIC由一组中断输入信号,一个24*64bit的Programmable Redirection Table(PRT),一组register和用于从APIC BUS(FSB/QPI)上传送APIC MSG的部件组成,当南桥的IO device通过IOAPIC的interrupt lines产生interrupt,IOAPIC将根据内部的PRT table格式化成中断请求信息,并将该信息发送给目标CPU的LAPIC,再由LAPIC通知CPU进行处理。下图是一个基于Intel APIC的连接示意图,如下图所示IOAPIC上有24个interrupt pin,
. i, Z4 m. Q! Y8 a每一个pin都对应一个RTE,所以针对每一个interrupt pin都可以单独设定它的mask,触发方式(level,edge trigger),中断管脚的极性,传送方式,传送状态,目的地,中断向量等。4 E8 p8 A& d* @0 a
$ |2 u4 x9 ?& ]; o; D0 y* M3 l
% l. K- L# ] e1 u5 t3 R X9 q5 t
* `& `* I! g: d: S2 b# f
) P `3 S1 ]/ d" \# f* Q: i" XProgrammable Redirection Table详细格式如下所示:# {. R+ g* o9 j* g( J; k7 {
4 z6 E& H ~5 l
Bit Description:% u r- ^! B P8 W( k( b+ r" Z
| [63:56] Destination Field—R/W.
/ X0 e! ]* i' ?- O9 fIf the Destination Mode of this entry is Physical Mode (bit 11=0), bits- B# a4 w; h8 @; @
| [59:56] contain an APIC ID. If Logical Mode is selected (bit 11=1), the Destination Field
+ _" Z' q2 c+ n7 apotentially defines a set of processors. Bits [63:56] of the Destination Field specify the logical) V) u9 C2 d! f+ y t
destination address.
* u7 J$ Z: j( u! bDestination Mode IOREDTBLx[11] Logical Destination Address
: D& g3 {1 v! R3 a0, Physical Mode IOREDTBLx[59:56] = APIC ID
- x4 C r3 H Z6 D( q0 W( X2 Q1, Logical Mode IOREDTBLx[63:56] = Set of processors" y; {% ^) P6 G( ^" a3 m! h
| [55:17] Reserved.82093AA (IOAPIC)
5 F: t& |6 P" O2 ^2 W3 o1 ?. I | [16]+ e2 n! H* e& q7 g- ~
Interrupt Mask—R/W.
( _0 K! n2 q0 e# iWhen this bit is 1, the interrupt signal is masked. Edge-sensitive
6 g1 c+ l7 d* _- S: @8 E) `1 f, Finterrupts signaled on a masked interrupt pin are ignored (i.e., not delivered or held pending).' V0 u4 q7 ]: U/ }% X
Level-asserts or negates occurring on a masked level-sensitive pin are also ignored and have no
$ z8 c! r. O" N# Pside effects. Changing the mask bit from unmasked to masked after the interrupt is accepted by
6 I* K+ P' `. q* m( Na local APIC has no effect on that interrupt. This behavior is identical to the case where the* d0 u6 i4 A7 C# ]
device withdraws the interrupt before that interrupt is posted to the processor. It is software's' h/ f6 E. e) X% U
responsibility to handle the case where the mask bit is set after the interrupt message has been
4 M$ {- V8 S! N% I8 zaccepted by a local APIC unit but before the interrupt is dispensed to the processor. When this
% T8 ]/ g; ^4 u3 P; ~( h7 Bbit is 0, the interrupt is not masked. An edge or level on an interrupt pin that is not masked
; s. s& z) n) xresults in the delivery of the interrupt to the destination.7 s G9 M' {5 [+ z x! H4 x% f
| [15] Trigger Mode—R/W.* d1 R' x' l7 ?
The trigger mode field indicates the type of signal on the interrupt pin that triggers an interrupt. 1=Level sensitive, 0=Edge sensitive.* D1 j& B8 x( ^- G
| [14] Remote IRR—RO.9 h- d- r. P. L9 G7 f( U; S" b* W; V$ J
This bit is used for level triggered interrupts. Its meaning is undefined for edge triggered interrupts. For level triggered interrupts, this bit is set to 1 when local APIC(s) accept the level interrupt sent by the IOAPIC. The Remote IRR bit is set to 0 when an EOI message with a matching interrupt vector is received from a local APIC.
" F3 g& J1 c w2 d8 a | [13] Interrupt Input Pin Polarity (INTPOL)—R/W.7 k6 x9 W: G4 a2 Y2 u) ^0 U
This bit specifies the polarity of the interrupt4 K1 D1 W; \2 {. i5 m$ U
signal. 0=High active, 1=Low active.2 Z3 x7 Z: f+ L8 U, B- s, d1 s
| [12]
% z4 E' L2 Z5 T# cDelivery Status (DELIVS)—RO.
6 X! ]. R+ t/ CThe Delivery Status bit contains the current status of the0 w/ A3 {, m# F2 K) t4 Z7 w5 y
delivery of this interrupt. Delivery Status is read-only and writes to this bit (as part of a 32 bit
6 B* y) J# N* A7 S0 G% fword) do not effect this bit. 0=IDLE (there is currently no activity for this interrupt). 1=Send
5 `" ?' G ~) ?7 M; @Pending (the interrupt has been injected but its delivery is temporarily held up due to the APIC/ Q9 y' d8 z* }, n" ~
bus being busy or the inability of the receiving APIC unit to accept that interrupt at that time).6 m+ t& }. j, N5 \
| [11] Destination Mode (DESTMOD)—R/W.
% w" }% |4 [$ n s \& x. m3 [This field determines the interpretation of the
' i3 @* R z! c0 W0 w( h; _! lDestination field. When DESTMOD=0 (physical mode), a destination APIC is identified by its ID.
0 B1 r* y2 e8 m! w& U4 Y& w, m8 {Bits 56 through 59 of the Destination field specify the 4 bit APIC ID. When DESTMOD=1 (logical mode), destinations are identified by matching on the logical destination under the control of theDestination Format Register and Logical Destination Register in each Local APIC.5 }) ?: t7 I, p
Destination Mode IOREDTBLx[11] Logical Destination Address 0, Physical Mode IOREDTBLx[59:56] = APIC ID1, Logical Mode IOREDTBLx[63:56] = Set of processorsE 82093AA (IOAPIC)
c& m/ B% e, |% W- z9 y2 g | [10:8]Delivery Mode (DELMOD)—R/W.
7 K2 n; s# A. ?9 w; q hThe Delivery Mode is a 3 bit field that specifies how the APICs listed in the destination field should act upon reception of this signal. Note that certain
$ m9 a2 R' g0 {. DDelivery Modes only operate as intended when used in conjunction with a specific trigger Mode.
- |* v( y2 I4 `2 M& Y" t. i. _These restrictions are indicated in the following table for each Delivery Mode.
9 W' [0 }, n/ ^' t: H( k8 UMode Description
6 l) [ H M6 f5 t0005 J) }& G# r o. [* t& j( T7 `
Fixed Deliver the signal on the INTR signal of all processor cores listed in the
2 f* t6 v9 {' J1 D3 P9 a3 F; odestination. Trigger Mode for "fixed" Delivery Mode can be edge or level.2 }) l# X# j7 m; Z9 C2 w& i
0014 g8 c) Z8 a$ c# _3 N3 t7 }, R
Lowest
7 c/ N) e% V5 X: x( T& GPriority Deliver the signal on the INTR signal of the processor core that is
( T& r! r2 U8 c; |5 P! texecuting at the lowest priority among all the processors listed in the! ~- O, r6 w9 l |" C
specified destination. Trigger Mode for "lowest priority". Delivery Mode+ S- d' p( E) O' Y* {) m9 c# y+ t
can be edge or level.0 C6 X9 r/ m. l) q v; K) N7 c( J
010
/ ?! |& R4 S) ^1 m* }* f. {SMI System Management Interrupt. A delivery mode equal to SMI requires an
2 x% K) b }" Q4 F/ Cedge trigger mode. The vector information is ignored but must be
5 ]1 A3 j# D% S7 H: V, E# [programmed to all zeroes for future compatibility.
; O4 H3 \7 H6 D011
- H" h0 ~6 q. Q3 ]6 v" NReserved. T5 S8 X$ z0 G2 k+ @) U( \: r9 a
100
( J* z& o' V3 K8 x6 x8 PNMI Deliver the signal on the NMI signal of all processor cores listed in the
$ t4 T% O4 N; e2 b B% `& B9 idestination. Vector information is ignored. NMI is treated as an edge
5 `1 U' b3 q- M! I1 ?& J1 a6 v2 x0 H. Etriggered interrupt, even if it is programmed as a level triggered interrupt.( N7 t0 W* K; _3 c
For proper operation, this redirection table entry must be programmed to
( Z3 A8 x: [) I& [/ q) U1 e/ |" Q“edge” triggered interrupt.; I6 M/ P- X/ o5 e9 J
101
- h; i- v$ I* r1 z3 hINIT Deliver the signal to all processor cores listed in the destination by
: R: b; f# v" i8 k6 N. K# yasserting the INIT signal. All addressed local APICs will assume their% X+ w6 ^/ F; g& {* w; u( {5 g
INIT state. INIT is always treated as an edge triggered interrupt, even if
3 o$ u# C2 x( Qprogrammed otherwise. For proper operation, this redirection table entry) s# H! V" L: V6 s4 w. s) C2 p
must be programmed to “edge” triggered interrupt.; a1 b# g0 M/ K! Q l7 Z
110, p4 a# i" u- v4 f) C% d9 H1 N
Reserved. x: J2 G( s, D2 P
111
( b" ^' |* |8 DExtINT Deliver the signal to the INTR signal of all processor cores listed in the
# ^# X E8 {# G! o6 W s+ | Wdestination as an interrupt that originated in an externally connected% o Y9 l2 x$ ^0 f4 O7 p
(8259A-compatible) interrupt controller. The INTA cycle that corresponds: F1 t0 _$ ?4 J4 \( v& X$ A
to this ExtINT delivery is routed to the external controller that is expected, |3 s! {: m) y- Q! u
to supply the vector. A Delivery Mode of "ExtINT"
; K6 H5 Z, ~" q& p5 i6 frequires an edge
0 u4 f: z+ c; h) itrigger mode.# m0 K) e# r, K; q5 w2 W3 U5 B1 }: e0 C
| [7:0] Interrupt Vector (INTVEC)—R/W:
% m+ I1 H0 t- _6 y, ?& `2 kThe vector field is an 8 bit field containing the interrupt
- S% n1 f. a- l. r$ Mvector for this interrupt. Vector values range from 10h to FEh.1 W4 @: N- _- n1 s8 r
| . d* [' q) A: A' F5 _" X+ {! z& C
REFF:
6 _" n; J: M0 d8 j4 _0 ^
# [! t# A0 [+ n' _3 M1 {& P( ~1.: c4 x G% Y2 @6 G1 B" g9 |1 ^; J
《82093AA I/O ADVANCED PROGRAMMABLE INTERRUPT CONTROLLER (IOAPIC)》
: e' e4 @! \) f- _2.
0 |. I M) n k; F4 K7 r" O+ p2 o+ B《8259A PROGRAMMABLE INTERRUPT CONTROLLER(8259A/8259A-2)》
, g7 D, z/ o! a5 c L" Y# j3.
`8 ^9 g: l+ @: a《Undocumented PC》( R& U$ t9 n( ?3 p, b: l
4.
$ }* p r5 d+ x* k S8 D* t( |; d) [& v; H
8259A初始化编程
2 L+ f( c) G* {7 U
a+ O' X# n* X, {+ i0 J& r$ BThat’s all! r' B! O- I6 j4 a, @3 |& a
" z4 J1 A( u5 ^" Q1 p- \* l
Peter
* S8 B4 |9 D% x, Z* e% g* ~, h; p: @; G& R% Q
2010/10/07
- C6 l# O# M( Y0 r( w
: U! }5 p# K/ o- R Y# M[ 本帖最后由 peterhu 于 2010-10-29 16:13 编辑 ] |
|