当前位置:文档之家› 基于的秒表设计与实现

基于的秒表设计与实现

基于的秒表设计与实现
基于的秒表设计与实现

基于8086的秒表设计与实现

————————————————————————————————作者:————————————————————————————————日期:

郑州科技学院

微机原理课程设计(论文)

题目_基于8086的秒表设计与实现_

学生姓名程昭昭

专业班级计科一班

学号201115003

所在系信息工程学院

指导教师王清珍

完成时间2013年12月13日

目录

摘要 (1)

1 99秒秒表设计背景及目的要求 (1)

1.1 99秒秒表设计背景 (1)

1.2设计目的 (1)

1.3硬件选择 (2)

1.4设计内容 (2)

2 设计方案及基本原理 (2)

2.1 预备知识 (2)

2.2 LED显示原理 (3)

2.3 元器件选择 (3)

2.4 系统设计 (3)

2.5硬件工作原理 (4)

2.6 硬件连接 (4)

3 设计流程 (5)

3.1设计步骤 (5)

3.2程序代码 (6)

4 程序 (7)

4.1 main.c主程序 (7)

4.2 key.asm ——键盘扫描子程序 (11)

5 调试结果及分析 (24)

5.1 调试结果 (24)

5.2 结果分析 (25)

6 结论与分析 (25)

7 参考与文献 (25)

摘要

本设计是设计一个芯片控制的多功能秒表系统。近年来随着科技的飞速发展,单的应用正在不断的走向深入,同时带动着传统控制检测日新月异更新。在实时检测和自动控制的单片机应用系统中,单片机往往是作为一个核心部件来使用,仅单片机方面的知识是不够的,还要根据具体的硬件结构,以及针对具体的应用对象的软件结合,加以完善。秒表的出现,解决了传统的由于人为因素造成的误差和不公平性。将软、硬件有机地结合起来,使得系统能够实现两位LED显示,显示时间为00~99秒,每秒自动加1,能正确地进行加、减(倒)计时,快加,快减,可以同时记录4个相对独立的时间,通过上翻下翻来查看这4个不同的计时值,可谓功能强大。其中软件系统采用汇编语言编写程序,包括显示程序,加减计数程序,快加快减程序,中断,延时程序,按键消抖程序等,并在WAVE中调试运行,硬件系统利用PROTEUS强大的功能来实现,简单切易于观察,在仿真中就可以观察到实际的工作状态。

关键词: AT89C51 99秒

【设计题目】99秒秒表设计

1 99秒秒表设计背景及目的要求

1.1 99秒秒表设计背景

目前,单片机正朝着高性能和对品种方向发展,趋势是进一步向着CMO化,低功耗,小体积,大存量,高性能,低价格和外国电路内装化等几个方面发展。

单片机应用的重要意义还在于他从根本上改变了传统的控制系统设计思想和设计方法。从前必须由模拟电路或数字电路实现的大部分功能功能,现在已能用单片机通过软件方法来实现了。这种软件代替硬件的控制技术也称为微控制技术,是传统控制技术的一次革命。

单片机模块中最常见的是秒表、数字钟等显示时间类的装置,此装置是一种用数字电路实现时、分、秒计时的装置,与机械式时钟相比具有更高的准确性和直观性,且无机械装置,具有更长的使用寿命,因此得到了广泛的使用。

此设计利用凌阳科技公司的凌阳16位单片机SPCE061A为主控芯片,充分利用61板上面的三个按键,完成一个简易的现实系统——99秒秒表。

61板是一套完整的16位单片机开发系统,可直接把程序下载到61板上进行调试和封装。集成度高、运算速度快、体积小、运算可靠、价格低廉,在过程控制、数据采集、机电一体化、智能仪器仪表、网络技术等方面得到广泛应用。

1.2 设计目的

随着单片机应用的日益广泛,在校学生加强对单片机的认识和动手能力,已经是非常重要的一项锻炼。课程设计就是为加强实践机会、培养学生动手能力的一个重要环节,将理论知识与实际联系起来的一个关键机会。本课程设计的基本要求是:

1. 掌握LED数码管原理及使用方法。

2. 掌握61板的使用方法。

3. 初步掌握SPCE061A单片机汇编语言一般编程技巧。

4. 初步掌握61板系统调试的一般步骤及方法。

1.3硬件选择

装有Windows系统和μ’nSP? IDE仿真环境的PC机一台,μ’nSP?十六位单片机实验箱一个。本设计用到的实验箱硬件模块为:SPCE061A核心及周边电路模块(包含32个I/O口),LED数码管。做此实验用51板也可以,因为51板也提供了相应的LED模组,因为实验室里面给我们提供了61板,所以我决定选用SPCE061A 单片机实验箱。

