0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

51單片機(jī)的中斷體系結(jié)構(gòu)_中斷的響應(yīng)過程

h1654155282.3538 ? 來源:網(wǎng)絡(luò)整理 ? 2018-05-18 15:28 ? 次閱讀

51單片機(jī)的中斷系統(tǒng)十分重要,分為外部中斷和定時(shí)器中斷。本文主要詳解51單片機(jī)的中斷體系結(jié)構(gòu)以及中斷的響應(yīng)過程,具體的跟隨小編一起來了解一下。

51單片機(jī)的中斷體系結(jié)構(gòu)詳解

80C51的中斷系統(tǒng)有5個(gè)中斷源(8052有 6個(gè)) ,2個(gè)優(yōu)先級,可實(shí)現(xiàn)二級中斷嵌套 。MCS-51系列單片機(jī)中斷系統(tǒng)的機(jī)構(gòu)如下:

51單片機(jī)的中斷體系結(jié)構(gòu)_中斷的響應(yīng)過程

與中斷系統(tǒng)相關(guān)的特殊寄存器

1)中斷允許控制寄存器(IE)------ 控制各中斷的開放和屏蔽

2)中斷優(yōu)先級控制寄存器(IP)------設(shè)置各中斷的優(yōu)先級

3)定時(shí)器/計(jì)數(shù)器控制寄存器(TCON)----定時(shí)器和外部中斷的控制

4)串行口控制寄存器(SCON)------串行中斷的控制

中斷類型分為三類:

1)T0、T1是2個(gè)定時(shí)器/計(jì)數(shù)器中斷,由片內(nèi)定時(shí)器提供;

2)INT0、INT1是2個(gè)外部中斷,由引腳P3.2和P3.2提供;

3)RX、TX為串行口中斷所用,由片內(nèi)串口提供。

51單片機(jī)的中斷體系結(jié)構(gòu)_中斷的響應(yīng)過程

1、(P3.2)/(P3.3)可由IT0(TCON.0)/IT1(TCON.2)選擇其為低電平有效還是下降沿有效。當(dāng)CPU檢測到P3.2/P3.3引腳上出現(xiàn)有效的中斷信號時(shí),中斷標(biāo)志IE0(TCON.1)/IE1(TCON.3)置1,向CPU申請中斷。

2、TF0(TCON.5)/TF1(TCON.7),片內(nèi)定時(shí)/計(jì)數(shù)器T0/T1溢出中斷請求標(biāo)志。當(dāng)定時(shí)/計(jì)數(shù)器T0/T1發(fā)生溢出時(shí),置位TF0/TF1,并向CPU申請中斷。

3、RI(SCON.0)或TI(SCON.1),串行口中斷請求標(biāo)志。當(dāng)串行口接收完一幀串行數(shù)據(jù)時(shí)置位RI或當(dāng)串行口發(fā)送完一幀串行數(shù)據(jù)時(shí)置位TI,向CPU申請中斷。

1)定時(shí)器中斷的使用(以定時(shí)器0為例)

……

TMOD |= 0x01 | 0x04; //使用模式1,16位計(jì)數(shù)器,使用“|”符號可以在使用多個(gè)定時(shí)器時(shí)不受影響

TH0=0xFF; //給定初值

TL0=245; //從245計(jì)數(shù)到255

EA=1; //總中斷打開

ET0=1; //定時(shí)器中斷打開

TR0=1; //定時(shí)器開關(guān)打開

void Timer0_isr(void) interrupt 1 using 1 //中斷服務(wù)程序

{

TH0=0xFF; //重新給定初值

TL0=245;

……

}

2)外部中斷的使用(以外部中斷0為例)

…………

EA=1; //全局中斷開

EX0=1; //外部中斷0開

IT0=0; //電平觸發(fā)

void ISR_Key(void) interrupt 0 using 1 //中斷服務(wù)程序

{

…………

}

中斷的響應(yīng)過程

若某個(gè)中斷源通過編程設(shè)置,處于被打開的狀態(tài),并滿足中斷響應(yīng)的條件,而且①當(dāng)前正在執(zhí)行的那條指令已被執(zhí)行完

1、當(dāng)前末響應(yīng)同級或高級中斷

