基于AT89C51单片机的出租车计价器系统设计综述_第1页
基于AT89C51单片机的出租车计价器系统设计综述_第2页
基于AT89C51单片机的出租车计价器系统设计综述_第3页
基于AT89C51单片机的出租车计价器系统设计综述_第4页
基于AT89C51单片机的出租车计价器系统设计综述_第5页
已阅读5页,还剩23页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、华蛀也力*孑课程设计(综合实验)报告(2013- 2014 年度第2学期)名称:单片机与嵌入式系统课程设计题 目:基于51单片机的出租车计价器设计院系:控制与计算机工程学院班级:测控1101班学 号:1111160108学生姓名:李 权指导教师:吕跃刚设计周数:一周成 绩:日期:2014年06月19日普*L- 力人* 课程设计(综合实验)报告、课程设计的目的与要求1. 每三人一组,按学号排列分组。2. 每组同学可按题目自行合理分工合作完成,答辩时可分别负责回答其中一部分,如资料查询、总体设计、外围器件研究、传感器研究、电路设计、硬件制版图绘制、软件编程等。3. 每组课设只给出题目,而没有给出具

2、体技术功能要求。同学可以充分发挥、完善设计。4. 建议每组应有一个同学学习掌握protel 99SE 制版软件,并负责电路板设计。5. 建议认真查阅资料,多参考别人的成果,但设计的内容要有自己的独立见解。6. 课设报告按学校格式要求书写。二、设计正文1.1.1单片机的概念单片机(microcontroller,又称微控制器)是在一块硅片上集成了各种部件的微型计算机。这些部件包括中央处理器 CPU数据存储器 RAM程序存储器 ROM定时器/计数器和多种I/O接口电路。 图1是80C51单片机的基本结构图图1 89C51结构方框图a. 89C51单片机的结构特点有以下几点:8 位 CPU片内振荡器

3、及时钟电路;32根I/O线;外部存储器ROM和RAM寻址范围各64KB;两个16位的定时器/计数器;5个中断源,2个中断优先级全双工串行口布尔处理器b. 定时器/计数器89C51内部有两个16位可编程定时器/计数器,记为TO和T1。16位是指它们都是由16个触发器 构成,故最大计数模值为 2-1。可编程是指他们的工作方式由指令来设定,或者当计数器来用,或者 当定时器来用,并且计数(定时)的范围也可以由指令来设置。这种控制功能是通过定时器方式控制 寄存器TMOD来完成的.如果需要,定时器在计到规定的定时值时可以向CPU发出中断申请,从而完成某种定时的控制功能。在计数状态下同样也可以申请中断。定时

4、器控制寄存器 TCON用来负责定时器的启动、停止以及中断管理在定时工作时,时钟由单片机内部提供,即系统时钟经过12分频后作为定时器的时钟。技术工作 时,时钟脉冲由TO和 T1输入。c. 中断系统89C51的中断系统允许接受五个独立的中断源,即两个外部中断申请, 两个定时器/计数器中断以及一个串行口中断。外部中断申请通过INTO和INT1 (即P3.2和P3.3 )输入,输入方式可以是电平触发 (低电平有效), 也可以是边沿触发 (下降沿有效)。两个定时器中断请求是当定时器溢出时向CPU提出的,即当定时器由状态1转为全零时提出的。第五个中断请求是由串行口发出的,串行口每发送完一个数据或接收完 一

5、个数据,就可提出一次中断请求。1.1.2 89C51的芯片引脚图如图2所示VCC供电电压。GND接地。P0 口: P0 口为一个8位漏极开路双向I/O 口,每脚可吸收8TTL门电流。当P1 口的管脚第一次写 1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口, 当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。Pl. 0Pl. 1C L124039VccJ P0. O/ADOFl. 2C3PO.1/AD1Pl. 3C43TPO.2/AD2Pl. 4c53&P0.3/AD3Pl. 5c635P0.4/A

