一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

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

h1654155282.3538 ? 來源:網(wǎng)絡整理 ? 2018-05-18 15:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

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

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

中斷類型分為三類:

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

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

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

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

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

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

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

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

……

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

TH0=0xFF; //給定初值

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

EA=1; //總中斷打開

ET0=1; //定時器中斷打開

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

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

{

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

TL0=245;

……

}

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

…………

EA=1; //全局中斷開

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

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

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

{

…………

}

中斷的響應過程

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

1、當前末響應同級或高級中斷

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

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

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

中斷源 入口地址

INT0(外部中斷0) 0003H

TF0(TO中斷) 000BH

INT1(外部中斷1) 0013H

TFl(T1中斷) 001BH

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

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

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

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

下面給出一個應用定時器中斷的實例。

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

Fosc=6MHZ.

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

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

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

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

串行端口的控制寄存器:

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

①串行口控制寄存器SCON

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

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

SMo,SMl:

串行口工作方式控制位。

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

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

SM2:

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

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

當為方式2或方式3時:

接收機 SM2=1時,若RB8=1,可引起串行接收中斷;若RB8=0,不

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

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

REN:

串行接收允許位。

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

TB8:

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

RB8:

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

送機的TB8。

TI:

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

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

RI:

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

電源控制寄存器PCON

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

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

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

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

    關(guān)注

    6067

    文章

    44992

    瀏覽量

    650639
  • 51單片機
    +關(guān)注

    關(guān)注

    277

    文章

    5711

    瀏覽量

    127420
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

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

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

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

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

    淺談51單片機中斷控制

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

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

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

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

    本文檔的詳細介紹的是51單片機中斷系統(tǒng)詳細資料總結(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'>單片機</b>的<b class='flag-5'>中斷</b>系統(tǒng)詳細資料總結(jié)

    51單片機有幾個中斷?單片機中斷號對應的中斷類型說明

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

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

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

    51單片機中斷

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

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

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

    C51單片機學習筆記(四)——單片機中斷系統(tǒng)及應用

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

    51單片機中斷

    中斷中斷時為使單片機具有對外部或內(nèi)部隨機發(fā)生的事件實時處理而設置的,51單片機內(nèi)部一共有5個中斷
    發(fā)表于 11-19 09:06 ?18次下載
    <b class='flag-5'>51</b><b class='flag-5'>單片機</b>—<b class='flag-5'>中斷</b>

    51單片機中斷

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

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

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

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

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

    51單片機中斷程序示例

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