2、不是在操作IE,IP中斷控制寄存器或執(zhí)行REH指令則單片機(jī)響應(yīng)此中斷。

在正常的情況下,從中斷請求信號有效開始,到中斷得到響應(yīng),通常需要3個(gè)機(jī)器周期到8個(gè)機(jī)器周期。中斷得到響應(yīng)后,自動清除中斷請求標(biāo)志(對串行I/O端口的中斷標(biāo)志,要用軟件清除),將斷點(diǎn)即程序計(jì)數(shù)器之值(PC)壓入堆棧(以備恢復(fù)用);然后把相應(yīng)的中斷入口地址裝入PC,使程序轉(zhuǎn)入到相應(yīng)的中斷服務(wù)程序中去執(zhí)行。

各個(gè)中斷源在程序存儲器中的中斷入口地址如下:

中斷源 入口地址

INT0(外部中斷0) 0003H

TF0(TO中斷) 000BH

INT1(外部中斷1) 0013H

TFl(T1中斷) 001BH

RI/TI(串行口中斷) 0023H

由于各個(gè)中斷入口地址相隔甚近,不便于存放各個(gè)較長的中斷服務(wù)程序,故通常在中斷入口地址開始的二三個(gè)單元中,安排一條轉(zhuǎn)移類指令,以轉(zhuǎn)入到安排在那兒的中斷服務(wù)程序。以T1中斷為例,其過程下如圖四所示。

由于5個(gè)中斷源各有其中斷請求標(biāo)志0,TF0,IEl,TFl以及RI/TI,在中斷源滿足中斷請求的條件下,各標(biāo)志自動置1,以向CPU請求中斷。如果某一中斷源提出中斷請求后,CPU不能立即響應(yīng),只要該中斷請求標(biāo)志不被軟件人為清除,中斷請求的狀態(tài)就將一直保持,直到CPU響應(yīng)了中斷為止,對串行口中斷而言,這一過程與其它4個(gè)中斷的不同之處在于;即使CPU響應(yīng)了中斷,其中斷標(biāo)志RI/TI也不會自動清零,必須在中斷服務(wù)程序中設(shè)置清除RI/TI的指令后,才會再一次地提出中斷請求。

CPU的現(xiàn)場保護(hù)和恢復(fù)必須由被響應(yīng)的相應(yīng)中斷服務(wù)程序去完成,當(dāng)執(zhí)行RETI中斷返回指令后,斷點(diǎn)值自動從棧頂2字節(jié)彈出,并裝入PC寄存器,使CPU繼續(xù)執(zhí)行被打斷了的程序。

下面給出一個(gè)應(yīng)用定時(shí)器中斷的實(shí)例。

現(xiàn)要求編制一段程序,使P1.0端口線上輸出周期為2ms的方波脈沖。設(shè)單片機(jī)晶振頻率

Fosc=6MHZ.

1、方法:利用定時(shí)器T0作1ms定時(shí),達(dá)到定時(shí)值后引起中斷,在中斷服務(wù)程序中,使P1.0的狀態(tài)取一次反,并再次定時(shí)1ms。

2、定時(shí)初值:機(jī)器周期MC=12/fosc=2us。所以定時(shí)lms所需的機(jī)器周期個(gè)數(shù)為500D,亦即0lF4H。設(shè)T0為工作方式1(16位方式),則定時(shí)初值是(01F4H)求補(bǔ)=FEOCH

51單片機(jī)的中斷體系結(jié)構(gòu)_中斷的響應(yīng)過程

51單片機(jī)的中斷體系結(jié)構(gòu)_中斷的響應(yīng)過程

串行端口的控制寄存器:

串行端口共有2個(gè)控制寄存器SCON和PCON,用以設(shè)置串行端口的工作方式、接收/發(fā)送的運(yùn)行狀態(tài)、接收/發(fā)送數(shù)據(jù)的特征、波特率的大小,以及作為運(yùn)行的中斷標(biāo)志等。

①串行口控制寄存器SCON

SCON的字節(jié)地址是98H,位地址(由低位到高位)分別是98H一9FH。SCON的格式如圖五所示。

51單片機(jī)的中斷體系結(jié)構(gòu)_中斷的響應(yīng)過程