6、D4Pl. 6cT34J PO. 5/AD5Pl. 7cE:33P0. 6/AD6RESETc932P0.7/ADTKXD/P3. 0c1031ea/vppTKD/P3. 1c1130ALE/PROGIHT0/P3. 2c1229PSENIBTI/P3. 3c1328J P2.7/AD1ST0/P3. 4c142TJ P艺G/AD14T1/P3. 5c1526J P2.5/AD13WP3- &c16251 F2.4/AD12RS/P3. 7c1?24J P2.3/AD11XTAL2c1823P2.2/AD10XTAL1c1922?2.1/AD9PDIPVssc2021P2.0/AD8图2P1

7、口: P1 口是一个内部提供上拉电阻的8位双向I/O 口,P1 口缓冲器能接收输出 4TTL门电流。P1 口管脚写入1后,被内部上拉为高,可用作输入,P1 口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在 FLASH编程和校验时,P1 口作为第八位地址接收。P2 口: P2 口为一个内部上拉电阻的8位双向I/O 口,P2 口缓冲器可接收,输出 4个TTL门电流,当P2 口被写“ 1”时,其管脚被内部上拉电阻拉高,且作为输入。因此作为输入时,P2 口的管脚被外部拉低,将输出电流,这是由于内部上拉的缘故。P2 口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2 口输出地

8、址的高八位。当对外部八位地址数据存储器进行读写时,P2 口输出其特殊功能寄存器的内容。P2 口在FLASH编程和校验时接收高八位地址信号和控制信号。P3 口: P3 口管脚是8个带内部上拉电阻的双向 I/O 口,可接收输出 4个TTL门电流。当P3 口写 入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3 口将输出电流(ILL )这是由于上拉的缘故。 P3 口也可作为AT89C51的一些特殊功能口,如下表所示:P3.0 RXD (串行输入口)P3.1 TXD (串行输出口)P3.2 /INTO (外部中断 0)P3.3 /INT1 (外部中断1)P3.4 T0

9、 (定时器/计数器0外部输入)P3.5 T1 (定时器/计数器1外部输入)P3.6 /WR (外部数据存储器写选通)P3.7 /RD (外部数据存储器读选通)P3 口同时为闪烁编程和编程校验接收一些控制信号。RST复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。FLASHALE/PROG当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想

10、禁止 ALE的输出可在SFR8EH地址上置0。此时,ALE只有在执行MOVXMOVC旨令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。PSEN外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSE N信号将不出现。EA/VPP当/EA保持低电平时,则在此期间外部程序存储器( 0000H-FFFFH),不管是否有内部程 序存储器。注意加密方式 1时,/EA将内部锁定为 RESET当/EA端保持高电平时,此间内部程序存储 器。在FLASH编程期间,此引脚也用于施加 12V编程电

11、源(VPF)。XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。XTAL2来自反向振荡器的输出。1.1.3使用I/O 口的注意事项(1) P1,P2,P3 口的输出缓冲器可驱动 4个LSTTL电路。对于HCMO芯片单片机的I/O 口,在正 常情况下,可任意由TTL或NMOSfe路驱动。HMO及CMO性的单片机I/O 口有集电极开路或漏极开路 的输出来驱动时,不必外加上拉电阻(2) 对于74LS系列,CD4000系列以及一些大规模集成电路芯片(如8155, 8253, 8279等),都 可以和MCS-51系列单片机直接接口。具体使用时,可以查阅有关器件手册或参考典型电路(3) 对一些线性

