本書全面、系統(tǒng)地介紹了MCS-51系列單片機應(yīng)用系統(tǒng)的各種實用接口技術(shù)及其配置。 內(nèi)容包括:MCS-51系列單片機組成原理:應(yīng)用系統(tǒng)擴展、開發(fā)與調(diào)試;鍵盤輸入接口的設(shè)計及調(diào)試;打印機和顯示器接口及設(shè)計實例;模擬輸入通道接口技術(shù);A/D、D/A、接口技術(shù)及在控制系統(tǒng)中的應(yīng)用設(shè)計;V/F轉(zhuǎn)換器接口技術(shù)、串行通訊接口技術(shù)以及其它與應(yīng)用系統(tǒng)設(shè)計有關(guān)的實用技術(shù)等。 本書是為滿足廣大科技工作者從事單片機應(yīng)用系統(tǒng)軟件、硬件設(shè)計的需要而編寫的,具有內(nèi)容新穎、實用、全面的特色。所有的接口設(shè)計都包括詳細的設(shè)計步驟、硬件線路圖及故障分析,并附有測試程序清單。書中大部分接口軟、硬件設(shè)計實例都是作者多年來從事單片機應(yīng)用和開發(fā)工作的經(jīng)驗總結(jié),實用性和工程性較強,尤其是對應(yīng)用系統(tǒng)中必備的鍵盤、顯示器、打印機、A/D、D/A通訊接口設(shè)計、模擬信號處理及開發(fā)系統(tǒng)應(yīng)用舉例甚多,目的是讓將要開始和正在從事單片機應(yīng)用開發(fā)的科研人員根據(jù)自己的實際需要來選擇應(yīng)用,一書在手即可基本完成單片機應(yīng)用系統(tǒng)的開發(fā)工作。 本書主要面向從事單片機應(yīng)用開發(fā)工作的廣大工程技術(shù)人員,也可作為大專院校有關(guān)專業(yè)的教材或教學(xué)參考書。 第一章MCS-51系列單片機組成原理 1.1概述 1.1.1單片機主流產(chǎn)品系列 1.1.2單片機芯片技術(shù)的發(fā)展概況 1.1.3單片機的應(yīng)用領(lǐng)域 1.2MCS-51單片機硬件結(jié)構(gòu) 1.2.1MCS-51單片機硬件結(jié)構(gòu)的特點 1.2.2MCS-51單片機的引腳描述及片外總線結(jié)構(gòu) 1.2.3MCS-51片內(nèi)總體結(jié)構(gòu) 1.2.4MCS-51單片機中央處理器及其振蕩器、時鐘電路和CPU時序 1.2.5MCS-51單片機的復(fù)位狀態(tài)及幾種復(fù)位電路設(shè)計 1.2.6存儲器、特殊功能寄存器及位地址空間 1.2.7輸入/輸出(I/O)口 1.3MCS-51單片機指令系統(tǒng)分析 1.3.1指令系統(tǒng)的尋址方式 1.3.2指令系統(tǒng)的使用要點 1.3.3指令系統(tǒng)分類總結(jié) 1.4串行接口與定時/計數(shù)器 1.4.1串行接口簡介 1.4.2定時器/計數(shù)器的結(jié)構(gòu) 1.4.3定時器/計數(shù)器的四種工作模式 1.4.4定時器/計數(shù)器對輸入信號的要求 1.4.5定時器/計數(shù)器的編程和應(yīng)用 1.5中斷系統(tǒng) 1.5.1中斷請求源 1.5.2中斷控制 1.5.3中斷的響應(yīng)過程 1.5.4外部中斷的響應(yīng)時間 1.5.5外部中斷方式的選擇 第二章MCS-51單片機系統(tǒng)擴展 2.1概述 2.2程序存貯器的擴展 2.2.1外部程序存貯器的擴展原理及時序 2.2.2地址鎖存器 2.2.3EPROM擴展電路 2.2.4EEPROM擴展電路 2.3外部數(shù)據(jù)存貯器的擴展 2.3.1外部數(shù)據(jù)存貯器的擴展方法及時序 2.3.2靜態(tài)RAM擴展 2.3.3動態(tài)RAM擴展 2.4外部I/O口的擴展 2.4.1I/O口擴展概述 2.4.2I/O口地址譯碼技術(shù) 2.4.38255A可編程并行I/O擴展接口 2.4.48155/8156可編程并行I/O擴展接口 2.4.58243并行I/O擴展接口 2.4.6用TTL芯片擴展I/O接口 2.4.7用串行口擴展I/O接口 2.4.8中斷系統(tǒng)擴展 第三章MCS-51單片機應(yīng)用系統(tǒng)的開發(fā) 3.1單片機應(yīng)用系統(tǒng)的設(shè)計 3.1.1設(shè)計前的準(zhǔn)備工作 3.1.2應(yīng)用系統(tǒng)的硬件設(shè)計 3.1.3應(yīng)用系統(tǒng)的軟件設(shè)計 3.1.4應(yīng)用系統(tǒng)的抗干擾設(shè)計 3.2單片機應(yīng)用系統(tǒng)的開發(fā) 3.2.1仿真系統(tǒng)的功能 3.2.2開發(fā)手段的選擇 3.2.3應(yīng)用系統(tǒng)的開發(fā)過程 3.3SICE—IV型單片機仿真器 3.3.1SICE-IV仿真器系統(tǒng)結(jié)構(gòu) 3.3.2SICE-IV的仿真特性和軟件功能 3.3.3SICE-IV與主機和終端的連接使用方法 3.4KHK-ICE-51單片機仿真開發(fā)系統(tǒng) 3.4.1KHK—ICE-51仿真器系統(tǒng)結(jié)構(gòu) 3.4.2仿真器系統(tǒng)功能特點 3.4.3KHK-ICE-51仿真系統(tǒng)的安裝及其使用 3.5單片機應(yīng)用系統(tǒng)的調(diào)試 3.5.1應(yīng)用系統(tǒng)聯(lián)機前的靜態(tài)調(diào)試 3.5.2外部數(shù)據(jù)存儲器RAM的測試 3.5.3程序存儲器的調(diào)試 3.5.4輸出功能模塊調(diào)試 3.5.5可編程I/O接口芯片的調(diào)試 3.5.6外部中斷和定時器中斷的調(diào)試 3.6用戶程序的編輯、匯編、調(diào)試、固化及運行 3.6.1源程序的編輯 3.6.2源程序的匯編 3.6.3用戶程序的調(diào)試 3.6.4用戶程序的固化 3.6.5用戶程序的運行 第四章鍵盤及其接口技術(shù) 4.1鍵盤輸入應(yīng)解決的問題 4.1.1鍵盤輸入的特點 4.1.2按鍵的確認(rèn) 4.1.3消除按鍵抖動的措施 4.2獨立式按鍵接口設(shè)計 4.3矩陣式鍵盤接口設(shè)計 4.3.1矩陣鍵盤工作原理 4.3.2按鍵的識別方法 4.3.3鍵盤的編碼 4.3.4鍵盤工作方式 4.3.5矩陣鍵盤接口實例及編程要點 4.3.6雙功能及多功能鍵設(shè)計 4.3.7鍵盤處理中的特殊問題一重鍵和連擊 4.48279鍵盤、顯示器接口芯片及應(yīng)用 4.4.18279的組成和基本工作原理 4.4.28279管腳、引線及功能說明 4.4.38279編程 4.4.48279鍵盤接口實例 4.5功能開關(guān)及撥碼盤接口設(shè)計 第五章顯示器接口設(shè)計 5.1LED顯示器 5.1.1LED段顯示器結(jié)構(gòu)與原理 5.1.2LED顯示器及顯示方式 5.1.3LED顯示器接口實例 5.1.4LED顯示器驅(qū)動技術(shù) 5.2單片機應(yīng)用系統(tǒng)中典型鍵盤、顯示接口技術(shù) 5.2.1用8255和串行口擴展的鍵盤、顯示器電路 5.2.2由鎖存器組成的鍵盤、顯示器接口電路 5.2.3由8155構(gòu)成的鍵盤、顯示器接口電路 5.2.4用8279組成的顯示器實例 5.3液晶顯示LCD 5.3.1LCD的基本結(jié)構(gòu)及工作原理 5.3.2LCD的驅(qū)動方式 5.3.34位LCD靜態(tài)驅(qū)動芯片ICM7211系列簡介 5.3.4點陣式液晶顯示控制器HD61830介紹 5.3.5點陣式液晶顯示模塊介紹 5.4熒光管顯示 5.5LED大屏幕顯示器 第六章打印機接口設(shè)計 6.1打印機簡介 6.1.1打印機的基本知識 6.1.2打印機的電路構(gòu)成 6.1.3打印機的接口信號 6.1.4打印機的打印命令 6.2TPμP-40A微打與單片機接口設(shè)計 6.2.1TPμP系列微型打印機簡介 6.2.2TPμP-40A打印功能及接口信號 6.2.3TPμP-40A工作方式及打印命令 6.2.48031與TPμP-40A的接口 6.2.5打印編程實例 6.3XLF微型打印機與單片機接口設(shè)計 6.3.1XLF微打簡介 6.3.2XLF微打接口信號及與8031接口設(shè)計 6.3.3XLF微打控制命令 6.3.4打印機編程 6.4標(biāo)準(zhǔn)寬行打印機與8031接口設(shè)計 6.4.1TH3070接口引腳信號及時序 6.4.2與8031的簡單接口 6.4.3通過打印機適配器完成8031與打印機的接口 6.4.4對打印機的編程 第七章模擬輸入通道接口技術(shù) 7.1傳感器 7.1.1傳感器的分類 7.1.2溫度傳感器 7.1.3光電傳感器 7.1.4濕度傳感器 7.1.5其他傳感器 7.2模擬信號放大技術(shù) 7.2.1基本放大器電路 7.2.2集成運算放大器 7.2.3常用運算放大器及應(yīng)用舉例 7.2.4測量放大器 7.2.5程控增益放大器 7.2.6隔離放大器 7.3多通道模擬信號輸入技術(shù) 7.3.1多路開關(guān) 7.3.2常用多路開關(guān) 7.3.3模擬多路開關(guān) 7.3.4常用模擬多路開關(guān) 7.3.5多路模擬開關(guān)應(yīng)用舉例 7.3.6多路開關(guān)的選用 7.4采樣/保持電路設(shè)計 7.4.1采樣/保持原理 7.4.2集成采樣/保持器 7.4.3常用集成采樣/保持器 7.4.4采樣保持器的應(yīng)用舉例 7.5有源濾波器的設(shè)計 7.5.1濾波器分類 7.5.2有源濾波器的設(shè)計 7.5.3常用有源濾波器設(shè)計舉例 7.5.4集成有源濾波器 第八章D/A轉(zhuǎn)換器與MCS-51單片機的接口設(shè)計與實踐 8.1D/A轉(zhuǎn)換器的基本原理及主要技術(shù)指標(biāo) 8.1.1D/A轉(zhuǎn)換器的基本原理與分類 8.1.2D/A轉(zhuǎn)換器的主要技術(shù)指標(biāo) 8.2D/A轉(zhuǎn)換器件選擇指南 8.2.1集成D/A轉(zhuǎn)換芯片介紹 8.2.2D/A轉(zhuǎn)換器的選擇要點及選擇指南表 8.2.3D/A轉(zhuǎn)換器接口設(shè)計的幾點實用技術(shù) 8.38位D/A轉(zhuǎn)換器DAC080/0831/0832與MCS-51單片機的接口設(shè)計 8.3.1DAC0830/0831/0832的應(yīng)用特性與引腳功能 8.3.2DAC0830/0831/0832與8031單片機的接口設(shè)計 8.3.3DAC0830/0831/0832的調(diào)試說明 8.3.4DAC0830/0831/0832應(yīng)用舉例 8.48位D/A轉(zhuǎn)換器AD558與MCS-51單片機的接口設(shè)計 8.4.1AD558的應(yīng)用特性與引腳功能 8.4.2AD558與8031單片機的接口及調(diào)試說明 8.4.38位D/A轉(zhuǎn)換器DAC0800系列與8031單片機的接口 8.510位D/A轉(zhuǎn)換器AD7522與MCS-51的硬件接口設(shè)計 8.5.1AD7522的應(yīng)用特性及引腳功能 8.5.2AD7522與8031單片機的接口設(shè)計 8.610位D/A轉(zhuǎn)換器AD7520/7530/7533與MCS一51單片機的接口設(shè)計 8.6.1AD7520/7530/7533的應(yīng)用特性與引腳功能 8.6.2AD7520系列與8031單片機的接口 8.6.3DAC1020/DAC1220/AD7521系列D/A轉(zhuǎn)換器接口設(shè)計 8.712位D/A轉(zhuǎn)換器DAC1208/1209/1210與MCS-51單片機的接口設(shè)計 8.7.1DAC1208/1209/1210的內(nèi)部結(jié)構(gòu)與引腳功能 8.7.2DAC1208/1209/1210與8031單片機的接口設(shè)計 8.7.312位D/A轉(zhuǎn)換器DAC1230/1231/1232的應(yīng)用設(shè)計說明 8.7.412位D/A轉(zhuǎn)換器AD7542與8031單片機的接口設(shè)計 8.812位串行DAC-AD7543與MCS-51單片機的接口設(shè)計 8.8.1AD7543的應(yīng)用特性與引腳功能 8.8.2AD7543與8031單片機的接口設(shè)計 8.914位D/A轉(zhuǎn)換器AD75335與MCS-51單片機的接口設(shè)計 8.9.1AD8635的內(nèi)部結(jié)構(gòu)與引腳功能 8.9.2AD7535與8031單片機的接口設(shè)計 8.1016位D/A轉(zhuǎn)換器AD1147/1148與MCS-51單片機的接口設(shè)計 8.10.1AD1147/AD1148的內(nèi)部結(jié)構(gòu)及引腳功能 8.10.2AD1147/AD1148與8031單片機的接口設(shè)計 8.10.3AD1147/AD1148接口電路的應(yīng)用調(diào)試說明 8.10.416位D/A轉(zhuǎn)換器AD1145與8031單片機的接口設(shè)計 第九章A/D轉(zhuǎn)換器與MCS-51單片機的接口設(shè)計與實踐 9.1A/D轉(zhuǎn)換器的基本原理及主要技術(shù)指標(biāo) 9.1.1A/D轉(zhuǎn)換器的基本原理與分類 9.1.2A/D轉(zhuǎn)換器的主要技術(shù)指標(biāo) 9.2面對課題如何選擇A/D轉(zhuǎn)換器件 9.2.1常用A/D轉(zhuǎn)換器簡介 9.2.2A/D轉(zhuǎn)換器的選擇要點及應(yīng)用設(shè)計的幾點實用技術(shù) 9.38位D/A轉(zhuǎn)換器ADC0801/0802/0803/0804/0805與MCS-51單片機的接口設(shè)計 9.3.1ADC0801~ADC0805芯片的引腳功能及應(yīng)用特性 9.3.2ADC0801~ADC0805與8031單片機的接口設(shè)計 9.48路8位A/D轉(zhuǎn)換器ADC0808/0809與MCS一51單片機的接口設(shè)計 9.4.1ADC0808/0809的內(nèi)部結(jié)構(gòu)及引腳功能 9.4.2ADC0808/0809與8031單片機的接口設(shè)計 9.4.3接口電路設(shè)計中的幾點注意事項 9.4.416路8位A/D轉(zhuǎn)換器ADC0816/0817與MCS-51單片機的接口設(shè)計 9.510位A/D轉(zhuǎn)換器AD571與MCS-51單片機的接口設(shè)計 9.5.1AD571芯片的引腳功能及應(yīng)用特性 9.5.2AD571與8031單片機的接口 9.5.38位A/D轉(zhuǎn)換器AD570與8031單片機的硬件接口 9.612位A/D轉(zhuǎn)換器ADC1210/1211與MCS-51單片機的接口設(shè)計 9.6.1ADC1210/1211的引腳功能與應(yīng)用特性 9.6.2ADC1210/1211與8031單片機的硬件接口 9.6.3硬件接口電路的設(shè)計要點及幾點說明 9.712位A/D轉(zhuǎn)換器AD574A/1374/1674A與MCS-51單片機的接口設(shè)計 9.7.1AD574A的內(nèi)部結(jié)構(gòu)與引腳功能 9.7.2AD574A的應(yīng)用特性及校準(zhǔn) 9.7.3AD574A與8031單片機的硬件接口設(shè)計 9.7.4AD574A的應(yīng)用調(diào)試說明 9.7.5AD674A/AD1674與8031單片機的接口設(shè)計 9.8高速12位A/D轉(zhuǎn)換器AD578/AD678/AD1678與MCS—51單片機的接口設(shè)計 9.8.1AD578的應(yīng)用特性與引腳功能 9.8.2AD578高速A/D轉(zhuǎn)換器與8031單片機的接口設(shè)計 9.8.3AD578高速A/D轉(zhuǎn)換器的應(yīng)用調(diào)試說明 9.8.4AD678/AD1678采樣A/D轉(zhuǎn)換器與8031單片機的接口設(shè)計 9.914位A/D轉(zhuǎn)換器AD679/1679與MCS-51單片機的接口設(shè)計 9.9.1AD679/AD1679的應(yīng)用特性及引腳功能 9.9.2AD679/1679與8031單片機的接口設(shè)計 9.9.3AD679/1679的調(diào)試說明 9.1016位ADC-ADC1143與MCS-51單片機的接口設(shè)計 9.10.1ADC1143的應(yīng)用特性及引腳功能 9.10.2ADC1143與8031單片機的接口設(shè)計 9.113位半積分A/D轉(zhuǎn)換器5G14433與MCS-51單片機的接口設(shè)計 9.11.15G14433的內(nèi)部結(jié)構(gòu)及引腳功能 9.11.25G14433的外部電路連接與元件參數(shù)選擇 9.11.35G14433與8031單片機的接口設(shè)計 9.11.45G14433的應(yīng)用舉例 9.124位半積分A/D轉(zhuǎn)換器ICL7135與MCS—51單片機的接口設(shè)計 9.12.1ICL7135的內(nèi)部結(jié)構(gòu)及芯片引腳功能 9.12.2ICL7135的外部電路連接與元件參數(shù)選擇 9.12.3ICL7135與8031單片機的硬件接口設(shè)計 9.124ICL7135的應(yīng)用舉例 9.1312位雙積分A/D轉(zhuǎn)換器ICL7109與MCS—51單片機的接口設(shè)計 9.13.1ICL7109的內(nèi)部結(jié)構(gòu)與芯片引腳功能 9.13.2ICL7109的外部電路連接與元件參數(shù)選擇 9.13.3ICL7109與8031單片機的硬件接口設(shè)計 9.1416位積分型ADC一ICL7104與MCS-51單片機的接口設(shè)計 9.14.1ICL7104的主要應(yīng)用特性及引腳功能 9.14.2ICL7104與8031單片機的接口設(shè)計 9.14.3其它積分型A/D轉(zhuǎn)換器簡介 第十章V/F轉(zhuǎn)換器接口技術(shù) 10.1V/F轉(zhuǎn)換的特點及應(yīng)用環(huán)境 10.2V/F轉(zhuǎn)換原理及用V/F轉(zhuǎn)換器實現(xiàn)A/D轉(zhuǎn)換的方法 10.2.1V/F轉(zhuǎn)換原理 10.2.2用V/F轉(zhuǎn)換器實現(xiàn)A/D轉(zhuǎn)換的方法 10.3常用V/F轉(zhuǎn)換器簡介 10.3.1VFC32 10.3.2LMX31系列V/F轉(zhuǎn)換器 10.3.3AD650 10.3.4AD651 10.4V/F轉(zhuǎn)換應(yīng)用系統(tǒng)中的通道結(jié)構(gòu) 10.5LM331應(yīng)用實例 10.5.1線路原理 10.5.2軟件設(shè)計 10.6AD650應(yīng)用實例 10.6.1AD650外圍電路設(shè)計 10.6.2定時/計數(shù)器(8253—5簡介) 10.6.3線路原理 10.6.4軟件設(shè)計 第十一章串行通訊接口技術(shù) 11.1串行通訊基礎(chǔ) 11.1.1異步通訊和同步通訊 11.1.2波特率和接收/發(fā)送時鐘 11.1.3單工、半雙工、全雙工通訊方式 11.14信號的調(diào)制與解調(diào) 11.1.5通訊數(shù)據(jù)的差錯檢測和校正 11.1.6串行通訊接口電路UART、USRT和USART 11.2串行通訊總線標(biāo)準(zhǔn)及其接口 11.2.1串行通訊接口 11.2.2RS-232C接口 11.2.3RS-449、RS-422、RS-423及RS485 11.2.420mA電流環(huán)路串行接口 11.3MCS-51單片機串行接口 11.3.1串行口的結(jié)構(gòu) 11.3.2串行接口的工作方式 11.3.3串行通訊中波特率設(shè)置 11.4MCS-51單片機串行接口通訊技術(shù) 11.4.1單片機雙機通訊技術(shù) 11.4.2單片機多機通訊技術(shù) 11.5IBMPC系列機與單片機的通訊技術(shù) 11.5.1異步通訊適配器 11.5.2IBM-PC機與8031雙機通訊技術(shù) 11.5.3IBM—PC機與8031多機通訊技術(shù) 11.6MCS-51單片機串行接口的擴展 11.6.1Intel8251A可編程通訊接口 11.6.2擴展多路串行口的硬件設(shè)計 11.6.3通訊軟件設(shè)計 第十二章應(yīng)用系統(tǒng)設(shè)計中的實用技術(shù) 12.1MCS-51單片機低功耗系統(tǒng)設(shè)計 12.1.1CHMOS型單片機80C31/80C51/87C51的組成與使用要點 12.1.2CHMOS型單片機的空閑、掉電工作方式 12.1.3CHMOS型單片機的I/O接口及應(yīng)用系統(tǒng)實例 12.1.4HMOS型單片機的節(jié)電運行方式 12.2邏輯電平接口技術(shù) 12.2.1集電極開路門輸出接口 12.2.2TTL、HTL、ECL、CMOS電平轉(zhuǎn)換接口 12.3電壓/電流轉(zhuǎn)換 12.3.1電壓/0~10mA轉(zhuǎn)換 12.3.2電壓1~5V/4~20mA轉(zhuǎn)換 12.3.30~10mA/0~5V轉(zhuǎn)換 12.344~20mA/0~5V轉(zhuǎn)換 12.3.5集成V/I轉(zhuǎn)換電路 12.4開關(guān)量輸出接口技術(shù) 12.4.1輸出接口隔離技術(shù) 12.4.2低壓開關(guān)量信號輸出技術(shù) 12.4.3繼電器輸出接口技術(shù) 12.4.4可控硅(晶閘管)輸出接口技術(shù) 12.4.5固態(tài)繼電器輸出接口 12.4.6集成功率電子開關(guān)輸出接口 12.5集成穩(wěn)壓電路 12.5.1電源隔離技術(shù) 12.5.2三端集成穩(wěn)壓器 12.5.3高精度電壓基準(zhǔn) 12.6量程自動轉(zhuǎn)換技術(shù) 12.6.1自動轉(zhuǎn)換量程的硬件電路 12.6.2自動轉(zhuǎn)換量程的軟件設(shè)計 附錄AMCS-51單片機指令速查表 附錄B常用EPROM固化電壓參考表 參考文獻
標(biāo)簽: MCS 51 單片機實用 接口技術(shù)
上傳時間: 2013-10-15
上傳用戶:himbly
MCS-51系列單片機是美國Intel公司在1980年推出的高性能8位單片機,它包含51和52 兩個子系列。 對于51子系列,主要有8031、8051、8751 三種機型,它們的指令系統(tǒng)與芯片引腳完全兼容,僅片內(nèi)程序存儲器有所不同,8031芯片不帶ROM,8051芯片帶4KROM,8751芯片帶4KEPROM。51子系列的主要特點為: ◆8位CPU。 ◆片內(nèi)帶振蕩器,頻率范圍1.2~12MHZ。 ◆片內(nèi)帶128字節(jié)的數(shù)據(jù)存儲器。 ◆片內(nèi)帶4K的程序存儲器。 ◆程序存儲器的尋址空間為64K字節(jié)。 ◆片外數(shù)據(jù)存儲器的尋址空間為64K字節(jié)。 ◆128個用戶位尋址空間。
上傳時間: 2013-11-05
上傳用戶:cxl274287265
摘要:文章介紹了一種以8031單片機為核心片外擴展at93c46電擦除可編程只讀存儲器并帶有數(shù)碼LED顯示時.分.秒和以指示燈做標(biāo)志的按鍵校時自動打鈴器。 關(guān)鍵詞:單片機 存儲器 數(shù)碼管
上傳時間: 2013-11-01
上傳用戶:refent
摘要:鍵盤擔(dān)負(fù)著向系統(tǒng)發(fā)出命令和查詢系統(tǒng)工作狀態(tài)的重任。由于各種單片機所提供的片內(nèi)外資源不同,所以在進行鍵盤擴展時其硬件電路的形式也多種多樣。文中介紹了利用單片機內(nèi)部的A/D轉(zhuǎn)換通道、并行口以及片外擴展芯片等方法擴展鍵盤的硬件電路及電路工作原理,并給出了部分程序。關(guān)鍵詞:單片機;鍵盤;A/D轉(zhuǎn)換;并行口;串行口
標(biāo)簽: 單片機 應(yīng)用系統(tǒng) 鍵盤 擴展方法
上傳時間: 2013-11-15
上傳用戶:kang1923
一、實驗要求編制程序,對實驗箱上提供的外部存貯器(62256)進行讀寫操作。二、實驗?zāi)康恼莆针S機存儲器的讀寫方法。三、實驗說明1.單片機系統(tǒng)中,對片外存貯器的讀寫操作是最基本的操作。通過本實驗了解單片機讀寫片外存儲器的讀寫方法,并藉此來熟悉MCS51單片機編程的基本規(guī)則、基本指令的使用和調(diào)試程序的方法。2.ADuC831片內(nèi)有2K字節(jié)XRAM,當(dāng)堆棧不擴展使用時,片內(nèi)XRAM占用外部數(shù)據(jù)存儲空間的低2K字節(jié),所以,尋址片外數(shù)據(jù)存儲器時要大于2K字節(jié)空間。四、實驗電路連線本實驗不需要連線。
上傳時間: 2013-11-11
上傳用戶:liu999666
摘要:本文主要結(jié)合51單片機系統(tǒng)的硬件資源特點,從指針結(jié)構(gòu)聲明,對于不同存儲區(qū)(片內(nèi)、片外數(shù)據(jù)存儲區(qū)和程序存儲區(qū))的指針尋址的實現(xiàn)等方面闡述了單片機C語言才勻針的應(yīng)用。關(guān)鍵詞:單片機C語言 指針
上傳時間: 2013-10-09
上傳用戶:libenshu01
8031單片機的中斷系統(tǒng)簡單實用,其基本特點是:有5個固定的可屏蔽中斷源,3個在片內(nèi),2個在片外,它們在程序存儲器中各有固定的中斷入口地址,由此進入中斷服務(wù)程序;5個中斷源有兩級中斷優(yōu)先級,可形成中斷嵌套;2個特殊功能寄存器用于中斷控制和條件設(shè)置的編程。
標(biāo)簽: 51單片機 中斷系統(tǒng)
上傳時間: 2014-12-27
上傳用戶:1214209695
P87LPC767 OTP 單片機原理 P87LPC767 是20 腳封裝的單片機適合于許多要求高集成度低成本的場合可以滿足許多方面的性能要求作為Philips 小型封裝系列中的一員P87LPC767 提供高速和低速的晶振和RC 振蕩方式可編程選擇具有較寬的操作電壓范圍可編程I/O 口線輸出模式選擇可選擇施密特觸發(fā)輸入LED 驅(qū)動輸出有內(nèi)部看門狗定時器P87LPC767 采用80C51 加速處理器結(jié)構(gòu)指令執(zhí)行速度是標(biāo)準(zhǔn)80C51 MCU 的兩倍特性 操作頻率為20MHz 時除乘法和除法指令外加速80C51 指令執(zhí)行時間為300600ns VDD=4.5 5.5V 時時鐘頻率可達20MHz VDD=2.7 4.5V 時時鐘頻率最大為10MHz 4 通道多路8 位A/D 轉(zhuǎn)換器在振蕩器頻率fosc=20MHz 時轉(zhuǎn)換時間為9.3μs 用于數(shù)字功能時操作電壓范圍為2.7 6.0V 4K 字節(jié)OTP 程序存儲器128 字節(jié)的RAM 32Byte 用戶代碼區(qū)可用來存放序列碼及設(shè)置參數(shù) 2 個16 位定時/計數(shù)器每一個定時器均可設(shè)置為溢出時觸發(fā)相應(yīng)端口輸出 內(nèi)含 2 個模擬比較器 全雙工通用異步接收/發(fā)送器UART 及I2C 通信接口 八個鍵盤中斷輸入另加2 路外部中斷輸入 4 個中斷優(yōu)先級 看門狗定時器利用片內(nèi)獨立振蕩器,無需外接元件,看門狗定時器溢出時間有8 種選擇 低電平復(fù)位使用片內(nèi)上電復(fù)位時不需要外接元件 低電壓復(fù)位選擇預(yù)設(shè)的兩種電壓之一復(fù)位可在掉電時使系統(tǒng)安全關(guān)閉也可將其設(shè)置為一個中斷源 振蕩器失效檢測看門狗定時器具有獨立的片內(nèi)振蕩器因此它可用于振蕩器的失效檢測 可配置的片內(nèi)振蕩器及其頻率范圍和RC 振蕩器選項(用戶通過對EPROM 位編程選擇) 選擇RC 振蕩器時不需外接振蕩器件 可編程 I/O 口輸出模式準(zhǔn)雙向口,開漏輸出,上拉和只有輸入功能可選擇施密特觸發(fā)輸入 所有口線均有20mA 的驅(qū)動能力 可控制口線輸出轉(zhuǎn)換速度以降低EMI,輸出最小上升時間約為10ns 最少 15 個I/O 口,選擇片內(nèi)振蕩和片內(nèi)復(fù)位時可多達18 個I/O 口 如果選擇片內(nèi)振蕩及復(fù)位時,P87LPC767 僅需要連接電源線和地線 串行 EPROM 編程允許在線編程2 位EPROM 安全碼可防止程序被讀出 空閑和掉電兩種省電模式提供從掉電模式中喚醒功能低電平中斷輸入啟動運行典型的掉電電流為1μA 低功耗 4MHz-20MHz,1.7-10mA@3.3v 100KHz-4MHz,0.044-1.7mA@3.3v 20KHz-100KHz,9-44μA@3.3v 20 腳DIP 和SO 封裝
上傳時間: 2013-11-06
上傳用戶:xcy122677
單片機在鍵盤上的應(yīng)用 鍵盤擔(dān)負(fù)著向系統(tǒng)發(fā)出命令和查詢系統(tǒng)工作狀態(tài)的重任。由于各種單片機所提供的片內(nèi)外資源不同,所以在進行鍵盤擴展時其硬件電路的形式也多種多樣。文中介紹了利用單片機內(nèi)部的A /D轉(zhuǎn)換通道、并行口以及片外擴展芯片等方法擴展鍵盤的硬件電路及電路工作原理,并給出了部分程序。
上傳時間: 2013-11-11
上傳用戶:silenthink
單片機指令系統(tǒng)原理 51單片機的尋址方式 學(xué)習(xí)匯編程序設(shè)計,要先了解CPU的各種尋址法,才能有效的掌握各個命令的用途,尋址法是命令運算碼找操作數(shù)的方法。在我們學(xué)習(xí)的8051單片機中,有6種尋址方法,下面我們將逐一進行分析。 立即尋址 在這種尋址方式中,指令多是雙字節(jié)的,一般第一個字節(jié)是操作碼,第二個字節(jié)是操作數(shù)。該操作數(shù)直接參與操作,所以又稱立即數(shù),有“#”號表示。立即數(shù)就是存放在程序存儲器中的常數(shù),換句話說就是操作數(shù)(立即數(shù))是包含在指令字節(jié)中的。 例如:MOV A,#3AH這條指令的指令代碼為74H、3AH,是雙字節(jié)指令,這條指令的功能是把立即數(shù)3AH送入累加器A中。MOV DPTR,#8200H在前面學(xué)單片機的專用寄存器時,我們已學(xué)過,DPTR是一個16位的寄存器,它由DPH及DPL兩個8位的寄存器組成。這條指令的意思就是把立即數(shù)的高8位(即82H)送入DPH寄存器,把立即數(shù)的低8位(即00H)送入DPL寄存器。這里也特別說明一下:在80C51單片機的指令系統(tǒng)中,僅有一條指令的操作數(shù)是16位的立即數(shù),其功能是向地址指針DPTR傳送16位的地址,即把立即數(shù)的高8位送入DPH,低8位送入DPL。 直接尋址 直接尋址方式是指在指令中操作數(shù)直接以單元地址的形式給出,也就是在這種尋址方式中,操作數(shù)項給出的是參加運算的操作數(shù)的地址,而不是操作數(shù)。例如:MOV A,30H 這條指令中操作數(shù)就在30H單元中,也就是30H是操作數(shù)的地址,并非操作數(shù)。 在80C51單片機中,直接地址只能用來表示特殊功能寄存器、內(nèi)部數(shù)據(jù)存儲器以及位地址空間,具體的說就是:1、內(nèi)部數(shù)據(jù)存儲器RAM低128單元。在指令中是以直接單元地址形式給出。我們知道低128單元的地址是00H-7FH。在指令中直接以單元地址形式給出這句話的意思就是這0-127共128位的任何一位,例如0位是以00H這個單元地址形式給出、1位就是以01H單元地址給出、127位就是以7FH形式給出。2、位尋址區(qū)。20H-2FH地址單元。3、特殊功能寄存器。專用寄存器除以單元地址形式給出外,還可以以寄存器符號形式給出。例如下面我們分析的一條指令 MOV IE,#85H 前面的學(xué)習(xí)我們已知道,中斷允許寄存器IE的地址是80H,那么也就是這條指令可以以MOV IE,#85H 的形式表述,也可以MOV 80H,#85H的形式表述。 關(guān)于數(shù)據(jù)存儲器RAM的內(nèi)部情況,請查看我們課程的第十二課。 直接尋址是唯一能訪問特殊功能寄存器的尋址方式! 大家來分析下面幾條指令:MOV 65H,A ;將A的內(nèi)容送入內(nèi)部RAM的65H單元地址中MOV A,direct ;將直接地址單元的內(nèi)容送入A中MOV direct,direct;將直接地址單元的內(nèi)容送直接地址單元MOV IE,#85H ;將立即數(shù)85H送入中斷允許寄存器IE 前面我們已學(xué)過,數(shù)據(jù)前面加了“#”的,表示后面的數(shù)是立即數(shù)(如#85H,就表示85H就是一個立即數(shù)),數(shù)據(jù)前面沒有加“#”號的,就表示后面的是一個地址地址(如,MOV 65H,A這條指令的65H就是一個單元地址)。 寄存器尋址 寄存器尋址的尋址范圍是:1、4個工作寄存器組共有32個通用寄存器,但在指令中只能使用當(dāng)前寄存器組(工作寄存器組的選擇在前面專用寄存器的學(xué)習(xí)中,我們已知道,是由程序狀態(tài)字PSW中的RS1和RS0來確定的),因此在使用前常需要通過對PSW中的RS1、RS0位的狀態(tài)設(shè)置,來進行對當(dāng)前工作寄存器組的選擇。2、部份專用寄存器。例如,累加器A、通用寄存器B、地址寄存器DPTR和進位位CY。 寄存器尋址方式是指操作數(shù)在寄存器中,因此指定了寄存器名稱就能得到操作數(shù)。例如:MOV A,R0這條指令的意思是把寄存器R0的內(nèi)容傳送到累加器A中,操作數(shù)就在R0中。INC R3這條指令的意思是把寄存器R3中的內(nèi)容加1 從前面的學(xué)習(xí)中我產(chǎn)應(yīng)可以理解到,其實寄存器尋址方式就是對由PSW程序狀態(tài)字確定的工作寄存器組的R0-R7進行讀/寫操作。 寄存器間接尋址 寄存間接尋址方式是指寄存器中存放的是操作數(shù)的地址,即操作數(shù)是通過寄存器間接得到的,因此稱為寄存器間接尋址。 MCS-51單片機規(guī)定工作寄存器的R0、R1做為間接尋址寄存器。用于尋址內(nèi)部或外部數(shù)據(jù)存儲器的256個單元。為什么會是256個單元呢?我們知道,R0或者R1都是一個8位的寄存器,所以它的尋址空間就是2的八次方=256。例:MOV R0,#30H ;將值30H加載到R0中 MOV A,@R0 ;把內(nèi)部RAM地址30H內(nèi)的值放到累加器A中 MOVX A,@R0 ;把外部RAM地址30H內(nèi)的值放到累加器A中 大家想想,如果用DPTR做為間址寄存器,那么它的尋址范圍是多少呢?DPTR是一個16位的寄存器,所以它的尋址范圍就是2的十六次方=65536=64K。因用DPTR做為間址寄存器的尋址空間是64K,所以訪問片外數(shù)據(jù)存儲器時,我們通常就用DPTR做為間址寄存器。例:MOV DPTR,#1234H ;將DPTR值設(shè)為1234H(16位) MOVX A,@DPTR ;將外部RAM或I/O地址1234H內(nèi)的值放到累加器A中 在執(zhí)行PUSH(壓棧)和POP(出棧)指令時,采用堆棧指針SP作寄存器間接尋址。例:PUSH 30H ;把內(nèi)部RAM地址30H內(nèi)的值放到堆棧區(qū)中堆棧區(qū)是由SP寄存器指定的,如果執(zhí)行上面這條命令前,SP為60H,命令執(zhí)行后會把內(nèi)部RAM地址30H內(nèi)的值放到RAM的61H內(nèi)。 那么做為寄存器間接尋址用的寄存器主要有哪些呢?我們前面提到的有四個,R0、R1、DPTR、SP 寄存器間接尋址范圍總結(jié):1、內(nèi)部RAM低128單元。對內(nèi)部RAM低128單元的間接尋址,應(yīng)使用R0或R1作間址寄存器,其通用形式為@Ri(i=0或1)。 2、外部RAM 64KB。對外部RAM64KB的間接尋址,應(yīng)使用@DPTR作間址尋址寄存器,其形式為:@DPTR。例如MOVX A,@DPTR;其功能是把DPTR指定的外部RAM的單元的內(nèi)容送入累加器A中。外部RAM的低256單元是一個特殊的尋址區(qū),除可以用DPTR作間址寄存器尋址外,還可以用R0或R1作間址寄存器尋址。例如MOVX A,@R0;這條指令的意思是,把R0指定的外部RAM單元的內(nèi)容送入累加器A。 堆棧操作指令(PUSH和POP)也應(yīng)算作是寄存器間接尋址,即以堆棧指針SP作間址寄存器的間接尋址方式。 寄存器間接尋址方式不可以訪問特殊功能寄存器!! 寄存器間接尋址也須以寄存器符號的形式表示,為了區(qū)別寄存器尋址我寄存器間接尋址的區(qū)別,在寄存器間接尋址方式式中,寄存器的名稱前面加前綴標(biāo)志“@”。 基址寄存器加變址寄存器的變址尋址 這種尋址方式以程序計數(shù)器PC或DPTR為基址寄存器,累加器A為變址寄存器,變址尋址時,把兩者的內(nèi)容相加,所得到的結(jié)果作為操作數(shù)的地址。這種方式常用于訪問程序存儲器ROM中的數(shù)據(jù)表格,即查表操作。變址尋址只能讀出程序內(nèi)存入的值,而不能寫入,也就是說變址尋址這種方式只能對程序存儲器進行尋址,或者說它是專門針對程序存儲器的尋址方式。例:MOVC A,@A+DPTR這條指令的功能是把DPTR和A的內(nèi)容相加,再把所得到的程序存儲器地址單元的內(nèi)容送A假若指令執(zhí)行前A=54H,DPTR=3F21H,則這條指令變址尋址形成的操作數(shù)地址就是54H+3F21H=3F75H。如果3F75H單元中的內(nèi)容是7FH,則執(zhí)行這條指令后,累加器A中的內(nèi)容就是7FH。 變址尋址的指令只有三條,分別如下:JMP @A+DPTRMOVC A,@A+DPTRMOVC A,@A+PC 第一條指令JMP @A+DPTR這是一條無條件轉(zhuǎn)移指令,這條指令的意思就是DPTR加上累加器A的內(nèi)容做為一個16位的地址,執(zhí)行JMP這條指令是,程序就轉(zhuǎn)移到A+DPTR指定的地址去執(zhí)行。 第二、三條指令MOVC A,@A+DPTR和MOVC A,@A+PC指令這兩條指令的通常用于查表操作,功能完全一樣,但使用起來卻有一定的差別,現(xiàn)詳細說明如下。我們知道,PC是程序指針,是十六位的。DPTR是一個16位的數(shù)據(jù)指針寄存器,按理,它們的尋址范圍都應(yīng)是64K。我們在學(xué)習(xí)特殊功能寄存器時已知道,程序計數(shù)器PC是始終跟蹤著程序的執(zhí)行的。也就是說,PC的值是隨程序的執(zhí)行情況自動改變的,我們不可以隨便的給PC賦值。而DPTR是一個數(shù)據(jù)指針,我們就可以給空上數(shù)據(jù)指針DPTR進行賦值。我們再看指令MOVC A,@A+PC這條指令的意思是將PC的值與累加器A的值相加作為一個地址,而PC是固定的,累加器A是一個8位的寄存器,它的尋址范圍是256個地址單元。講到這里,大家應(yīng)可明白,MOVC A,@A+PC這條指令的尋址范圍其實就是只能在當(dāng)前指令下256個地址單元。所在,這在我們實際應(yīng)用中,可能就會有一個問題,如果我們需要查詢的數(shù)據(jù)表在256個地址單元之內(nèi),則可以用MOVC A,@A+PC這條指令進行查表操作,如果超過了256個單元,則不能用這條指令進行查表操作。剛才我們已說到,DPTR是一個數(shù)據(jù)指針,這個數(shù)據(jù)指針我們可以給它賦值操作的。通過賦值操作。我們可以使MOVC A,@A+DPTR這條指令的尋址范圍達到64K。這就是這兩條指令在實際應(yīng)用當(dāng)中要注意的問題。 變址尋址方式是MCS-51單片機所獨有的一種尋址方式。 位尋址 80C51單片機有位處理功能,可以對數(shù)據(jù)位進行操作,因此就有相應(yīng)的位尋址方式。所謂位尋址,就是對內(nèi)部RAM或可位尋址的特殊功能寄存器SFR內(nèi)的某個位,直接加以置位為1或復(fù)位為0。 位尋址的范圍,也就是哪些部份可以進行位尋址: 1、我們在第十二課學(xué)習(xí)51單片機的存儲器結(jié)構(gòu)時,我們已知道在單片機的內(nèi)部數(shù)據(jù)存儲器RAM的低128單元中有一個區(qū)域叫位尋址區(qū)。它的單元地址是20H-2FH。共有16個單元,一個單元是8位,所以位尋址區(qū)共有128位。這128位都單獨有一個位地址,其位地址的名字就是00H-7FH。這里就有一個比較麻煩的問題需要大家理解清楚了。我們在前面的學(xué)習(xí)中00H、01H。。。。7FH等等,所表示的都是一個字節(jié)(或者叫單元地址),而在這里,這些數(shù)據(jù)都變成了位地址。我們在指令中,或者在程序中如何來區(qū)分它是一個單元地址還是一個位地址呢?這個問題,也就是我們現(xiàn)在正在研究的位尋址的一個重要問題。其實,區(qū)分這些數(shù)據(jù)是位地址還是單元地址,我們都有相應(yīng)的指令形式的。這個問題我們在后面的指令系統(tǒng)學(xué)習(xí)中再加以論述。 2、對專用寄存器位尋址。這里要說明一下,不是所有的專用寄存器都可以位尋址的。具體哪些專用寄存器可以哪些專用寄存器不可以,請大家回頭去看看我們前面關(guān)于專用寄存器的相關(guān)文章。一般來說,地址單元可以被8整除的專用寄存器,通常都可以進行位尋址,當(dāng)然并不是全部,大家在應(yīng)用當(dāng)中應(yīng)引起注意。 專用寄存器的位尋址表示方法: 下面我們以程序狀態(tài)字PSW來進行說明 D7 D6 D5 D4 D3 D2 D1 D0 CY AC F0 RS1 RS0 OV P 1、直接使用位地址表示:看上表,PSW的第五位地址是D5,所以可以表示為D5H MOV C,D5H 2、位名稱表示:表示該位的名稱,例如PSW的位5是F0,所以可以用F0表示 MOV C,F(xiàn)0 3、單元(字節(jié))地址加位表示:D0H單元位5,表示為DOH.5 MOV C,D0H.5 4、專用寄存器符號加位表示:例如PSW.5 MOV C,PSW.5 這四種方法實現(xiàn)的功能都是相同的,只是表述的方式不同而已。 例題: 1. 說明下列指令中源操作數(shù)采用的尋址方式。 MOV R5,R7 答案:寄存器尋址方式 MOV A,55H 直接尋址方式 MOV A,#55H 立即尋址方式 JMP @A+DPTR 變址尋址方式 MOV 30H,C 位尋址方式 MOV A,@R0 間接尋址方式 MOVX A,@R0 間接尋址方式 改錯題 請判斷下列的MCS-51單片機指令的書寫格式是否有錯,若有,請說明錯誤原因。 MOV R0,@R3 答案:間址寄存器不能使用R2~R7。 MOVC A,@R0+DPTR 變址尋址方式中的間址寄存器不可使用R0,只可使用A。 ADD R0,R1 運算指令中目的操作數(shù)必須為累加器A,不可為R0。 MUL AR0 乘法指令中的乘數(shù)應(yīng)在B寄存器中,即乘法指令只可使用AB寄存器組合。
標(biāo)簽: 單片機指令 系統(tǒng)原理
上傳時間: 2013-11-11
上傳用戶:caozhizhi
蟲蟲下載站版權(quán)所有 京ICP備2021023401號-1