SMo,SMl:

串行口工作方式控制位。

00--方式0;01--方式1;

10--方式2;11--方式3。

SM2:

僅用于方式2和方式3的多機(jī)通訊控制位

發(fā)送機(jī)SM2=1(要求程控設(shè)置)。

當(dāng)為方式2或方式3時(shí):

接收機(jī) SM2=1時(shí),若RB8=1,可引起串行接收中斷;若RB8=0,不

引起串行接收中斷。SM2=0時(shí),若RB8=1,可引起串行接收中斷;若

RB8=0,亦可引起串行接收中斷。

REN:

串行接收允許位。

0--禁止接收;1--允許接收。

TB8:

在方式2,3中,TB8是發(fā)送機(jī)要發(fā)送的第9位數(shù)據(jù)。

RB8:

在方式2,3中,RB8是接收機(jī)接收到的第9位數(shù)據(jù),該數(shù)據(jù)正好來自發(fā)

送機(jī)的TB8。

TI:

發(fā)送中斷標(biāo)志位。發(fā)送前必須用軟件清零,發(fā)送過程中TI保持零電平,

發(fā)送完一幀數(shù)據(jù)后,由硬件自動置1。如要再發(fā)送,必須用軟件再清零。

RI:

接收中斷標(biāo)志位。接收前,必須用軟件清零,接收過程中RI保持零電平,接收完一幀數(shù)據(jù)后,由片內(nèi)硬件自動置1。如要再接收,必須用軟件再清零。

電源控制寄存器PCON

PCON的字節(jié)地址為87H,無位地址,PCON的格式如圖六所示。需指出的是,對80C31單片機(jī)而言,PCON還有幾位有效控制位。

51單片機(jī)的中斷體系結(jié)構(gòu)_中斷的響應(yīng)過程

SMOD:波特率加倍位。在計(jì)算串行方式1,2,3的波特率時(shí);0---不加倍;1---加倍。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6023

    文章

    44376

    瀏覽量

    628294
  • 51單片機(jī)
    +關(guān)注

    關(guān)注

    272

    文章

    5689

    瀏覽量

    122144