12、组件,特别是应用键盘、码盘、LED显示器等输入/输出设备时,应当尽量增加驱动部分的容量,否则,单片机将提供不出足够的驱动电流供给负载使用1.2 89C51中断系统所谓中断,是指当计算机执行正常程序时,系统中出现某些急需处理的异常情况和特殊情求,CPU暂停执行现行程序,转去对随机发生地更紧迫事件进行处理;处理完毕后,CPU自动返回原来的程序继续执行。中断允许软件设计不需要关心系统其他部分定时要求,算术程序不需要考虑隔几个指令检查I/O设备是否需要服务。相反,算术程序编写时好像有无限的时间作算术运算而无其他工作在进行。若其 它事件需要服务时,则通过中断告诉系统。89C51单片机有5个中断源,有两个

13、中断优先级,每个中断源的优先级可以编程控制。中断允许 受到CPU开中断和中断源开中断的两级控制。1.2.1 中断源中断源是指任何引起计算机中断的事件,一般一台机器允许有许多个中断源。89C51系列单片机至少有5个中断源。增加很少的硬件就可把各种硬件中断源“线或”成为一个外部中断输入,然后再 顺序检索一起中断的特定源。89C51单片机的5个中断源是: 外部中断请求0,由(P3.2 )输入; 外部中断请求1,由(P3.3 )输入;3普*L- 力人* 课程设计(综合实验)报告 片内定时器/计数器0益处中断请求; 片内定时器/计数器1溢出中断请求; 片内串行口发送/接收中断请求;为了了解每个中断源是否

14、产生了中断请求,中断系统应设置许多个中断请求触发器(标志位)实现记忆。这些中断源请求标志位分别有特殊功能寄存器Tcor和scon勺相应位锁存定时器/计数器控制寄存器 TCON它是一个八位的寄存器,各位如表1所示:表1定时器/计数器控制寄存器 TCONTF1TF0IE1IT1IE0IT0IT0,IT1 :外部中断0、1触发方式选择位,由软件设置。 1是下降沿触发,0是电平触发。IE0,IE1 :外部终端0、1请求标志位。TF0,TF1 :定时器/计数器0、1溢出中断请求标志。1.2.2 中断的控制中断的控制主要实现中断的开关管理和中断优先级的管理。这个管理主要通过对特殊功能寄存器IE和IP的编程

15、实现。(1)中断允许寄存器IE 表2中断允许寄存器IEEA-ET2ESET1EX1ET0EX0EX0,EX1 :外部终端0, 1的中断允许位。1是中断开,0是中断关ET0,ET1:定时器/计数器0、1溢出中断允许位。1是开中断,0是关中断ES:串行口中断允许位。1是中断开,0是中断关ET2:定时器/计数器2溢出中断位EA CPU开/关中断控制位。1是开中断,0是关中断(2)中断优先级寄存器IP 表3中断优先级寄存器IPPSPT1PX1PT0PX0若系统中多个中断源同时请求中断,则CPU按中断源的优先级别,由高到低分别响应。89C51单片机有两个中断优先级:高优先级和低优先级。每个中断源都可以编

16、程为高优先级。这可以实现两级中断嵌套。嵌套的原则:一个正在执行的中断服务程序可以被高级的中断请求中断,而不能被同级或较低级的中断请求中断。两级中断通过使用IP寄存器设置,相应的位置1,则优先级高,0则优先级低。PX0 PX1:终端0、1中断优先级控制;PT0 PT1:定时器/计数器0、1中断优先级控制。PS:串行口中断优先级控制。89C51复位时,IP被清零,5个中断源都在同一个优先级。这时若其中几个中断源同时产生中断请求,则CPU按照片内硬件优先级链路的顺序相应中断,硬件优先级由高到低的顺序是:外部终端0, 定时器/计数器0,外部中断1定时器/计数器1串行口中断。1.2.3 中断响应89C5

17、1的CPU在每个机器周期采样中断源的中断请求标志位,如果没有上述阻止条件,则将在下 一个机器周期响应被激活的最高级中断请求。阻止条件如下: CPU正在处理同级或更高级的中断; 现行机器周期不是所执行指令的最后一个机器周期; 正在执行的是 RETI或者是访问IE或IP的指令;CPU在中断响应之后完成如下操作: 硬件清除相应的中断标志位; 执行一条硬件子程序,保护断点,并转向中断服务程序入口。 结束中断时执行 RETI指令,恢复断点,返回主程序。89C51的CPU在相应中断请求时,由硬件电路自动形成转向与该中断源对应的中断的服务程序入 口地址。这种方法为硬件向量中断法。各中断源的中断服务程序入口地

