单片机延时程序

合集下载

单片机延时500ms程序汇编

单片机延时500ms程序汇编

单片机延时500ms程序汇编一、概述在单片机编程中,延时操作是非常常见且重要的一部分。

延时可以使程序在执行过程中暂停一段时间,以确保输入输出设备能够正常工作,或者是为了保护其他设备。

本文将介绍如何使用汇编语言编写单片机延时500ms的程序。

二、延时原理在单片机中,延时操作通常通过循环来实现。

每个循环需要一定的时间,通过控制循环次数和循环体内的指令数量,可以实现不同长度的延时。

在汇编语言中,可以使用计数器来控制循环次数,从而实现精确的延时操作。

三、汇编语言编写延时程序接下来,我们将使用汇编语言编写延时500ms的程序。

1. 设置计数器初值在程序的开头我们需要设置计数器的初值,这个初值需要根据单片机的工作频率和所需的延时时间来计算。

假设单片机的工作频率为1MHz,那么在循环500次后,就能够达到500ms的延时。

我们需要将计数器的初值设为500。

2. 循环计数接下来,我们进入一个循环,在循环中进行计数操作。

每次循环结束时,都需要检查计数器的值,当计数器减至0时,表示已经达到了500ms的延时时间,可以退出循环。

3. 优化程序为了提高程序的执行效率,可以对计数器进行优化。

例如可以通过嵌套循环的方式,减少循环的次数,从而提高延时的精度和稳定性。

四、程序示例下面是一个简单的示例程序,演示了如何使用汇编语言编写延时500ms的程序。

```org 0x00mov r2, #500 ; 设置计数器初值为500delay_loop:djnz r2, delay_loop ; 进行计数ret ; 延时结束,退出程序```五、结语通过以上的示例程序,我们可以看到如何使用汇编语言编写单片机延时500ms的程序。

当然,实际的延时程序可能会更加复杂,需要根据具体的单片机型号和工作频率进行调整,但是思路是相似的。

在实际的编程中,需要根据具体的需求和硬件环境来进行调整和优化,以实现更加稳定和精确的延时操作。

希望本文对单片机延时程序的编写有所帮助,也欢迎大家在评论区提出宝贵意见和建议。

单片机延时程序

单片机延时程序

实验一单片机延时程序实验一、实验目的与要求:在使用4MH在外部晶体振荡器的PIC16F877A上用软件设计一个20ms的软件延时子程序。

另外,还要求用MPLAB的软件模拟器及其附带的软件工具窗口stopwatch观测延时程序执行的时间。

二、实验内容:1.硬件电路设计:本实验中用的是软件延时,利用循环来实现延时功能。

电路就用了单片机的原本电路。

没有用到其他的功能模块,单片机与ICD3相连接。

2.软件设计思路:单片机软件延时的前提和根底是每条指令的执行时间是固定的,且大局部指令的执行时间是一样的。

这要求对每条指令所花费的指令周期〔Tcy〕做到心中有数。

指令集中5条无条件跳转指令GOTO,CALL.RETURN,RETLW和RETFIE,由于它们必然引起程序跳转,造成流水线中断,因此肯定将占用2个指令周期。

而其他4条有可能引起程序跳转的条件跳转指令DECFSZ,INCFSZ,BTFSC和,BTFSS的执行时间,需要占用2个指令周期,当条件为假不发生跳转时,仅占用1个指令周期。

其余所有指令都只用1个指令周期。

每个指令周期Tcy的时间长度,计算方法:如果采用4MHz 的外部晶体〔fosc=4 MHz〕,那么PIC中档单片机的指令周期Tcy为1us,这是一个整数。

而采用其他频率的外部晶体时,指令周期时间将反比于外部晶体频率。

至于软件延时的构造和实现方法,其实可以采用任何指令和构造,因为只是通过执行指令消耗时间。

但通常情况下有两个选择延时程序构造的原那么:(1)执行指令周期数计算方便。

如果含有太多复杂的条件跳转循环等构造势必会造成指令周期的计算困难,甚至可能造成执行所造成的软件延时时间不等。