收藏 人收藏

    評論

    相關(guān)推薦

    51單片機(jī)體系結(jié)構(gòu)是如何構(gòu)成的

    51單片機(jī)體系結(jié)構(gòu)內(nèi)部結(jié)構(gòu)中央處理器(CPU)數(shù)據(jù)存儲器(RAM)片內(nèi)程序存儲器(ROM)特殊功能寄存器(SFR)并行輸入/輸出口(P0,P1,P2,P3)(32個(gè)I/O口)可編程串行口(通信
    發(fā)表于 11-18 08:15

    單片機(jī)中斷系統(tǒng)介紹_51單片機(jī)中斷系統(tǒng)結(jié)構(gòu)

    單片機(jī)中斷就是當(dāng)單片機(jī)正在執(zhí)行程序的時(shí)候,突然某個(gè)按鍵按下了(產(chǎn)生外部中斷),單片機(jī)就必須得去處理那個(gè)按鍵(
    發(fā)表于 01-10 17:29 ?1.2w次閱讀
    <b class='flag-5'>單片機(jī)</b><b class='flag-5'>中斷</b>系統(tǒng)介紹_<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b><b class='flag-5'>中斷</b>系統(tǒng)<b class='flag-5'>結(jié)構(gòu)</b>

    淺談51單片機(jī)中斷控制

    51系列單片機(jī)有5個(gè)中斷源,2個(gè)優(yōu)先級,可以實(shí)現(xiàn)二級中斷服務(wù)嵌套結(jié)構(gòu)。
    發(fā)表于 05-29 14:07 ?3865次閱讀
    淺談<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>中斷</b>控制

    51單片機(jī)教程之51單片機(jī)中斷系統(tǒng)的詳細(xì)資料概述

    本文檔的主要內(nèi)容詳細(xì)介紹的是51單片機(jī)教程之51單片機(jī)中斷系統(tǒng)的詳細(xì)資料概述主要內(nèi)容介紹的是中斷
    發(fā)表于 11-19 09:56 ?17次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>教程之<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b><b class='flag-5'>中斷</b>系統(tǒng)的詳細(xì)資料概述

    51單片機(jī)中斷系統(tǒng)詳細(xì)資料總結(jié)

    本文檔的詳細(xì)介紹的是51單片機(jī)中斷系統(tǒng)詳細(xì)資料總結(jié)。主要內(nèi)容包括了:1 中斷的概念,2 中斷系統(tǒng)結(jié)構(gòu)
    發(fā)表于 03-07 16:37 ?3次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>中斷</b>系統(tǒng)詳細(xì)資料總結(jié)

    51單片機(jī)有幾個(gè)中斷?單片機(jī)中斷號對應(yīng)的中斷類型說明

    51單片機(jī)通常有5個(gè)中斷,當(dāng)中斷發(fā)生時(shí),程序會跳到相應(yīng)的中斷服務(wù)程序去執(zhí)行。為了區(qū)別不同的中斷,
    發(fā)表于 08-06 17:34 ?5次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>有幾個(gè)<b class='flag-5'>中斷</b>?<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>中斷</b>號對應(yīng)的<b class='flag-5'>中斷</b>類型說明

    51單片機(jī)中斷系統(tǒng)的原理和結(jié)構(gòu)詳細(xì)說明

    本文檔的主要內(nèi)容詳細(xì)介紹的是51單片機(jī)中斷系統(tǒng)的原理和結(jié)構(gòu)詳細(xì)說明。
    發(fā)表于 11-19 08:00 ?2次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b><b class='flag-5'>中斷</b>系統(tǒng)的原理和<b class='flag-5'>結(jié)構(gòu)</b>詳細(xì)說明

    51單片機(jī)中斷

    51單片機(jī)中斷51單片機(jī)中斷原理中斷的概念:
    發(fā)表于 11-11 14:36 ?52次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b><b class='flag-5'>中斷</b>篇

    51單片機(jī)體系結(jié)構(gòu)

    51單片機(jī)體系結(jié)構(gòu)內(nèi)部結(jié)構(gòu)中央處理器(CPU)數(shù)據(jù)存儲器(RAM)片內(nèi)程序存儲器(ROM)特殊功能寄存器(SFR)并行輸入/輸出口(P0,P1,P2,P3)(32個(gè)I/O口)可編程串行口(通信
    發(fā)表于 11-11 17:21 ?9次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)體系結(jié)構(gòu)</b>

    C51單片機(jī)學(xué)習(xí)筆記(四)——單片機(jī)中斷系統(tǒng)及應(yīng)用

    C51單片機(jī)學(xué)習(xí)筆記(四)——單片機(jī)中斷系統(tǒng)及應(yīng)用文章目錄C51單片機(jī)學(xué)習(xí)筆記(四)——
    發(fā)表于 11-14 10:21 ?17次下載
    C<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>學(xué)習(xí)筆記(四)——<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>中斷</b>系統(tǒng)及應(yīng)用

    51單片機(jī)中斷

    51單片機(jī)中斷(interrupt)
    發(fā)表于 11-20 16:51 ?13次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>之<b class='flag-5'>中斷</b>

    51單片機(jī)中斷系統(tǒng)

    文章目錄1 51單片機(jī)中斷系統(tǒng)1.1 中斷的固有優(yōu)先級和搶占優(yōu)先級1 51單片機(jī)
    發(fā)表于 11-22 13:36 ?8次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>中斷</b>系統(tǒng)

    51單片機(jī)中斷系統(tǒng)

    文章目錄1 51單片機(jī)中斷系統(tǒng)1.1 中斷的固有優(yōu)先級和搶占優(yōu)先級1 51單片機(jī)
    發(fā)表于 11-23 16:51 ?14次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>中斷</b>系統(tǒng)

    51單片機(jī)中斷程序示例

    51單片機(jī)中斷程序示例
    發(fā)表于 05-17 18:03 ?0次下載

    51單片機(jī)中斷系統(tǒng)介紹

    51單片機(jī)中斷系統(tǒng)介紹與運(yùn)用外部中斷系統(tǒng)觸發(fā)數(shù)碼管顯示數(shù)字的代碼實(shí)驗(yàn)
    發(fā)表于 12-05 09:10 ?1次下載