18、址如下:表4中断源的中断服务程序入口地址编号中断源入口地址0外部终端00003H1定时器/计数器0000BH2外部终端10013H3定时器/计数器1001BH4串行口中断0023H各中断服务程序入口地址仅隔8个字节,编译器在这些地址放入无条件转移指令,跳到服务程序的实际地址。向量中断包括把先前的程序计数指针推入堆栈,中断服务程序很像其他子程序。当向量中断发生 时,硬件禁止所有中断。此时表明外部中断或定时器溢出的标志位由硬件清除。中断服务程序的不同 分支取决于中断源。 在重新允许全局 CPU中断EA之前,必须仔细清除各种标志。标志会引起立即地重复中断。89C51对终端实际上有特殊的返回指令-RE

19、TI 。不是RET RETI重新允许系统识别其他中断。因而,没必要在正常使用中断时复位EA,只要在程序初始化时开中断一次就可以了。1.3单片机定时器/计数器的使用89C51系列单片机至少有两个 16位内部定时器/计数器。8952有三个定时器/计数器,其中连个基 本定时器/计数器是定时器/计数器0和定时器/计数器1。他们既可以编程为定时器使用,也可以编程为计数器使用。若是计数内部晶振驱动时钟,则它是定时器;若是计数89C51的输入引脚的脉冲信号,则它是计数器。89C51的T/C时加一计数的。定时器实际上也是工作在技术方式下的,只不过对固定频率的脉冲 计数;由于脉冲周期固定,由计数值可以计算出时间

20、,有定时功能。当T/C工作在定时器时,对振荡源12分频的脉冲计数,即每个机器周期计数值加一,频率加 =fosc/12。晶振为6MHz计数频率=500KHz每2uS计数加一。当T/C工作在计数器时,计数脉冲来自外部脉冲输入引脚TO或T1。当TO或T1脚上负跳变需2个机器周期,即24个振荡周期。所以 TO或T1脚输入的计数外部脉冲的最高频率为 fosc/12。当晶振 为12MHz时,最高技术频率为 500KHz高于此频率将计数出错。1.3.1与T/C有关的特殊功能寄存器(1)计数寄存器TH和TLT/C是16位的,计数寄存器有TH高8位TL低8位构成。在特殊功能寄存器中,对应T/C0为TH0和TLO

21、;对应T/C1为TH1和TL1。定时器/计数器的初始值通过 TH1/TL1和THO/TLO设置(2)定时器/计数器控制寄存器 TCON表5定时器/计数器控制寄存器 TCONTR1TR0TRO TR1:定时器/计数器0、1启动控制位。1是启动,0是停止TCOF复位后清零,T/C需要受到软件控制才能启动计数;当计数计满时,产生向高位的进位TF,即溢出中断请求标志T/C的方式控制寄存器 TMOD表6 T/C的方式控制寄存器 TMODGATEC/TM1M0GATEC/TM1M0C/T:计数器或定时器选择位。1位计数器,0位定时器GATE门控信号。1时T/C的启动控制受到双重控制,即要求 TR0/TR1

22、和INT0/INT1同时为高;0时T/C的启动仅受TR0/TR1控制。表7 M1和M0工作方式选择位M1M0方式功能000为13位定时器/计数器,TL存低5位,TH存高8位011为16定时器/计数器,TL存低8, TH存高8位102常数自动装入的8位定时器/计数器113仅适用于T/C0 ,两个8为定时器/计数器1.3.2定时器/计数器的初始化(1)初始化步骤在使用89C51的定时器/计数器前,应对它进行编程初始化,主要是对TCOF和 TMOD编程,还需要计算和装载T/C的计数初值。一般完成以下几个步骤:确定T/C的工作方式-编程TMOD寄存器。计算T/C中的计数初值,并装载到TH和TL。T/C

