单片机原理及其应用
实验指导书
南通大学电气工程学院
自动化系
2012 年 3 月
前 言
单片机目前已广泛应用在智能仪表、工业控制、家用电器等各个领域,成为现代电子系统的一个极其重要的组成部分,对于电类专业学生来说,掌握单片机知识,具备基本应用技能,才能符合当前社会对专业人才的要求。
单片机是一门应用性极强的课程,学生在掌握基本理论知识的基础上,更要通过实验训练,提高其调试动手能力,学会解决具体问题的思路和手段,具备初步的系统设计和调试能力。
因此,为了更好地做好单片机课程的软硬件实验,特编写本实验指导书,书中叙述了各实验的目的、要求,对于设计性实验,给出了列出了接线图、程序结构框图和清单。学生按要求完成本实验指导书中的实验,可基本掌握MCS-51单片机的结构原理、接口技术以及程序设计技巧。另外:
一、所有实验都是相互独立的,次序上也没有固定的先后关系,在使用本书进行教学时,教师可根据教学要求,选择相应实验。
二、对同一问题的解决方法往往不是唯一的,欢迎各位指导教师在使用本实验指导书的过程中提出更完善的实验方案,指出书中的错误和不足,并希望大家反馈给我们,以便及时修改。
I
目 录
第一章 集成开发环境简介…………………………………… 1 第二章 演示程序……………………………………………… 9 第三章 实验项目……………………………………………… 15
实验一 简单程序设计实验……………………………………… 15 实验二 I/O口实验……………………………………………… 18 实验三 定时器实验……………………………………………… 20 实验四 A/D、D/A转换实验 …………………………………… 21 实验五 并行接口扩展实验……………………………………… 25
II
第一章 集成开发环境简介
Super ICES-51 80C51单片机实验仪使用当前流行的Keil C51开发软件,采用uVision2集成开发环境。 1.1 Keil C51简介
Keil C51软件是德国Keil 公司开发的功能完善的C51开发软件,近年来在国内得到了迅速普及。Keil包括以下几个部分:uVision2 IDE、C51编译器、A51汇编器、LIB库管理器、BL51连接器/定位器、uVision硬件调试器、RTX51实时多任务操作系统。Keil软件的最新版本是7.50。用户可以向Keil公司或国内代理商购买正版软件或索取Demo版本,也可以直接到Keil公司网站(http://www.keil.com)下载。 1.2 uVision2 集成开发环境
uVision2集成开发环境如图1-1所示,有编辑、项目、输出等3个大窗口
和File、Edit、View、Project、Debug、Periherals、Tools、SVCS、Windows、Help等下拉菜单。
项目名称栏
工具菜单栏
快捷图标
工程项目窗口 编辑区 输出信息窗变量观察区 存储器观察
图1-1 uVision2 集成开发环境
1
1.2.1 创建、保存工程文件
在uVision2环境下,使用工程来管理各个文件。为了开始新的工程,选择“Project/New Projiect”选项,出现如图1-2所示界面。
图1-2 创建新工程
然后选择此新工程要保存的路径,键入项目名称并保存,项目名称将会出现在集成环境的左上端,名称后缀为“.uv2”,如图1-3所示。
注意项目名称最好不要超过8个字符、尽量不采用中文,与软件编程时变量的命名习惯一致。
图1-3 保存新工程
2
1.2.2 MCU选择
接着系统出现“Select Device for Target”界面,要求选择目标硬件系统的MCU,如图1-4所示。选择要开发的目标硬件系统的MCU,点击“确定”即可。
对于Super ICES-51实验仪,应选择Atlmel的AT89C51。
1.2.3 添加源文件
如图1-5所示,在“Target 1/Source Group 1”上点击右键,选择“/Add Files to Group ?Source Group 1?” 后,出现如图1-6所示界面,添加所要的源程序。
源程序包括“*.C”、“*.ASM”、“*.LIB”、“*.A51”等。
3
图1-4 MCU选择
图1-5 添加源文件
图1-6 选择待添加的源文件
4
1.2.4 目标硬件系统配置
源程序添加完毕后,进行“Option for Target”的设定。在菜单栏中,选择“Project/Option for Target…”,出现如图1-7所示界面。
点击Target选项卡,输入目标硬件系统的晶振频率,本实验仪为11.0592 MHz;
点击Output选项卡,选中Crest Hex File 选项,在编译时系统将会自动生成目标代码文件*.HEX;
点击 Debug选项卡,如图1-8所示,选择仿真模式等。
图1-7 目标硬件系统配置
5
图1-8 debug配置
uVision2的仿真模式分为Use Simulator(软件仿真)和Use(硬件仿真)2种。
其中Use Simulator选项是将uVision2调试器设置成软件模拟仿真模式,在此模式下不需要实际的目标硬件就可以模拟8051单片机的很多功能。Use Simulator中的“Load Application at Start”是装入程序的复选框,“Go till main()”是表示从应用程序的主函数开始执行的复选框。除非有特殊情况,一般都同时使用这两复选框。
Use选项有高级的GDI驱动(ICES仿真器)和Keil Monitor-51驱动。运用此功能可以把Keil C51 嵌入到自己的系统中去,从而实现在目标硬件上调试程序。实验仪选择“use keil Monitor-51 Driver”。
选择 “load Application at start”,在启动时直接装载程序,选择“Go till main”,C51开发时,装载后直接运行到main函数。
6
硬件仿真模式下还需配置波特率等,点击“Settings”选项,如图1-9所示。
选择“serial interrupt”,在前面打勾,否则装载过程中,仿真器会发出“嘀”一声长声报警,仿真结果将可能不正确。
选择正确的串口号,波特率最高为38400; 建议只选cache code。
1.2.5 程序编译、连接与下载
使用“Project”下拉菜单中的编译命令,“Build Target”(在项目窗口中的修改过的程序;“Rebuild all Target File”(所有的源程序文件。
)只编译和连接
图1-9 串口等配置
)编译和连接项目里
7
编译等无误后,使用菜单栏中的“Debug”下“/start/stop Debug Session”或使用快捷方式(
图1-10 硬件调试系统界面
)进入硬件调试系统,如图1-10所示。
“Debug”下“Step”或用快捷方式()进行单步(进子程序)调试;
)进行单步(不进子程序)调试;
)进行运行到当前光标处
“Debug”下“Step Over”或用快捷方式(
“Debug”下“Run to cursor line”或用快捷方式(调试;
“Debug”下“Go”或用快捷方式(
)进行全速运行,直到下一个有效断点;
“Debug”下“/start/stop Debug Session”进入、退出硬件调试系统环境。 另外,“Debug”下还有“stop running”、“rst”等操作。
8
第二章 演示程序
为了更好地熟悉uVision2集成开发环境仿真开发系统的应用,本指导书提供了一个完整的程序编译、调试例子,详细说明集成环境下的各种操作。
程序内容:将1~10十个数相加,并把其和放入内部 RAM 30H 单元。
这个问题有好几种算法,如果单纯从算法上来说,下面所列算法并不是最优的,因为其目的在于让你熟悉仿真系统的各种操作。
算法介绍:
1.加数、被加数、和最终单元(SUM)首先设置初始值,分别为1、0、0,加法次数单元(R2)设为10;
2.每次加法所得中间结果存放在被加数单元中(累加器ACC),同时将加数单元增1;
3.做完一次加法后,加法次数单元减1,并判断是否已为0(即已做完10次加法),如果不为0,继续做下次加法,若为0,则将累加器内容赋值给和最终单元;
4.做完后,程序原地循环。
算法流程图及源程序分别如下:
9
结果放入 和最终单元 N 已做完10 次加法? Y 加数增1 被加数+加数,结果放在被加数(和中间结果)单元 加数、被加数(和中间结果)、和最终结果单元、加法次数单元初始化 堆栈初始化 10
源程序:
;变量DATA_REG中的内容为加数(1-10);
;ACC中的内容为被加数,同时也是每一次加法后的和中间结果存放单元; ;做完10次加法后,再将ACC内容放入指定的和单元SUM中。 ;******************************************************** DATA_REG SUM
EQU EQU
31H 30H
;定义加数单元 ;定义和单元
;=========================================================
ORG
0000H
;复位后PC指针
LJMP MAIN ORG
0100H
;从程序存储空间 0100H 单元放程序
;---------------------------------------------------------
MAIN:
MOV DATA_REG, #1 MOV SUM, #00H MOV R2, #10 CLR CLR
A C
;被加数+加数,结果放入ACC ;加数增1
;10次加法未做完,继续做
;10次加法已做完,将和放入SUM单元 ;原地循环
;加数单元初始值为1 ;和单元初始值为0 ;加法循环次数为10 被加数单元初始值为0 ;进位初始值为0
MOV SP, #70H
;堆栈指针从复位后的 07H 调整到 70H
ADD_LOOP:
ADDC A, DATA_REG INC
DATA_REG
DJNZ R2, ADD_LOOP MOV SUM,A LJMP $
;*********************************************************
END
11
2.1 打开仿真环境,新建一个工程文件
按第一章介绍建立一个工程名为“test.uv2”的工程文件,选择目标硬件系统的MCU为Atlmel的AT89C51;目标硬件系统配置选择“Use Simulator”,其余配置参考第一章介绍。
2.2 输入源程序
单击菜单“File/New”,出现源程序编辑窗口,输入源程序,以“*.asm”保存,选择“/Add Files to Group ?Source Group 1?”,将此源程序添加到工程中,如图2-1所示。
2.3 源程序编译、连接
单击“project/rebuild all target files”菜单或者按 按纽,仿真环境则对源文件进行编译连接,视程序正确与否,有两种编译结果:
若程序无误,编译通过,出现如图2-2所示的编译信息窗口,说明编译成功。
图2-1 包含源程序的工程界面
12
图2-2 编译成功的信息窗口
若源程序有误,则出现如下的编译连接信息窗口,说明编译错误。可双击错误信息,则在源文件编辑窗口中自动显示出错信息所在行。
2.4 程序调试
图2-3 编译不成功的信息窗口
源程序编译通过并不代表程序就一定正确,这只能说明程序已经没有语法上的错误了,至于在算法、流程上是否正确,则需要对程序进行调试,如果程序运行结果符合事先设计的算法、流程,那么这才能说编写的程序是正确的。
初学者很容易犯急噪的毛病,即程序编译通过后,急着让程序连续运行,若运行通过(即结果正确),则认为程序就正确了,其实,这样做并不能说明程序完全正确,有时一个程序对于某些初始条件,可以得到正确结果,而初始条件改变后,却发现结果错误。
程序调试的一般做法是:
编译、连接通过后,不要急于让程序连续运行,而是先进行手动的单步调试,随时观察各个变量、RAM单元、流程跳转等是否符合算法规定,排除各种非语法性错误,直至程序完全正确;
对于复杂程序,必须设计成模块化结构,调试时一个一个模块单独调试,每个模块均正确后,再进行整个程序的调试。
在调试过程中,充分利用断点、变量窗口、寄存器窗口、内部RAM窗口等各种工具,提高程序调试效率。
13
编译通过后,使用菜单栏中的“Debug”下“/start/stop Debug Session”或使用快捷方式(
为了观察每一次加法过程的变化,可通过“View / Memory Window”打开存储器观察窗口,在“Address”栏中输入“D:XXH”(XX为地址),观察内部RAM各单元变化情况。
“Address”栏中输入“D”表示内部RAM,“X”表示外部RAM,“C”表示程序存储空间。
可以用“Debug”选项下各种调试手段调试程序,如单步(进子程序)、单步(不进子程序)、运行到当前光标处、断点运行、全速运行等,以及停止、复位等等,以便进一步熟悉仿真系统的各种操作。
图2-4 程序调试界面
)进入硬件调试系统,如图2-4所示。
14
第三章 实验项目
实验一 简单程序设计实验
一、实验目的
掌握 uVision2 IDE单片机集成开发软件的应用,熟悉单片机仿真开发环境,掌握基本的单片机软件调试方法,为后续实验做好准备。
掌握单片机内部RAM之间、内外RAM之间、外部RAM之间的数据传送操作;掌握MCS-51汇编语言程序设计方法。
二、实验内容
1、置数程序
把2000H~20FFH的内容全部置成55H。
(1)实验程序框图 (2)实验步骤
用连续或单步方式运行程序,
检查2000~20FF单元中程序执行前后的内容变化。 (3)思考
假使把2000H~20FFH中的内容改成FFH,如何修改程序。
DPTR+1,R0+1 开 始 R0=00 55H送2000H R0=FFHY 结 束 N 15
2、拆字程序
把2000H的内容拆开,高位送2001H低位,低位送2002H低位,2001H、2002H高位清零,一般本程序用于把数据送显示缓冲区时用。 (1)实验程序框图
(2)实验步骤
用连续或单步方式运行程序,检查2000H~2002H单元中内容变化情况。 (3)思考
如何用断点方式调试本程序。
结 束 2000H内容送A 高低位交换,屏蔽高位后送2001H 2000H内容送A 屏蔽高位后送2002H 开 始 16
3、内部、外部RAM数据传送程序
按以下要求自行设计程序流程图,编写、调试程序。 (1) 内部RAM之间数据传送;
将内部RAM 40H~4FH单元内容传送到内部RAM 60H~6FH单元中。 源数据(首址存放在R2单元中);目的数据(首址存放在R4单元中);数据字节数存放在R6单元中。 (2) 内外RAM之间数据传送;
将内部RAM 40H~4FH单元内容传送到外部RAM 2040H~204FH单元中。 源数据(首址存放在R2单元中);目的数据(首址存放在DPTR0中);数据字节数存放在R6单元中。 (3) 外RAM之间数据传送;
将外部RAM 1000H~1111H单元内容传送到外部RAM 2000H~2111H单元中。
源数据(首址存放在DPTR0中);目的数据(首址存放在DPTR1中);数据字节数存放在R6.R7单元中。
17
实验二 I/O口实验
一、实验目的:
(1)学习单片机I/O口的使用方法; (2)学习延时子程序的编写;
(3)掌握基本的单片机硬件调试方法。
二、实验预备知识:
(1)P1口为准双向口,每位都可独立地定义为输入或输出,在作输入使用前,必须向口锁存器相应位写入“1”,该位才能作为输入;
(2)本实验中延时子程序采用循环来实现,定时时间=机器周期时间*程序总机器周期数(本实验箱晶振频率为11.0592 MHz)。
三、实验内容:
P1口做输出口,接八只发光二极管,编写程序,使发光二极管循环点亮。 (1)左移点亮1只发光二极管; (2)右移点亮1只发光二极管; (3)左移点亮2只相邻发光二极管; (4)右移点亮2只相邻发光二极管。
18
四、实验程序框图
给出实验内容(1)参考流程图,其余内容自行设计。
五、实验硬件连线
将P10---P17按顺序连接到LED1---LED8
+5V延 时 A左移一位 开 始 P1口初始化 点亮1位发光管 LD26_1LD26_2LD26_3LD26_4LD26_5LD26_6LD26_7R26_1LED1R26_2LED2R26_3LED3R26_4LED4R26_5LED5R26_6LED6R26_7LED7R26_8LED8LD26_8
六、实验思考
(1)修改延时常数,改变发光二极管闪亮时间; (2)修改程序,改变发光二极管闪亮个数、方向。
19
实验三 定时器实验
一、实验目的:
(1)学习单片机定时器的使用方法; (2)掌握单片机长定时方法;
(3)掌握基本的单片机定时器调试方法。
二、实验预备知识:
本实验箱晶振频率为11.0592 MHz,定时器工作方式1下最长定时时间为65536 us,如果要求定时时间大于此值,则可采用多次定时方法来实现长定时。
三、实验内容:
编写程序,使定时器每500 ms对内部RAM单元40H的内容加1,然后用P1口控制的8只发光二极管显示40H单元的二进制数值。
四、实验思考
修改定时时间,改变数值显示速度。
20
实验四 A/D、D/A转换实验
一、实验目的
1、掌握A/D、D/A转换芯片与单片机接口的方法; 2、了解A/D芯片ADC0809转换性能及编程方法; 3、了解D/A芯片DAC0832转换性能及编程方法; 4、了解如何通过A/D转换进行数据采集的基本方法; 5、了解如何通过D/A转换进行数字控制的基本方法。 二、实验内容
利用实验系统上的电位器提供ADC0809的模拟量输入,A/D转换后数字量送入DAC0832,产生模拟量输出,用电压表测量比较电位器输出电压和D/A输出电压。
三、实验预备知识
1、ADC0809是带8位A/D转换器,8路开关以及微处理机兼容的控制逻辑的CMOS组件,它是逐次逼近式A/D转换器,可以和单片机直接相连。
2、由于DAC0832为电流输出,为取得电压输出,需在电流输出端Iout1、Iout2分别接上运算放大器LM324的B-、B+;使Rfd与LM324的BOUT连接,Rfd即为运算放大器的负反馈电阻端;由于Vref=5V,所以由运算放大器输出电压(测试点BOUT)为负电压(0到-5V)。
21
四、实验原理图
22
五、实验硬件连线 1、ADC0809系统连线
(1)将跳线器插在JP22_1上;
(2)使用导线把MON51仿真器区的A0,A2,A3分别连接并行模数转换模块的DA,DB,DC;
(3)RD和WR分别接51MONI模块的RD和WR ; (4)使用导线连接A15和并行模数转换模块的CS;
(2)用导线连接MON51模块的AD0-AD7与并行数模转换模块的D0-D7; (6)使用导线连接INT0和并行模数转换模块的/EOC;
(7)并行模数转换模块的REF+,REF—分别连接VCC和GND ; (8)使用导线连接并行模数转换模块的IN0与电位器模块的中间脚VW,VH连接VCC,VL连接GND;
23
(9)实时时钟模块的1/64分频与并行模数转换模块的CLK相连。实时时钟加2M的晶振,用导线连接CLK-IN与2MHZ; 2、DAC0832系统连线
(1)将跳线器插在JP71;
(2)用导线连接MON51模块的AD0-AD7与并行模数转换模块的DI0-DI7; (3)用导线连接WR与并行模数转换模块的WR1和WR2; (4)用导线连接A14与并行模数转换模块的CS和Xfer ; (5)用导线连接ILE,Vref和+5V;
(5)使用导线连接Iout1与模拟运放模块的B-;
(6)使用导线连接Iout2与模拟运放模块的B+,B+同时与电源的地相连接; (7)使用导线连接Rfb与模拟运放模块的BOUT; (8)使用导线连接模拟运放模块的V+与+12V,V-与-12V; 六、实验思考:修改程序,用其它通道轮流采样显示。
24
实验五 并行接口扩展实验
一、实验目的
掌握可编程并行接口芯片8155的接口原理使用,熟悉对8155初始化编
程和输入、输出程序的设计方法。 二、实验内容
学生按以下要求设计程序流程图,编写、调试程序。在8155的A、B、C口用示波器测出每个口线的波形。 三、实验原理图
25
四、实验硬件连线
1、利用跳线器连接JP21;
2、利用导线连接8155模块的CE与MON51模块的A10,IOM接A9,ALE接ALE,RD接RD,WR接WR;
五、实验思考
修改程序,用PB口作输入,PA口作输出,观察运行情况。
26