WDP 0 WDP 1
17. EXTINT - 外部割り込み (External Interrupts)
外部割り込みはINTピンまたはPCINTピンの何れかによって起動されます。許可したなら、例えINTピンまたはPCINTピンが出力として設 定されても、割り込みが起動することに注目してください。この特徴はソフトウェア割り込みを生成する方法を提供します。
PCI2ピン変化割り込みは許可したPCINT16~23の何れかが切り替わると起動します。PCI1ピン変化割り込みは許可したPCINT8~14 の何れかが切り替わると起動します。PCI0ピン変化割り込みは許可したPCINT0~7の何れかが切り替わると起動します。ピン変化割り 込みn群許可レジスタ(PCMSK0,PCMSK1,PCMSK2)は、どのピンがピン変化割り込み要因となるかを制御します。PCINTnでのピン変化割 り込みは非同期に検知されます。これはそれらの割り込みがアイドル動作以外の休止形態からもデバイスを起動するのに使用できること を意味します。
INT割り込みは上昇端または下降端(含む両端)、またはLowレベルによって起動できます。これは外部割り込み制御レジスタA(EICRA) の詳述で示されるように構成設定されます。INT割り込みがレベル起動として設定、且つ許可されると、そのピンがLowに保持される限 り、割り込みは(継続的に)起動します。INTの上昇端や下降端割り込みの認知はI/Oクロックの存在を必要とすることに注意してくださ い。INTのLowレベル割り込みは非同期に検知されます。これはこの割り込みがアイドル動作以外の休止形態からもデバイスを起動するの に使用できることを意味します。I/Oクロックはアイドル動作を除く全休止形態で停止されます。
注: レベル起動割り込みがパワーダウン動作からの起動に使用される場合、この必要としたレベルはレベル割り込みを起動する完全な起動 復帰のため、MCUに対して充分長く保持されなければならないことに注意してください。このレベルが起動時間の最後に先立って 消滅すると、MCUは今まで通り起動しますが、割り込みが生成されません。起動時間はSUTとCKSELのヒューズで定義されます。
関連リンク 28頁の「システム クロックとクロック選択」
17.1. ピン変化割り込みタイミング
ピン変化割り込みの例は下図で示されます。
図17-1. ピン変化割り込みタイミング PCINTn
clk
本数分合成
Q D E
Q D
~
PCMSKmの PCINTn Q
D D Q D Q PCIFm
A B C
D E
PCINTn A: ラッチ B: 遅延 C: 変化 D: 遅延 E: 遅延
clk
PCIFm
17.2. 外部割り込み用レジスタ
17.2.1. EICRA - 外部割り込み制御レジスタA (External Interrupt Control Register A) 外部割り込み制御レジスタAは割り込み条件制御ビットを含みます。
名称 : EICRA 変位 : $69 リセット : $00 特質 :
-- - - - ISC11,0 ISC01,0
7 6 5 4 3 2 1 0
ビット
R/W R/W
R/W R/W
R R
R R
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット3,2 - ISC11,0 : 外部割り込み1条件制御 (Interrupt Sense Control 1) 外部割り込み1はステータス レジスタ(SREG)の全割り込み許可(I)ビットと外部割り 込み許可レジスタ(EIMSK)の外部割り込み1許可(INT1)ビットが設定(1)される場 合のINT1外部ピンによって活性(有効)にされます。割り込みを活性にする外 部INT1ピンのエッジとレベルは右表で定義されます。INT1ピンの値はエッジ検出 に先立って採取されています。エッジまたは論理変化割り込みが選択される 場合、1クロック周期よりも長く留まるパルスは割り込みを生成します。より短いパ ルスは割り込みの発生が保証されません。Lowレベル割り込みが選択される場 合、そのLowレベルは割り込みを生成するために現在実行している命令の完 了まで保たれなければなりません。
表17-1. 外部割り込み1(INT1)割り込み条件
ISC11 割り込み発生条件
0 INT1ピンがLowレベルで発生。
INT1ピンの論理変化(両端)。
1 INT1ピンの下降端で発生。
INT1ピンの上昇端で発生。
ISC10
0 1
0 1 0 1
● ビット1,0 - ISC01,0 : 外部割り込み0条件制御 (Interrupt Sense Control 0) 外部割り込み0はステータス レジスタ(SREG)の全割り込み許可(I)ビットと外部割り 込み許可レジスタ(EIMSK)の外部割り込み0許可(INT0)ビットが設定(1)される場 合のINT0外部ピンによって活性(有効)にされます。割り込みを活性にする外 部INT0ピンのエッジとレベルは右表で定義されます。INT0ピンの値はエッジ検出 に先立って採取されています。エッジまたは論理変化割り込みが選択される 場合、1クロック周期よりも長く留まるパルスは割り込みを生成します。より短いパ ルスは割り込みの発生が保証されません。Lowレベル割り込みが選択される場 合、そのLowレベルは割り込みを生成するために現在実行している命令の完 了まで保たれなければなりません。
表17-2. 外部割り込み0(INT0)割り込み条件
ISC01 割り込み発生条件
0 INT0ピンがLowレベルで発生。
INT0ピンの論理変化(両端)。
1 INT0ピンの下降端で発生。
INT0ピンの上昇端で発生。
ISC00
0 1
0 1 0 1
- - - INT1 INT0
7 6 5 4 3 2 1 0
ビット
R/W R/W
R R
R R
R R
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット1 - INT1 : 外部割り込み1許可 (External Interrupt Request 1 Enable)
ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)され、INT1ビットが設定(1)されると、INT1外部ピン割り込みが許可されます。
外部割り込み制御レジスタA(EICRA)の割り込み条件制御1のビット1と0(ISC11,0)は、この外部割り込みがINT1ピンの上昇端、下降端、両 端、またはLowレベルのどれで活性(有効)にされるかを定義します。例えINT1ピンが出力として設定されても、このピンの動きは割り込み 要求を引き起こします。外部割り込み要求1に対応する割り込みはINT1割り込みベクタから実行されます。
● ビット0 - INT0 : 外部割り込み0許可 (External Interrupt Request 0 Enable)
ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)され、INT0ビットが設定(1)されると、INT0外部ピン割り込みが許可されます。
外部割り込み制御レジスタA(EICRA)の割り込み条件制御0のビット1と0(ISC01,0)は、この外部割り込みがINT0ピンの上昇端、下降端、両 端、またはLowレベルのどれで活性(有効)にされるかを定義します。例えINT0ピンが出力として設定されても、このピンの動きは割り込み 要求を引き起こします。外部割り込み要求0に対応する割り込みはINT0割り込みベクタから実行されます。
17.2.3. EIFR - 外部割り込み要求フラグ レジスタ (External Interrupt Flag Register)
LD系とST系の命令を使用し、データ空間としてI/Oレジスタをアクセスする時は、提供された変位が使用されなければなりません。I/O特定 命令のINとOUTを使用する時は、この変位が$20で減算され、I/Oアドレスの変位は$00~$3F内になります。
名称 : EIFR 変位 : $3C ($1C) リセット : $00
特質 : I/O特定命令でI/Oレジスタとしてアクセスする時の変位アドレスは$1Cです。
17.2.2. EIMSK - 外部割り込み許可レジスタ (External Interrupt Mask Register)
LD系とST系の命令を使用し、データ空間としてI/Oレジスタをアクセスする時は、提供された変位が使用されなければなりません。I/O特定 命令のINとOUTを使用する時は、この変位が$20で減算され、I/Oアドレスの変位は$00~$3F内になります。
名称 : EIMSK 変位 : $3D ($1D) リセット : $00
特質 : I/O特定命令でI/Oレジスタとしてアクセスする時の変位アドレスは$1Dです。
- - - INTF1 INTF0
7 6 5 4 3 2 1 0
ビット
R/W R/W
R R
R R
R R
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット1 - INTF1 : 外部割り込み1要求フラグ (External Interrupt Flag 1)
INT1ピン上のエッジまたは論理変化が割り込み要求を起動すると、INTF1が設定(1)されます。ステータス レジスタ(SREG)の全割り込み許可 (I)ビットと外部割り込み許可レジスタ(EIMSK)の外部割り込み1許可(INT1)ビットが設定(1)なら、MCUは対応する割り込みベクタへ飛びま す。このフラグは割り込みルーチンが実行されると解除(0)されます。代わりにこのフラグは1を書くことによっても解除(0)できます。INT1がレ ベル割り込みとして設定されると、このフラグは常に解除(0)されます。
● ビット0 - INTF0 : 外部割り込み0要求フラグ (External Interrupt Flag 0)
INT0ピン上のエッジまたは論理変化が割り込み要求を起動すると、INTF0が設定(1)されます。ステータス レジスタ(SREG)の全割り込み許可 (I)ビットと外部割り込み許可レジスタ(EIMSK)の外部割り込み0許可(INT0)ビットが設定(1)なら、MCUは対応する割り込みベクタへ飛びま す。このフラグは割り込みルーチンが実行されると解除(0)されます。代わりにこのフラグは1を書くことによっても解除(0)できます。INT0がレ ベル割り込みとして設定されると、このフラグは常に解除(0)されます。
17.2.4. PCICR - ピン変化割り込み制御レジスタ (Pin Change Interrupt Control Register) 名称 : PCICR
変位 : $68 リセット : $00 特質 :
-- - - PCIE2 PCIE1 PCIE0
7 6 5 4 3 2 1 0
ビット
R/W R/W
R/W R
R R
R R
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット2 - PCIE2 : ピン変化2群割り込み許可 (Pin Change Interrupt Enable 2)
ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)され、PCIE2ビットが設定(1)されると、ピン変化2群割り込みが許可されます。
許可したPCINT16~23ピンの何れかの変化が割り込みを起こします。このピン変化割り込み要求に対応する割り込みはPCI2割り込み ベクタから実行されます。PCINT16~23ピンはピン変化割り込み2群許可レジスタ(PCMSK2)によって個別に許可されます。
● ビット1 - PCIE1 : ピン変化1群割り込み許可 (Pin Change Interrupt Enable 1)
ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)され、PCIE1ビットが設定(1)されると、ピン変化1群割り込みが許可されます。
許可したPCINT8~14ピンの何れかの変化が割り込みを起こします。このピン変化割り込み要求に対応する割り込みはPCI1割り込みベ クタから実行されます。PCINT8~14ピンはピン変化割り込み1群許可レジスタ(PCMSK1)によって個別に許可されます。
● ビット0 - PCIE0 : ピン変化0群割り込み許可 (Pin Change Interrupt Enable 0)
ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)され、PCIE0ビットが設定(1)されると、ピン変化0群割り込みが許可されます。
許可したPCINT0~7ピンの何れかの変化が割り込みを起こします。このピン変化割り込み要求に対応する割り込みはPCI0割り込みベク タから実行されます。PCINT0~7ピンはピン変化割り込み0群許可レジスタ(PCMSK0)によって個別に許可されます。
17.2.5. PCIFR - ピン変化割り込み要求フラグ レジスタ (Pin Change Interrupt Flag Register)
LD系とST系の命令を使用し、データ空間としてI/Oレジスタをアクセスする時は、提供された変位が使用されなければなりません。I/O特定 命令のINとOUTを使用する時は、この変位が$20で減算され、I/Oアドレスの変位は$00~$3F内になります。
名称 : PCIFR 変位 : $3B ($1B) リセット : $00
特質 : I/O特定命令でI/Oレジスタとしてアクセスする時の変位アドレスは$1Bです。
- - - PCIF2 PCIF1 PCIF0
7 6 5 4 3 2 1 0
ビット
R/W R/W
R/W R
R R
R R
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット2 - PCIF2 : ピン変化2群割り込み要求フラグ (Pin Change Interrupt Flag 2)
PCINT16~23ピンの何れかの論理変化が割り込み要求を起動すると、PCIF2が設定(1)されます。ステータス レジスタ(SREG)の全割り込み 許可(I)ビットとピン変化割り込み制御レジスタ(PCICR)のピン変化2群割り込み許可(PCIE2)ビットが設定(1)なら、MCUは対応する割り込み ベクタへ飛びます。このフラグは割り込み処理ルーチンが開始されると解除(0)されます。代わりにこのフラグは1を書くことによっても解除(0) できます。
● ビット1 - PCIF1 : ピン変化1群割り込み要求フラグ (Pin Change Interrupt Flag 1)
PCINT8~14ピンの何れかの論理変化が割り込み要求を起動すると、PCIF1が設定(1)されます。ステータス レジスタ(SREG)の全割り込み 許可(I)ビットとピン変化割り込み制御レジスタ(PCICR)のピン変化1群割り込み許可(PCIE1)ビットが設定(1)なら、MCUは対応する割り込み ベクタへ飛びます。このフラグは割り込み処理ルーチンが開始されると解除(0)されます。代わりにこのフラグは1を書くことによっても解除(0) できます。
● ビット0 - PCIF0 : ピン変化0群割り込み要求フラグ (Pin Change Interrupt Flag 0)
PCINT0~7ピンの何れかの論理変化が割り込み要求を起動すると、PCIF0が設定(1)されます。ステータス レジスタ(SREG)の全割り込み許 可(I)ビットとピン変化割り込み制御レジスタ(PCICR)のピン変化0群割り込み許可(PCIE0)ビットが設定(1)なら、MCUは対応する割り込みベク タへ飛びます。このフラグは割り込み処理ルーチンが開始されると解除(0)されます。代わりにこのフラグは1を書くことによっても解除(0)でき ます。
PCINT23 PCINT22 PCINT21 PCINT20 PCINT19 PCINT18 PCINT17 PCINT16
7 6 5 4 3 2 1 0
ビット
R/W R/W
R/W R/W
R/W R/W
R/W R/W
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット7~0 - PCINT23~PCINT16 : ピン変化割り込み23~16許可 (Pin Change Enable Mask 23~16)
各PCINT16~23ビットは対応するI/Oピンでピン変化割り込みが許可されるかどうかを選びます。PCINT16~23とピン変化割り込み制御 レジスタ(PCICR)のPCIE2が設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT16~23が解除(0)されると、対応 するI/Oピンのピン変化割り込みは禁止されます。
17.2.7. PCMSK1 - ピン変化割り込み1群許可レジスタ (Pin Change Mask Register 1) 名称 : PCMSK1
変位 : $6C リセット : $00 特質 :
-17.2.6. PCMSK2 - ピン変化割り込み2群許可レジスタ (Pin Change Mask Register 2) 名称 : PCMSK2
変位 : $6D リセット : $00 特質 :
-- PCINT14 PCINT13 PCINT12 PCINT11 PCINT10 PCINT9 PCINT8
7 6 5 4 3 2 1 0
ビット
R/W R/W
R/W R/W
R/W R/W
R/W R
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット6~0 - PCINT14~PCINT8 : ピン変化割り込み14~8許可 (Pin Change Enable Mask 14~8)
各PCINT8~14ビットは対応するI/Oピンでピン変化割り込みが許可されるかどうかを選びます。PCINT8~14とピン変化割り込み制御レジ スタ(PCICR)のPCIE1が設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT8~14が解除(0)されると、対応する I/Oピンのピン変化割り込みは禁止されます。
17.2.8. PCMSK0 - ピン変化割り込み0群許可レジスタ (Pin Change Mask Register 0) 名称 : PCMSK0
変位 : $6B リセット : $00 特質 :
-PCINT7 PCINT6 PCINT5 PCINT4 PCINT3 PCINT2 PCINT1 PCINT0
7 6 5 4 3 2 1 0
ビット
R/W R/W
R/W R/W
R/W R/W
R/W R/W
0 0
0 0
0 0
0 0
アクセス種別 リセット値
● ビット7~0 - PCINT7~PCINT0 : ピン変化割り込み7~0許可 (Pin Change Enable Mask 7~0)
各PCINT0~7ビットは対応するI/Oピンでピン変化割り込みが許可されるかどうかを選びます。PCINT0~7とピン変化割り込み制御レジス タ(PCICR)のPCIE0が設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT0~7が解除(0)されると、対応するI/O ピンのピン変化割り込みは禁止されます。