23、在中断方式工作时,须开CPU中断和源中断-编程IE寄存器。启动定时器/计数器-编程TCOh中 TR1和TR0位(2)计数初值的计算在定时器方式下,T/C是对机器周期脉冲计数的,如果fosc=6MHz,一个机器周期为 2us,贝U方式0 13位定时器最大时间间隔(2-1) x 2us=16.384ms ;方式1 16位定时器最大时间间隔方式2 8位定时器最大时间间隔=(2-1 ) x 2us=131.072ms ;=(2-1 ) x 2us=512us若使T/C工作在定时器方式1,要求定时1ms,求计数初值。如设计数初值为x,则有(2-1 )x2us=1000usx=2-500因此,TH,TL

24、可置 65536-500。2、计价器系统设计2.1硬件设计2.1.1 整体硬件电路图匚丨丄图3整体硬件电路图由上图我们可以看到,本电路控制核心是AT89C51芯片。该方案我们采用动态显示的方法。动态显示的优点是,它占用 CPU的时间少,每次只把一个数据送到外部接口,虽然我们仿真看到的是全部 数码管都亮着,那是因为动态显示的时间比较快,超过我们人眼的辨别能力。若我们在仿真的时候暂 停一下,就可以清楚地看到,时间单元和价格单元分别只显示一位。静态显示,是每一个数码管不论 在什么时候都点亮,占用CPU的时间很多。按键主要控制系统的初始化、开始工作、数据锁存三项工作。刚开始上电,则所有的数码管同时显示

25、全0状态,当第一次按下开关,价格从起步价005.0元开始计费,等待是否超过三公里以及计算,时间单元则从00.00.00开始计时,一秒一秒往上加。P0 口作为数据总线口,分别把数据输送到4个74LS273地址锁存器中,而锁存器的工作需要等待脉冲的到来。脉冲通过写地址有些端口p3.6和端口 p2.0-p2.3经过或非门来产生。只有当把数据送到外部接口时,p3.6 口才为低电平,p2.0-p2.3用来控制到底是把数据送往哪一个锁存器。算法公式是:费用=起步价+ (路程-3 )X 1.3路程=速度x时间(速度恒定,60Km/h,也就是1Km/min)若路程小于等于3,则收起步价5元,否则按费用公式算。

26、由于速度恒定,所以计算的核心是时间,只要判断时间超出2分钟,则费用公式就开始计算,每多出一公里,费用就加上1.5元,一分钟一公里来计算,因此本设计比较简单。时间单元由单片机的定时器/计数器来计算,延时 1ms时间的初值由程序来设定。2.1.2 74LS273 和 74LS02 简介Vqq Q 了 內 D Qg Qs Dj 为 Q* CP莎而 而 而 百 puipiri nriijrT2 | J 11 4 11 6 11 T | R | 9 | IDW Q) Cfe Di Qz D2 D3 Qa GND图4 74LS273管脚图引脚功能:74LS273是8位数据/地址锁存器。74LS273是一种

27、带清除功能的 8D触发器,1D8D 为数据输入端,1C8Q为数据输出端,正脉冲触发,低电平清除,常用作8位地址锁存器。ftB 1A 3B 3AI Lp? II图5 74LS02管脚图引脚功能:74LS02是四二输入或非门。该芯片有四个或非门公选择,如1A或1B后,经过非门再输出,只有当输入的两个变量同时为0时,输出才为1。具有缓冲倒相功能。2.2软件设计2.2.1模块介绍该计费器系统的软件设计分为一下几个模块:(1)主程序模块在主程序模块中,需要完成对个接口芯片的初始化、出租车起步价和单价、中断向量的设计以及开中断、循环等待等工作。另外,在主程序模块中还需要设置启动 /清除标志寄存器、里程寄存