1.4 设计内容

本装置将实现0-99的计数,每一秒钟,计数器将加1,在数码管上显示当前计数值,并可用键盘按制计数的起始,以及归零。具体要求如下:

1. 开机时数码管显示00。

2. 每一秒钟,计数器自动加1。

3. 按键控制计数,分别控制开始计时、停止计时和归零,功能分配如下:

表1-1按键功能分配

按键功能描述

KEY1 开始计时

KEY2 停止计时

KEY3 归零

2 设计方案及基本原理

2.1 预备知识

1.熟悉凌阳单片机的工作原理。

(1)I/O口的使用原理和设置;

(2)定时器或时基的设置、使用;

(3)中断的设定。

2.了解数码管的显示原理。

3.熟悉键盘扫描原理。

4.熟悉汇编语言或C语言。

2.2 LED显示原理

静态显示就是显示驱动电路具有输出锁存功能,单片机将所要显示的数据送出后就不再管,直到下一次显示数据需要更新时再传送一次新数据,显示数据稳定,占用很少的CPU时间。

动态显示需要CPU时刻对显示器件进行数据刷新,显示数据有闪烁感,占用的CPU时间多。这两种显示方式各有利弊;静态显示虽然数据稳定,占用很少的CPU时间,但每个显示单元都需要单独的显示驱动电路,使用的硬件较多;动态显示虽然有闪烁感,占用的CPU时间多,但使用的硬件少,能节省线路板空间。

基本的半导体数码管是由七个条状发光二极管芯片排列而成的,可实现0~9的显示。

LED数码管是由发光二级管显示字段组成的显示器,有8段和“米”字段之分,这种显示器有共阳级和共阴极两种。所谓共阳方式是指笔画显示器各段发光管的阳极(即P区)是公共的,而阴极互相隔离。所谓共阴方式是笔画显示器各段发光管的阴极(即N区)是公共的,而阳极是互相隔离的。

2.3 元器件选择

61板一个,共阳极2位LED数码管一个,电路板一个,8050三极管二个,1k的电阻8个,33k电阻2个,导线若干,排针(10位)2个。

2.4 系统设计

根据设计题目的要求分析,并考虑到题目的可扩展性,可将系统分成两大部分:

1. 时间的产生和显示。

2. 按键控制计数起始、归零。

根据系统的功能现选择61板作为单片机控制处理部分,利用一2位LED作为显示部分,而按键采用61板上自带的三个按键,如图2-1所示。

秒IOB

图2-1 系统框图

2.5硬件工作原理

两位数的显示采用的是一个2位共阳极LED 数码管(LG5621AH),连接方法是SPCE061A的IOB0-IOB6接LED焊接板的A-G,小数显示部分可以省略不要;IOB8-IOB9分别接LED的位选COM1、COM2,电路原理图如图2-4。LED与SPCE061A的引脚连接如表2-1。

采用凌阳大学计划的LED键盘模组和61板搭配可以很容易的完成这个课程设计的题目。它的连结图如图所示,IOB的低八位控制数码管显示段位,高八位控制点亮哪一个数码管。

表2-1 LED引脚连接表

SPCE061A LED模块SPCE061A LED模块

IOB8 A IOB0 COM1

IOB9 B IOB1 COM2

IOB10 C

IOB11 D

IOB12 E

IOB13 F

IOB14 G

2.6 硬件连接

采用凌阳大学计划的LED键盘模组和61板搭配可以很容易的完成这个课程设计

的题目。它的连结图如图所示,IOB 的低八位控制数码管显示段位,高八位控制点亮哪一个数码管。

图2-2 LED 键盘模组和61板连接图

3 设计流程图

AD[0..15]READY 22INTR 18NMI 17RESET 21CLK 19

MN/MX 33HOLD/GT131HLDA/GT030A[16..19]M/IO/S028

ALE/QS025

DT/R/S127INTA/QS124TEST 23BHE 34DEN/S226RD 32WR/LOCK 29U9

8086

D08D17D26D35D44D53D62D71

RD 22WR 23A019A120CS 21

CLK09GATE011OUT010CLK115GATE114OUT113CLK218GATE216OUT2

17

U9

8253A

3.1设计步骤

根据设计要求的功能,程序主要分为三部分,即:

61板

IOA0 IOB8 IOA8

显示 显示

按键状

发光二

(1)计时显示部分;

(2)秒计时部分;

(3)按键控制部分。

(4)程序主流程主要完成键盘扫描、计时处理、键值分支控制的任务,流程图如图所示:

初始化

数据、以

扫描键

盘,针对

Key1 Key2 Key3

计时数据处