(2)不能占用太多的程序空间。

试想用20000个NOP指令来实现20ms的延时,显然是可以的,但是这样做浪费了整整一个页的程序存储器,得不偿失,而通过适当的循环构造,重复执行某些一样的程序是比拟合理的方法。

因此,软件延时程序一般采用以下方法:如果延时时间短〔微妙级别〕,可以连续插入几条NOP指令;如果延时时间长〔几个毫秒级别〕,那么可以使用双嵌套循环的方法来实现。

新手常用单片机延时程序

新手常用单片机延时程序
_NOP_( );
_NOP_( );
}
/*****************11us延时函数*************************/
//
void delay(uint t)
{
for (;t0;t--);
}
1ms延时子程序(12MHZ)
void delay1ms(uint p)//12mhz
DELAY:CLR EX0
MOV TMOD,#01H ;设置定时器的工作方式为方式1
MOV TL0,#0B0H ;给定时器设置计数初始值
MOV TH0,#3CH
SETB TR0;开启定时器
HERE:JBC TF0,NEXT1
SJMP HERE
NEXT1:MOV TL0,#0B0H
MOVTH0,#3CH
DJNZ R7,HERE
CLR TR0;定时器要软件清零
SETB EX0
RET
C语言延时程序:
void delay_18B20(unsigned inti)
{
while(i--);
}
void Delay10us( )//12mhz
{
_NOP_( );
_NOP_( );
_NOP_( );
_NOP_( );
延时则应该注意晶振的频率是多大。
软件延时:(asm)
晶振12MHZ,延时1秒
程序如下:
DELAY:MOV 72H,#100
LOOP3:MOV 71H,#100
LOOP1:MOV 70H,#47
LOOP0JNZ 70H,LOOP0
NOP
DJNZ 71H,LOOP1
MOV 70H,#46
LOOP2JNZ 70H,LOOP2

C8051F单片机C程序精确延时的方法

C8051F单片机C程序精确延时的方法

编译情况相同。3种循环语句在Keil C51中具有不同编 译特点的原因在于它们的流程不同。do—while语句是先 执行后判断,while和for语句都是先判断后执行。进行
多层循环时,使用do—while语句具有更大的优势:编译的 汇编代码就如直接用汇编语言编写的程序,结构紧凑,编
译效率高,条件转移控制循环次数的过程简单。因此,虽
C8051F单片机是完全集成的混合信号系统级芯片 (S0c),其MCU系统控制器的内核是CIP一51微控制器。 CIP一51的指令集与标准8051指令集完全兼容。CIP一 51采用流水线指令结构,指令时序与标准805l不同: 70%指令的执行时间为l或2个系统时钟周期;所有指令 时序都以时钟周期计算;大多数指令执行所需的时钟周期 数与指令的字节数一致;条件转移指令在不发生转移时和 发生转移时的时钟周期数不同。同标准8051相比, C8051F单片机实现程序延时的方法更复杂些。
void SingleCircle(unsigned char t){ unsigned char X=t,Y 5 tl
t基金项目:福建省教育厅科技硬目(jB07277)。
do(

}while(一一t); while(x一一);
for(;y--一;); }
使用Keil C51 V7.50编译器编泽,得到的汇编代码如 下:
2丁+(7l+3)T·(X一1)+(,l+2)T=ZT+(行+3)T·X一1’
同理,可得Delay函数的延时时间: {2T+[2T+(咒+3)T·x—T+3T]·y一丁+3丁)·
£一1’+5丁={[4y+(咒+3)X·y+4]·£+4}·T 其中,5丁为返回指令RET的时钟周期数。考虑调用De- lay函数的LCALL指令(时钟周期数为4T)和参数传递的 MOV指令(时钟周期数为2n,则总延时时间t且为

C51单片机的几种常用延时程序设计2024

C51单片机的几种常用延时程序设计2024

引言概述:C51单片机是一种广泛应用于嵌入式系统中的微控制器,它具有高度集成化、易于编程和灵活性强等特点。

在C51单片机的软件开发过程中,延时程序设计是非常重要的一部分。

本文将介绍C51单片机中几种常用的延时程序设计方法,包括循环延时、定时器延时、外部中断延时等。

这些方法不仅可以满足在实际应用中对延时的需求,而且可以提高程序的稳定性和可靠性。

正文内容:一、循环延时1. 使用循环控制语句实现延时功能,例如使用for循环、while循环等。

2. 根据需要设置延时的时间,通过循环次数来控制延时的时长。

3. 循环延时的精度受到指令执行时间的影响,可能存在一定的误差。

4. 循环延时的优点是简单易用,适用于较短的延时时间。

5. 注意在循环延时时要考虑其他任务的处理,避免长时间的等待造成程序卡死或响应延迟。

二、定时器延时1. 使用C51单片机内置的定时器模块来实现延时。

2. 配置定时器的工作模式,如工作方式、定时器精度等。

3. 设置定时器的初值和重装值,控制定时器中断的触发时间。

4. 在定时器中断服务函数中进行延时计数和延时结束标志的设置。

5. 定时器延时的优点是精确可控,适用于需要较高精度的延时要求。

三、外部中断延时1. 在C51单片机上配置一个外部中断引脚。

2. 设置外部中断中断触发条件,如上升沿触发、下降沿触发等。

3. 在外部中断中断服务函数中进行延时计数和延时结束标志的设置。

4. 外部中断延时的优点是能够快速响应外部信号,适用于实时性要求较高的场景。

5. 注意在外部中断延时时要处理好外部中断的抖动问题,确保延时的准确性。

四、内部计时器延时1. 使用C51单片机内部的计时器模块来实现延时。

2. 配置计时器的工作模式,如工作方式、计时器精度等。

3. 设置计时器的初值和重装值,使计时器按照一定的频率进行计数。

4. 根据计时器的计数值进行延时的判断和计数。

5. 内部计时器延时的优点是能够利用单片机内部的硬件资源,提高延时的准确性和稳定性。

单片机延时函数

单片机延时函数

单⽚机延时函数1.51单⽚机延时,晶振为11.0592MHz(1)粗略延时void delay_ms(uint x){uint i,j;for(i=x;i>0:i--)for(j=110;j>0;j--);}(2)定时器延时void delay_ms(uint i){TMOD=0x01; //设置定时器⼯作模式while(i != 0){TR0=1; //开启定时器TH0=(65535-1000)/256; //赋初值TL0=(65535-1000)%256;while(TF0 != 1); //溢出标志TF0=0;i--;}TR0=0; //关闭定时器}2.stm32l151C8T6延时,外部晶振8MHz(1)粗略延时void delay_us(uint32_t time) //us延时{uint32_t i=4\*time;while(i--);}void delay_us(uint32_t time) //ms延时{uint32_t i=4000\*time;while(i--);}(2)使⽤nop延时通过使⽤__NOP()函数进⾏延时,因为使⽤了8M晶振4倍频,所以是32MHz,所以⼀个nop约等于1/32us,所以使⽤32个nop函数为⼀个us,然后根据需要的定时时间进⾏计算。

void delay_us(uint32_t time) //us延时{uint32_t i=0;for(i=0;i(3)利⽤SysTick延时void delay_init() //初始化{SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8); //选择外部时钟fac_us=SystemCoreClock/8000000; //为系统时钟的1/8 4fac_ms=1000\*fac_us;}void delay_us(uint16_t nus) //延时us{uint32_t ui_tmp=0x00;SysTick->LOAD=nus\*fac_us;SysTick->VAL=0x00;SysTick->CTRL=0x01;do{ui_tmp=SysTick->CTRL;}while((ui_tmp&0x01) && (!(ui_tmp & (1<<16))));SysTick->CTRL=0x00;SysTick->VAL=0x00;}void delay_ms(uint16_t nms) //延时ms{uint32_t ui_tmp=0x00;SysTick->LOAD=nms\*fac_ms;SysTick->VAL=0x00;SysTick->CTRL=0x01;do{ui_tmp=SysTick->CTRL;}while((ui_tmp&0x01) && (!(ui_tmp&(1<<16))));SysTick->VAL=0x00;SysTick->CTRL=0x00;}void SysTick_Handler(void){flag=~flag;}(4)定时器延时void TIM3_Int_Init(uint16_t arr,uint16_t psc){TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;NVIC_InitTypeDef NVIC_InitStructure;RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);//设置在下⼀个更新事件装⼊活动的⾃动重装载寄存器周期的值,计数10000为1s;TIM_TimeBaseStructure.TIM_Period = arr;//设置⽤来作为TIMx时钟频率除数的预分频值,10kHz的计数频率TIM_TimeBaseStructure.TIM_Prescaler = psc;//设置时钟分割:TDIS = Tck_timTIM_TimeBaseStructure.TIM_ClockDivision = 0;//设置TIM向上计数模式TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;//初始化TIMx的时间基数单位TIM_TimeBaseInit(TIM3,&TIM_TimeBaseStructure);//使能指定的TIM3中断,允许更新中断TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE);//TIM3中断NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;//抢占优先级 0 级NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//从优先级 3 级NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;//IRQ通道被使能NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//初始化外设NVIC寄存器NVIC_Init(&NVIC_InitStructure);//使能TIMx外设TIM_Cmd(TIM3,ENABLE);}void TIM3_IRQHandler(void){if(TIM_GetITStatus(TIM3,TIM_IT_Update) != RESET) //检查指定的TIM中断发⽣与否 {TIM_ClearITPendingBit(TIM3,TIM_IT_Update); //清除TIMx的中断待处理位if(flag==0){flag=1;GPIO_ResetBits(GPIOB,GPIO_Pin_0) ;}else{flag=0;GPIO_SetBits(GPIOB,GPIO_Pin_0);}}}注意:定时时间的计算定时器时钟为:CK_CLK预分频数值:PSC⾃动装载寄存器数值:ARR进⼊中断的次数:timet=time\*(ARR+1)\*(PSC+1)/(CK_CLK)。

51单片机延时函数

51单片机延时函数

51单片机延时函数在嵌入式系统开发中,51单片机因其易于学习和使用、成本低廉等优点被广泛使用。

在51单片机的程序设计中,延时函数是一个常见的需求。

通过延时函数,我们可以控制程序的执行速度,实现定时器功能,或者在需要的时候进行延时操作。

本文将介绍51单片机中常见的延时函数及其实现方法。

一、使用for循环延时这种方法不精确,但是对于要求不高的场合,可以用来估算延时。

cvoid delay(unsigned int time){unsigned int i,j;for(i=0;i<time;i++)for(j=0;j<1275;j++);}这个延时函数的原理是:在第一个for循环中,我们循环了指定的时间次数(time次),然后在每一次循环中,我们又循环了1275次。

这样,整个函数的执行时间就是time乘以1275,大致上形成了一个延时效果。

但是需要注意的是,这种方法因为硬件和编译器的不同,延时时间会有很大差异,所以只适用于对延时时间要求不精确的场合。

二、使用while循环延时这种方法比使用for循环延时更精确一些,但是同样因为硬件和编译器的不同,延时时间会有差异。

cvoid delay(unsigned int time){unsigned int i;while(time--)for(i=0;i<1275;i++);}这个延时函数的原理是:我们先进入一个while循环,在这个循环中,我们循环指定的时间次数(time次)。

然后在每一次循环中,我们又循环了1275次。

这样,整个函数的执行时间就是time乘以1275,大致上形成了一个延时效果。

但是需要注意的是,这种方法因为硬件和编译器的不同,延时时间会有差异,所以只适用于对延时时间要求不精确的场合。

三、使用定时器0实现精确延时这种方法需要在单片机中开启定时器0,并设置定时器中断。

在中断服务程序中,我们进行相应的操作来实现精确的延时。

这种方法需要使用到单片机的定时器中断功能,相对复杂一些,但是可以实现精确的延时。

51单片机延时时间计算和延时程序设计

51单片机延时时间计算和延时程序设计

一、关于单片机周期的几个概念时钟周期时钟周期也称为振荡周期,定义为时钟脉冲的倒数(可以这样来理解,时钟周期就是单片机外接晶振的倒数,例如12MHz 的晶振,它的时间周期就是1/12 us),是计算机中最基本的、最小的时间单位。

在一个时钟周期内,CPU仅完成一个最基本的动作。

机器周期完成一个基本操作所需要的时间称为机器周期。

以51 为例,晶振12M,时钟周期(晶振周期)就是(1/12)μs,一个机器周期包含12 个时钟周期,一个机器周期就是1μ s。

指令周期:执行一条指令所需要的时间,一般由若干个机器周期组成。

指令不同,所需的机器周期也不同。

对于一些简单的的单字节指令,在取指令周期中,指令取出到指令寄存器后,立即译码执行,不再需要其它的机器周期。

对于一些比较复杂的指令,例如转移指令、乘法指令,则需要两个或者两个以上的机器周期。

2.延时常用指令的机器周期1.指令含义DJNZ:减 1 条件转移指令这是一组把减 1 与条件转移两种功能结合在一起的指令,共2条。

DJNZ Rn,rel ;Rn←(Rn)-1;若(Rn)=0,则PC←(PC)+2 ;顺序执行;若(Rn)≠ 0,则PC←(PC)+2+rel,转移到rel 所在位置DJNZ direct,rel ;direct ←(direct )-1;若(direct)= 0,则PC←(PC)+3;顺序执行;若(direct)≠ 0,则PC←(PC)+3+rel,转移到rel 所在位置2.DJNZ Rn,rel 指令详解例:MOV R7,#5DEL:DJNZ R7,DEL; r在el本例中指标号DEL三、51 单片机延时时间的计算方法和延时程序设计1.单层循环由上例可知,当Rn赋值为几,循环就执行几次,上例执行 5 次,因此本例执行的机器周期个数=1(MOV R7,#5)+2(DJNZ R7,DE)L ×5=11,以12MHz的晶振为例,执行时间(延时时间)=机器周期个数×1μs=11μ s,当设定立即数为0 时,循环程序最多执行256 次,即延时时间最多256μ s。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验一单片机延时程序实验一、实验目的与要求:在使用4MH在外部晶体振荡器的PIC16F877A上用软件设计一个20ms的软件延时子程序。

另外,还要求用MPLAB的软件模拟器及其附带的软件工具窗口stopwatch观测延时程序执行的时间。

二、实验内容:1.硬件电路设计:本实验中用的是软件延时,利用循环来实现延时功能。

电路就用了单片机的原本电路。

没有用到其他的功能模块,单片机与ICD3相连接。

2.软件设计思路:单片机软件延时的前提和基础是每条指令的执行时间是固定的,且大部分指令的执行时间是相同的。

这要求对每条指令所花费的指令周期(Tcy)做到心中有数。

指令集中5条无条件跳转指令GOTO,CALL.RETURN,RETLW和RETFIE,由于它们必然引起程序跳转,造成流水线中断,因此肯定将占用2个指令周期。

而其他4条有可能引起程序跳转的条件跳转指令DECFSZ,INCFSZ,BTFSC和,BTFSS的执行时间,需要占用2个指令周期,当条件为假不发生跳转时,仅占用1个指令周期。

其余所有指令都只用1个指令周期。

每个指令周期Tcy的时间长度,计算方法:如果采用4MHz 的外部晶体(fosc=4 MHz),则PIC中档单片机的指令周期Tcy 为1us,这是一个整数。

而采用其他频率的外部晶体时,指令周期时间将反比于外部晶体频率。

至于软件延时的结构和实现方法,其实可以采用任何指令和结构,因为只是通过执行指令耗费时间。

但通常情况下有两个选择延时程序结构的原则:(1)执行指令周期数计算方便。

如果含有太多复杂的条件跳转循环等结构势必会造成指令周期的计算困难,甚至可能造成执行所造成的软件延时时间不等。

(2)不能占用太多的程序空间。

试想用20000个NOP指令来实现20ms的延时,显然是可以的,但是这样做浪费了整整一个页的程序存储器,得不偿失,而通过适当的循环结构,重复执行某些相同的程序是比较合理的方法。

因此,软件延时程序一般采用下列方法:如果延时时间短(微妙级别),可以连续插入几条NOP指令;如果延时时间长(几个毫秒级别),则可以使用双嵌套循环的方法来实现。

实验的流程图:实验的源程序:#INCLUDE “P16F877A.INC”ORG 0000HNOPBSF STATUS,5CLRF TRISDBCF STA TUS,5CLRF PORTD LOOPBCF PORTD,0CALL DELAYBSF PORTD,0CALL DELAYGOTO LOOPDELAY MOVLW D’131’MOVWF iLOOP1 MOVLW D’50’MOVWF jLOOP2 DECFSZ j,fGOTO LOOP2DECFSZ i,fGOTO LOOP1RETURNEND执行上述延时子程序所需要的指令周期个数等于(1+1)+[(1+1)+(1+2)×(j-1)+2+(1+2)]×(i-1)+2+2。

当i等于131,j 等于50是指令周期数约为20000个。

在4HMz外部晶振条件下,这个延时程序将花费大约20ms。

程序说明如下:(1)上述等式中,第一个括号中的“1+1”对应两条向i中放入初值131的两条搬运指令。

(2)中括号中的“1+1”对应两条向j中放初值50的两条搬运指令。

(3)中括号中的第一个“1+2”对应DECFSZ和GOTO指令,当j没有被减到0时,这两条指令将被连续循环(j-1)次,因此每次将花费(1+2)×(j-1)个指令周期。

(4)当j被减到0时,单片机将跳过6行的GOTO指令,这时DECFSZ将花费2个指令周期的时间,也就是接在(1+2)×(j-1)之后加上的那个“2”。

(5)上式中括号里最后的那个“1+2”对应接下来的DECFSZ 和GOTO指令,和上面的一对DECFSZ和GOTO指令一样,在i被减到0之前,这两条指令将被连续循环(i-1)次。

(6)当在i被减到0时,单片机将跳过第8行的GOTO指令,,也就是式中的倒数第二个”2”。

(7)最后的“2”对应RETURN指令。

在设计和编写延时子程序时,为了精确计算整个延时程序的延迟时间,常常需要逐条分析每一条指令被执行的所占用的指令周期数,这是一项既枯燥又费力的工作。

可以利用MPLAB软件提供的stopwatch窗口来直接得到延时程序运行的时钟周期数。

这里的跑马表功能类似于田径场上赛跑计时用的跑表或者称为秒表,还有人叫它马表。

打开跑表观察窗口的操作很简单,在MPLAB SIM软件模拟器模式下,选择Debugger 菜单中的stopwatch即可弹出观察窗。

该窗口可以计算一段程序执行过程所需要的指令周期数和占用时间。

在程序运行的过程中,软件模器会更新instruction Cycles 和Time域,包括时间单位。

使用跑马表观察窗口的方法如下:(1)单击Synch(同步),将Stopwatch的值与Total Simulated(模拟总数)的值同步。

(2)单击Zero(归零),可以随时将Instruction Cycles和Time 的值设置为0.(3)选择Clear Simulation Time On Reset(在复位时清零模拟时间),可以在程序复位时将Instruction Cycles(指令周期)和Time的值设置为0.(4)其实MPLAB可以通过Debugger菜单下Setting菜单项配置Processor Frequency值。

单击Debugger下的Settings,在弹出的Simulator Settings对话框中的osc/trace(振荡器,跟踪)选项卡中设置。

三、实验步骤及结果:1.从开始菜单运行MPLAB,打开MPLAB后,在PROJECT菜单中选择project wizard。

单机弹出的工程向导窗口中的“下一步”按钮;在工程向导第一步的窗口中选择本工程要使用的单片机型号PIC16F877A;在工程向导第二部的窗口上部选择合适的编译工具包—microchip MPASM toolsuite,窗口中部显示了这个编译工具包内的工具,单击任何一个工具就会在窗口的下部显示这个工具所在的路径,如果MPLAB安装在省缺路径则无需修改这些工具的路径;在工程向导第三部的窗口中给新创建工程命名并选择新创建的工程所在的路径;在工程向导第四部的窗口中,可以将能重复使用的程序文件拷贝到本工程中。

完成以上四步吼就输入了创建新工程所需要的所有参数,工程向导将在最后的总结窗口中显示这些参数,合适无误后单机“完成”即可完成新工程的创建工作。

2.配置单片机的基本工作方式。

单击MPLAB开发环境中单击configure菜单下的configuration bits,在弹出的配置位置窗口中首先去掉configuration bits set in code复选框前面的小勾。

接着逐一设置窗口中提供的单片机配置位:将振荡器类型设置为“TX”;“看门狗”应该关闭,将其设置为“OFF”;将上电复位定时器关闭;将电压检测电路关闭;低电压编程设置为“disabled”;将数据EEPROM读保护关闭;将用户程序Flash写保护设置为“write protection off”;将代码保护关闭。

完成以上设置后关闭配置位窗口。

3.使用软件模拟器测试代码。

在MPLAB开发环境的Debugger菜单中选择MPLAB SIM,此时MPLAB环境的外观和菜单项都会发生变化。

4.选择file菜单下的new命令新建一个汇编语言文件,输入按本实验要求所编写的代码,保存时注意选择文件的类型为汇编语言源文件。

5.用右键单击MPLAB的工程管理窗口,从弹出的快捷菜单中选择add file……,将第四步编写好的汇编文件加入工程中。

6.编译工程。

在project菜单中选择build all。

如果有错误,则根据输出窗口的提示改正之,直到完全正确。

7.运行程序。

编译完成后,从如图所示的方针环境设置窗口将processor frequency设置为4MHz。

选择debugger菜单中的stopwatch,打开跑表观察窗,并将接着在源程序编辑窗口选中“call delay”语句,然后鼠标右击,在弹出的快捷菜单中选择run to cursor指令项,程序开始执行。

这是跑表观察窗口中有了时间和指令周期显示,表示此前被执行过的指令所占用的时间和指令表周期数。

这个显示值不是我们所关心的,单击“zero”按钮将其清零,再单击debugger菜单中的step ove 指令想,“跑表”便开始累计记录延时子程序运行的时间和指令周期数,当程序停止运行时,跑表观察窗中stopwatch所显示出的信息就是执行延时子程序所花费的时间和指令周期数。

8.如果该时间值不符合设计者的要求,可以修改延时子程序中的内循环参数j和外循环参数i,然后重复步骤6和7,按照同样的方法运行程序,并观察延时子程序消耗的时间。

反复这一过程,直到延迟时间满意为止。

四、实验心得:(主要是实验中遇到的问题,以及解决方案!)在进行编写源程序的时候出现了很多问题,虽然老师说这个实验是比较简单的实验,但在第一次运用所学的知识来进行简单的编写还是遇到了很多问题,在自己的感觉下写出来的程序有很多问题,怎么改都有错误,但在我们细心的一步一步的慢慢调试修改后终于编译成功了,我们在写源代码的时候犯了很基本的错误,在照着书打的时候打错了几个单词导致一直错误。

还有就是编写的延时子程序应该要在END之前,我们写在了END之后,一直运行错误。

在编译成功后,我们就迫不急待的连接上ICD3进行模拟,一直没有得到结果,感觉都有点失望的时候,积极的询问老师,老师的一句话点醒了我们,我们太急躁忘记修改配置,又认认真真的看了几遍书,照着书上的要求一步一步的进行设置,最终得到了正确的结果。

也让我们知道了以后在做任何实验的时候一定要认真仔细,提前要先预习好,按照步骤一步一步的进行,心急吃不了热豆腐。

沉着冷静,仔细认真才能走向成功!。

相关文档
最新文档