28、器和价 格寄存器,并对它们进行初始化。然后,主程序将根据各标志寄存器的内容,分别完成启动、清除、 计程和计价等不同的操作。流程图如3-4所示。当按下轻触开关时,开始对系统初始化,价格和时间都显示0、0,再次按下开关,时间单元开始计时,并计算时间是否超过2分钟,超过2分钟,则从第3分钟开始计费。价格单元从起步价5.0元开始计费,每多一分钟,价格单元多加1.5元。(2)显示子程序模块由于显示是由显示时间子程序DIS1和显示价格子程序 DIS组成的,时间由小时、分、秒三个单元19999.9 元。组成,共六个数码管。价格由元和角两个单元组成,最大可以显示2.2.2程序流程图223 汇编程序ORG 00

29、00H;初始化段地址LJMP MAIN;长跳转到主函数 MAI N处ORG 000BH;TT0开始地址LJMP TTO;长跳转到TT0处ORG 0030H;主函数开始地址,避开0030敏感段MAIN MOV SP,#40H;设堆栈底指针,下一个数据将放在41H单元MOV 70H,#60;价格单元的起步价MOV 71H,#00;价格单元的十位和百位MOV 72H,#00;秒单元清零MOV 74H,#00;时单元清零MOV 75H,#00;75H单元清零备用CLR 00HCLR 01H;将00H, 01H单元清零MOV 6BH,#0AH;将0AH(既十进制10)放入6B单兀MOV R1,#76H;

30、把76H放到R1中KKK MOV R1,#00H;将76H单元的内容清零INC R1DJNZ 6BH,KKK;76H 7FH单兀全部清零,备用LCALL DIS;调用价格显示子程序LCALL DIS1;调用时间显示子程序MOV TMOD,#11H;定时器/计数器工作方式设置MOV TH0,#3CHMOV TL0,#0B0H;这句和上一句设置延时50msMOV 6EH,#20;将6EH单元设置20,达到1s的延时G2: LCALL DIS;长调用价格显示子程序LCALL DIS1;长调用时间显示子程序JB P1.0,G2;开关没按下,等待按下,显示初始状态,全部为零LCALL TIME1;调用T

31、IME1延时子程序JB P1.0,G2;开关没按下,跳到G2,否则转到下一步G1: LCALL DISLCALL DIS1JNB P1.0,G1;开关按下,继续显示价格和时间,并转到中断SETB EA;开中断SETB ET0;定时器0中断允许,向CPU申请中断SETB TR0;定时器0工作允许SETB 01H;01H单兀置位LLL: LCALL CHAI;调用现场保护子程序LCALL DISLCALL JISUAN;调用计算子程序LCALL DIS1JB P1.0,G3;开关没按下,则返回LCALL TIME1JB P1.0,G3CPL 01H;01H单元此时为零JNB 01H,G5;01H;

32、单元内容为0,跳到G5SETB ET0;定时器0中断允许,向CPU申请中断G6: LCALL DISLCALL DIS1JNB P1.0,G6;开关按下,显示所走的时间及费用LJMP MAIN;重新等待下一个工作状态G5: CLR ET0G4: LCALL DISLCALL DIS1JNB P1.0,G4G3: LJMP LLLTT0: CLR ET0/*定时一秒*/CLRTR0MOVTH0,#3CHMOVTL0,#0B0HSETBTR0SETBET0DJNZ6EH,JJJLCALLADD1MOV6EH,#20JJJ: RETIDIS: MOV 6DH,#06H/*价格显示子程序*/MOV R