理,格式

图3-1 主程序流程图

显示部分是在IRQ4的1KHz中断中控制显示的,采用动态扫描的方式,1KHz的时基中断每1ms进一次中断,在中断中对2ms计数器i进行累加,当i从0累加到2时,则刚好为2ms,此时更新一个位的LED显示,并对i进行清零;当下一次累计到2ms时,则会再更新显示下一位LED数码管,当更新到最后一位时,返回重第一位开始更新;依此循环更新显示,而更新显示的数据保存在缓冲区当中,用户需要更新显

示的数据时,只需要改变对应的缓冲区中的数据即可。具体流程图如下。

秒计时采用IRQ5的2Hz 时基中断进行计时,流程图如图3-3所示。键盘输入利

用61板自带的三个按键,输入的端口为IOA0—IOA2。

图3-2 IRQ4 1KHz 时基中断流程 图3-3IRQ5 2Hz 时基中断流程图

4 程序

ctrl_port EQU 0106H A_PORT EQU 0100H B_PORT EQU 0102H c_port equ 0104h count equ 0206h

是计时器计

计时 结

IRQ4 2ms 计数器 更新显示一位 结

count0 equ 0200h

count1 equ 0202h

INTR EQU 0304H

INTR1 EQU 0306H

DCOUNT EQU 6

data segment

LEDTAB DB 3FH,06H,5BH,4FH,66H,6DH,7DH,07H,7FH,6FH,77H,7CH,39H,5EH,79H,71 H

BUF DB 0,0,0,0,0,0

buff db 20 dup(?)

DAT1 DB 0

DAT2 DB 0

DAT3 DB 1

dat4 db 0

data ends

CODE SEGMENT

ASSUME CS:CODE,ds:data START: CLI

PUSH DS

MOV SI,2*4

MOV AX,0

MOV DS,AX

MOV [SI],OFFSET INTB MOV 2[SI], SEG INTB POP DS

MOV AL,00010011B

MOV DX,INTR

OUT DX,AL

MOV AL,00000010B

MOV DX,INTR1

OUT DX,AL

MOV AL,00000001B

MOV DX,INTR1

OUT DX,AL

STI

mov ax,data

mov ds,ax

mov al,00110111b ;8253初始化 mov dx,count

out dx,al

mov dx,count0

mov ax,500h

out dx,al

mov al,ah

out dx,al

mov al,01110111b

mov dx,count

out dx,al

mov dx,count1

mov ax,50h

out dx,al

mov al,ah

out dx,al

MOV AL,10000001B ;8255初始化, MOV DX,CTRL_PORT

OUT DX,AL

back: MOV DX,C_PORT

in al,dx

test al,00000010b

jz b2 ;判断是否清0

again: MOV DX,C_PORT

in al,dx

test al,00000001b

jz b1 ;判断是暂停还是继续? mov cx,6

jia6: inc si

loop jia6

MOV AL,00000000B

MOV DX,C_PORT

OUT DX,AL

MOV AL,DAT1 ;DTA1中是秒

CMP AL,100

JZ A1

MOV BL,10

DIV BL

MOV BUF,AH ;秒的个位

MOV BUF+1,AL ;秒的十位

CALL DISPLAY_DEC

INC DAT1

JMP back

A1: MOV DAT1,0 ;满60秒,对DAT1清0 MOV AL,0

MOV AH,0

MOV BUF,AH

MOV BUF+1,AL

CALL DISPLAY_DEC ;先显示00,再进位

INC DAT2

MOV AL,DAT2 ;DAT2中是分

CMP AL,60

JZ A2

MOV BL,10

DIV BL

MOV BUF+2,AH ;分的个位

MOV BUF+3,AL ;分的十位

CALL DISPLAY_DEC

MOV CX,60

LOOP AGAIN

A2: MOV DAT2,0 ;满60分对DAT2清0 MOV AL,0

MOV AH,0

MOV BUF+2,AH

MOV BUF+3,AL

CALL DISPLAY_DEC ;先显示00:00再进位 MOV AL,DAT3 ;DAT3中是时

CMP AL,24

JZ A3

MOV BL,10

DIV BL

MOV BUF+4,AH ;时的个位

MOV BUF+5,AL ;时的十位

CALL DISPLAY_DEC

MOV CX,60

DEC CX

JZ back

A3: INC DAT3

JMP back

b1: CALL DISPLAY_DEC

mov al,01110000b ;对8253送GATE1控制信号 mov dx,c_port

out dx,al

call cunchu

CALL DELAY

jmp back

b2:

mov dx,c_port

in al,dx

test al,00000100b

jnz li

call xianshicj

相关主题
文本预览
相关文档 最新文档