33、0,#7AHMOV 6CH,#0FEHHHH: MOV DPTR,#0FDFFH /数据指针出口地址,低 8位给P0 口,高8给/位P2 口MOVA,6CHMOVXDPTR,AMOVA,R0MOVDPTR,#TAB;查表首地址MOVCA,A+DPTR;查表值送AMOV DPTR,#OFEFFHMOVX DPTR,ALCALL TIME1MOV A,6CHRL AMOVR0,#72HMOV6CH,#0FEHHHH1: MOV DPTR,#0F7FFHMOVA, 6CHMOVXDPTR,AMOVA,R0MOVDPTR,#TABMOVCAA+DPTRMOVDPTR,#0FBFFHMOVR1,6DHC

34、JNER1,#03H,K1ORLA,#80HDIS1: MOV 6DH,#04H/*时间显示子程序*/;FF给 P0 口 ,F7 给 P1.0 P1.3 口;将6CH的内容放到 0F7FFH中;查表首地址;查表值送AMOV6CH,AINCR0DJNZ6DH,HHHRETK1: MOVX DPTR,ALCALL TIME1MOV A, 6CHRL AMOV 6CH,AINC RODJNZ 6DH,HHH1RETTIME1: MOV 6AH,#0AH /*延时子程序 */FFF: MOV 69H,#0AHGGG: DJNZ 69H,GGGDJNZ 6AH,FFFRETJISUAN:JB 00H,K

35、2/*判断是否超过 3公里及计算价格子程序 */MOVA,78HCLRCSUBBA,#03HMOV73H,#06HJCK3SETB00HLJMPK3K2: MOV R3,71HMOVR4,70HMOVR2,#00HMOVR5,#00HMOV R6,#03HMOV R7,#0E8HLCALLNDIV42MOV75H,R4MOVA,R6MOVR3,AMOVA,R7MOVR4,AMOVR2,#00HMOVR7,#100LCALLNDIV31MOV74H,R4MOVA,R7MOV B,#10DIV ABMOV 73H,AMOV 72H,BK3:RETCHAI: MOV 6FH,#03H/*保护现场子程

36、序*/MOVR0,#77HMOVR1,#7AHZZZ: MOV A,R0ANLA,#0FHMOVR1,AMOVA,R0SWAPAANLA,0FHINCR1MOVR1,AINCROINCR1DJNZ6FH,ZZZRET;保存77H单元中的低4位;循环三次ADD1: MOV A,77H/*加一子程序*/CJNEA,#59H, L18LJMPL19L18: ADDA,#01HDA AMOV77H,ALJMPL24L19: MOV77H,#00HJNB00H,S1CLRCMOVA,70HADDA,#12MOV70H,AMOVA,71HADDCA,#00HMOV71H,AS1: MOVA,78HCJNE

37、A,#59H,L20LJMPL21L20: ADDA,#01HDA AMOV78H,ALJMPL24L21: MOV 78H,#00HMOVA,79HCJNEA,#23H, L22LJMPL23L22: ADDA,#01HDA AMOV79H,AL23: MOV 79H,#00HL24: RETNDIV42:MOV A,R1/*四除二子程序 */PUSHACCMOVB,#00HNDV421:MOV A,R2CLRCSUBBA,R7MOVR1,AMOVA,R5SUBBA,R6JC NDV422MOVR5,AMOVA,R1MOVR2,AINC BSJMPNDV421NDV422:PUSH BMOV B,#10HNDV423:CLR CMOVA, R4RLCAMOVR4,AMOVA,R3RLCAMOVR3,AMOVA, R2RLCAMOVR2,AXCHA,R5RLCAXCHA,R5MOVF0,CCLRCSUBBA,R7MOVR1,AMOVA,R5SUBBA,R6JBF0,NCV424JCNDV425NCV424:MOV R5,AMOVA,R1MOVR2,AINCR4NDV425:DJNZ B,NDV423POPACCCLROVJNZNDV426SETBOVNDV426:XCH A,R2MOVR7,A普*L- 力人* 课程设计(综合实验)报告MOV R7,A

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论