过程也由过程首和过程体构成,在进程或结构体中不必定义过程首,而在过程包中必须定义过程首。
2.函数是串行,过程是串行。
3区别:(1)参数表的区别。函数的参数表是用来定义输出值的,所以不必以显式表示参数的方向;过程的参数表可以对常数、变量和信号三类数据对象目标作出说明,并用关键词IN、OUT和INOUT定义这些参数的工作模式,即信息的流向。如果没有指定模式,则默认为IN。 (2)函数参量可以是信号或常数,默认函数参数为常数;过程的参数类型可以是常量或者是变量。
(3)过程可有多个返回值,函数只能有一个。 (4)过程中可以有wait,而函数中不可以。
(5)调用方式:函数调用时将所定义的函数作为语句中的一个因子如如一 *** 作数或赋值句。过程调用将定义的过程名作为一条语句来执行。
**** IC=AT89S52 F=12MHz T=1uS ********************************************* WRITER:COCO.LI*************
定时器T0、T1溢出周期为50MS(10MS),T0为秒计数用,T1为调整时闪烁用,
**** P1.0、P1.1、P1.2为调整按钮,P0口为字符输出口,采用共阳显示管。
********** 中断程序入口 ****************
ORG 0000H 程序执行开始地址
LJMPSTART 跳到标号START执行
ORG 0003H 外中断0中断程序入口
RETI外中断0中断返回
ORG 000BH 定时器T0中断程序入口
LJMPINTT0 跳到标号INTT0执行
ORG 0013H 外中断1中断程序入口
RETI外中断1中断返回
ORG 001BH 定时器T1中断程序入口
LJMPINTT1 跳到标号INTT1执行
ORG 0023H 串行口中断程序入口
RETI串行口中断程序返回
主程序
ORG 0030H
START:LCALL ST 上电显示年月日及班级学号
MOV R0,#70H 清70H~7AH共11个内存单元
MOV R7,#0BH
CLEARDISP:
MOV @R0,#00H
INC R0
DJNZR7,CLEARDISP
MOV 20H,#00H清20H , 标志用
MOV 7AH,#0AH放入“熄灭符”数据
MOV TMOD,#11H 设T0、T1为16位定时器
MOV TL0,#0B0H 50MS定时初值,T0计时用
MOV TH0,#3CH50MS定时初值
MOV TL1,#0B0H 50MS定时初值,T1闪烁定时用
MOV TH1,#3CH50MS定时初值
SETBEA 总中断开放
SETBET0 允许T0中断
SETBTR0 开启T0定时器
MOV R4,#14H 1 S定时用初值50MS*20
START1:
LCALL DISPLAY 调用显示子程序
JNB P3.3,SETMM1 P3.3口为0时,转时间调整程序
JNB P3.4,FUNSS 秒表功能,P3.4按键调时时作减1 *** 作
JNB P3.5,FUNPT STOP,PUSE,CLR
SJMPSTART1 P3.3口为1时跳回START1
SETMM1:
LJMPSETMM 转到时间调整程序SETMM
FUNSS:
LCALL DS20MS
JB P3.4,START1
WAIT11:
JNB P3.4,WAIT11
CPL 03H
MOV 70H,#00H
MOV 70H,#00H
MOV 70H,#00H
MOV 70H,#00H
MOV 70H,#00H
MOV 70H,#00H
AJMPSTART1
FUNPT:
LCALL DS20MS
JB P3.5,START1
WAIT22:
JNB P3.5,WAIT21
CLR ET0
CLR TR0
WAIT33:
JB P3.5,WAIT31
LCALL DS20MS
JB P3.5,WAIT33
WAIT66:
JNBP3.5,WAIT61
MOVR0,#70H 清70H~79H共10个内存单元
MOVR7,#0AH
CLEARP:
MOV@R0,#00H
INCR0
DJNZ R7,CLEARP
WAIT44:
JB P3.5,WAIT41
LCALL DS20MS
JB P3.5,WAIT44
WAIT55:
JNBP3.5,WAIT51
SETB ET0
SETB TR0
AJMP START1
WAIT21:
LCALL DISPLAY
AJMP WAIT22
WAIT31:
LCALL DISPLAY
AJMP WAIT33
WAIT41:
LCALL DISPLAY
AJMP WAIT44
WAIT51:
LCALL DISPLAY
AJMP WAIT55
WAIT61:
LCALL DISPLAY
AJMP WAIT66
1 s计时程式
T0中断服务程序
INTT0:
PUSHACC 累加器入栈保护
PUSHPSW 状态字入栈保护
CLR ET0 关T0中断允许
CLR TR0 关定时器T0
JB 03H,FSS 标志为1转秒表处理程序,,10MS定时
MOV A,#0B7H 中断响应时间同步修正
ADD A,TL0 低8位初值修正
MOV TL0,A 重装初值,,低8位修正值
MOV A,#3CH 高8位初值修正
ADDCA,TH0
MOV TH0,A 重装初值,, 高8位修正值
SETBTR0 开启定时器T0
DJNZR4,OUTT020次中断未到中断退出
ADDSS:
MOV R4,#14H 20次中断到,重赋初值,,1S
MOV R0,#71H 指向秒计时单元..71H~72H
ACALL ADD1调用加1程序,,加1S *** 作.
MOV A,R3秒数据放入A,,R3为2位十进制数组合
CLR C 清进位标志
CJNEA,#60H,ADDMM
ADDMM:
JC OUTT0 短于60S时中断退出
ACALL CLR0长于或者等于60S时对秒计数单元清0
MOV R0,#77H 指向分计时单元,,76H~77H
ACALL ADD1分计时单元加1
MOV A,R3分数据放入A
CLR C 清进位标志
CJNEA,#60H,ADDHH 秒表时最大为99
ADDHH:
JC OUTT0 短于60min时中断退出
ACALL CLR0长于或者等于60min时对分计数单元清0
MOV R0,#79H 指向分计时单元,,78H~79H
ACALL ADD1小时计时单元加1h
MOV A,R3时数据放入A
CLR C 清进位标志
JB 03H,OUTT0 秒表时最大为99
CJNEA,#24H,HOUR
HOUR:
JC OUTT0 短于24h时中断退出
ACALL CLR0长于或者等于24h时对计时单元清0
OUTT0:
MOV 72H,76H 中断退出时将分\时计时单元数据移
MOV 73H,77H 入对应显示单元
MOV 74H,78H
MOV 75H,79H
POP PSW 恢复状态字出栈
POP ACC 恢复累加器
SETBET0 开放T0中断
RETI
秒表计时程序(10min加1),低2位为0.1、0.01秒,中间2位为秒,最高2位为分.
最大计数值为99分59.99秒
FSS:MOV A,#0F7H
ADD A,TL0
MOV TL0,A
MOV A,#0D8H
ADDCA,TH0
MOV TH0,A
SETBTR0
MOV R0,#71H
ACALL ADD1
CLR C
MOV A,R3
JZ FSS1
SETBC
FSS1: AJMPADDMM
闪动调时程式
T1中断服务程序,用作时间调整单元闪烁指示
INTT1: PUSHACC
PUSHPSW
MOV TL1,#0B0H
MOV TH1,#3CH
DJNZR2,INTT1OUT
MOV R2,#06H
CPL 02H
JB 02H,FLASH1
MOV 72H,76H
MOV 73H,77H
MOV 74H,78H
MOV 75H,79H
INTT1OUT:
POP PSW
POP ACC
RETI
FLASH1: JB 01H,FLASH2
MOV 72H,76H
MOV 73H,77H
MOV 74H,78H
MOV 75H,79H
AJMPINTT1OUT
FLASH2: MOV 72H,76H
MOV 73H,77H
MOV 74H,78H
MOV 75H,79H
AJMPINTT1OUT
加1子程序
ADD1: MOV A,@R0 取当前计时单元数据到A
DEC R0 指向前一地址
SWAPA A中数据高四位与低四位交换
ORL A,@R0 前一地址中数据放入A中低四位
ADD A,#01H A加1 *** 作
DA A 十进制调整
MOV R3,A 移入R3中暂存数据
ANL A,#0FH 高四位变0
MOV @R0,A 数据放入当前地址单元中
MOV A,R3 返回
INC R0
SWAPA
ANL A,#0FH
MOV @R0,A
RET
分减1子程序
SUB1: MOV A,@R0 取当前计时单元数据到A
DEC R0 指向前一地址
SWAPA A中数据高四位与低四位交换
ORL A,@R0 前一地址中数据放入A中低四位
JZ SUB11
DEC A A减1 *** 作
SUB111: MOV R3,A 移入R3中暂存数据
ANL A,#0FH 高四位变0
CLR C 清进位标志
SUBBA,#0AH
SUB1111:
JC SUB1110
MOV @R0,#09H 大于等于0AH,为9
SUB110:
MOV A,R3 取回R3中暂存数据
INC R0 指向当前地址单元
SWAPA A中数据高四位与低四位交换
ANL A,#0FH 高四位变0
MOV @R0,A 数据放入当前地址单元中
RET返回
SUB11: MOV A,#59H
AJMPSUB111
SUB1110:
MOV A,R3 移入R3寄存器
ANL A,#0FH
MOV @R0,A
AJMPSUB110
时减1子程序
SUBB1: MOV A,@R0 取当前计时单元数据到A
DEC R0指向前一地址
SWAPA A中数据高四位与低四位交换
ORL A,@R0 前一地址中数据放入A中低四位
JZ SUBB1100减1为23H
DEC A A减1 *** 作
SUBB111:MOV R3,A 移入R3中暂存数据
ANL A,#0FH高四位变0
CLR C 清进位标志
SUBBA,#0AH时个位大于9为9
SUBB1111:
JC SUBB1110
MOV @R0,#09H 大于等于0AH,为9
SUBB110:
MOV A,R3 取回R3中暂存数据
INC R0指向当前地址单元
SWAPA A中数据高四位与低四位交换
ANL A,#0FH高四位变0
MOV @R0,A 数据放入当前地址单元中
RET 返回
SUBB11:
MOV A,#23H
AJMPSUBB111
SUBB1110:
MOV A,R3 时个位小于0A不处理
ANL A,#0FH高四位变0
MOV @R0,A 个位移入
AJMPSUBB110
清0程序
对计时单元复0用
CLR0: CLR A 清累加器
MOV @R0,A 清当前地址单元
DEC R0 指向前一地址
MOV @R0,A 前一地址单元清0
RET子程序返回
时钟调整程序
当调时按键按下时进入此程序
SETMM: CLR ET0关定时器T0中断
CLR TR0关闭定时器T0
LCALL DL1S 调用1S延时程序
JB P3.3,CLOSEDIS 键按下时间短于1S,关闭显示,,省电
MOV R2,#06H进入调时状态,赋闪烁定时初值
SETBET1允许T1中断
SETBTR1开启T1定时器
SET2:
JNB P3.3,SET1 P3.3口为0时,等待,,键未释放
SETB00H键释放,分调整闪烁标志置1
SET4: 等待键按下
JB P3.3,SET3 等待键按下
LCALL DL05S 有键按下,延时0.5S
JNB P3.3,SETHH 按下时间长于0.5S,转调小时状态
MOV R0,#77H按下时间短于0.5S,加1min *** 作
LCALL ADD1 调用加1子程序
MOV A,R3 取调整单元数据
CLR C 消位标志
CJNEA,#60H,HHH 调整单元数据与60比较
HHH:JC SET4 调整单元数据小于60,转SET4循环
LCALL CLR0 调整单元数据大于或等于60时,清0
CLR C 清进位0
AJMPSET4 跳转到SET4循环
CLOSEDIS:
SETBET0省电状态,开T0中断,,LED灯不显示
SETBTR0开启T0中断
CLOSE:
JB P3.3,CLOSE 无键按下,等待
LCALL DISPLAY有键按下,调用显示子程序延时消抖
JB P3.3,CLOSE 是干扰,返回CLOSE等待
WAITH:
JNB P3.3,WAITH 等待键释放
LJMPSTART1 返回主程序,,LED数据显示亮
SETHH: CLR 00H分闪烁标志清除,,进入调小时状态
SETHH1: JNB P3.3,SET5 等待键释放
SETB01H小时调整标志置1
SET6: JB P3.3,SET7 等待键按下
LCALL DL05S 有键按下,延时0.5S
JNB P3.3,SETOUT按下时间长于0.5S,退出时间调整
MOV R0,#79H按下时间短于0.5S,加1h *** 作
LCALL ADD1 调用加1子程序
MOV A,R3
CLR C
CJNEA,#24H,HOUU计时单元数据与24比较
HOUU: JC SET6 小于24,转SET6循环
LCALL CLR0 大于或等于24时,清0 *** 作
AJMPSET6 跳到SET6处循环
SETOUT: JNB P3.3,SETOUT1 调时退出程序.等待键释放
LCALL DISPLAY延时消抖
JNB P3.3,SETOUT是抖动,返回SETOUT再等待
CLR 01H清调小时标志
CLR 00H清调分标志
CLR 02H清闪烁标志
CLR TR1关闭定时器T1
CLR ET1关定时器T1中断
SETBTR0开启定时器T0
SETBET0开启定时器T0中断,,计时开始
LJMPSTART1 跳回主程序
SET1: LCALL DISPLAY键释放等待调时用显示程序
AJMPSET2 防止键按下时无时钟显示
SET3: LCALL DISPLAY等待调分按键时时钟显示用
JNB P3.3,FUNSUB减1分 *** 作
AJMPSET4 调分等待
SET5: LCALL DISPLAY键释放等待调时用显示程序
AJMPSETHH1 防止键按下时无时钟显示
SET7: LCALL DISPLAY等待调小时按键时时钟显示用
JNB P3.3,FUNSUBB 小时减1 *** 作
AJMPSET6 调时等待
SETOUT1:LCALL DISPLAY退出时钟整时键释放等待
AJMPSETOUT 防止键按下时无时钟显示
FUNSUB,分减1程序?
FUNSUB: LCALL DISPLAY延时消抖
JB P3.3,SET41 干扰,返回调分等待
FUNSUB1:JNB P3.3,FUNSUB1 等待键放开
MOV R0,#77H
LCALL SUB1 分减1程序
LJMPSET4 返回调分等待
SET41: LJMPSET4
FUNSUB,时减1程序?
FUNSUBB:LCALL DISPLAY 消抖动
JB P3.4,SET61 干扰,返回调时等待
FUNSUBB1:JNBP3.4,FUNSUBB1
MOV R0,#79H
LCALL SUBB1
LJMPSET6
SET61: LJMPSET6
显示程序
显示数据在70H~75H单元内,用六位LED共阳数码管显示。
扫描控制,每个LED数码管亮1mS时间。
DISPLAY:
MOV R1,#70H 指向显示数据首址
MOV R5,#0DFH 扫描控制字初值
PLAY: MOV A,R5 扫描字放入A
MOV P2,A 从P2口输出
MOV A,@R1 取显示数据到A
MOV DPTR,#TAB 取段码表地址
MOVCA,@A+DPTR 查显示数据对应段码
MOV P0,A 段码放入P0口
MOV A,R5
JB ACC_1,LOOP5 小数点处理
CLR P0.7
LOOP5: JB ACC_3,LOOP6
CLR P0.7
LOOP6: LCALL DL1MS 显示1MS
INC R1指向下一地址
MOV A,R5 扫描控制字放入A
JNB ACC_0,ENDOUT ACC.0=0时,一次显示结束
RR A A中数据循环左移
MOV R5,A 放回R5内
MOV P0,#0FFH
AJMPPLAY 跳回:PLAY循环.
ENDOUT: MOV P2,#0FFH 一次显示结束,P2口复位
MOV P0,#0FFH P0口复位
RET 子程序返回
TAB:DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H,0FFH,88H,0BFH
共阳段码表 1、 2、 3、 4、 5、 6、 7、 8、 9、不亮、A、—。
SDISPLAY,上电显示程序
不带小数点,有A、— 显示功能
SDISPLAY:
MOV R5,#0DFH 扫描控制字初值
SPLAY: MOV A,R5 扫描字放入A
MOV P2,A 从P2口输出
MOV A,@R1 取显示数据到A
MOV DPTR,#TABS取段码表地址
MOVCA,@A+DPTR 查显示数据对应段码
MOV P0,A 段码放入P0口
MOV A,R5
LCALL DL1MS 显示1MS
INC R1指向下一地址
MOV A,R5 扫描控制字放入A
JNB ACC_0,ENDOUTS ACC.0=0时,一次显示结束
RR A A中数据循环左移
MOV R5,A 放回R5内
AJMPSPLAY 跳回:PLAY循环.
ENDOUTS:MOV P2,#0FFH 一次显示结束,P2口复位
MOV P0,#0FFH P0口复位
RET 子程序返回
TABS: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H,0FFH,88H,0BFH
STAB表,启动时显示2003-12-07、A01-2-28
STAB: DB 0AH,0AH,0AH,0AH,0AH,0AH,08H,02H,0CH,02H,0CH,01H,00H,0BH,0AH,0AH
DB 07H,00H,0CH
DB 07H,00H,0CH,02H,01H,0CH,03H,00H,00H,02H,0AH,0AH,0AH,0AH,0AH,0AH
注:0A不亮,0B显示“A”,0C显示“-”
ST子程序,上电时显示年月日用,采用移动显示
ST: MOV R0,#40H 将显示内容移入40H~50H单元
MOV R2,#20H
MOV R3,#00H
CLR A
MOV DPTR,#STAB
SLOOP:
MOVCA,@A+DPTR
MOV @R0,A
MOV A,R3
INC A
MOV R3,A
INC R0
DJNZR2,SLOOP 移入完毕
MOV R1,#5AH
MOV R3,#1BH 显示27个单元
SSLOOP:
MOV R2,#32H 控制移动速度
SSLOOP1:
LCALL SDISPLAY
DJNZR2,SSLOOP11
MOV A,R1
SUBBA,#07H 显示首址修正为低1个单元
MOV R1,A
DJNZR3,SSLOOP
RET
SSLOOP11:
MOV A,R1指针修正为原值
SUBB A,#06H
MOV R1,A
AJMP SSLOOP1
延时程序
1ms延时程序,LED显示程序用
DL1MS: MOV R6,#14H
DL1:MOV R7,#19H
DL2:DJNZ R7,DL2
DJNZ R6,DL1
RET20MS延时程序,采用调用显示子程序,以改善LED的显示闪烁现象
DS20MS: ACALLDISPLAY
ACALLDISPLAY
ACALLDISPLAY
RET延时程序,用作按键时间的长短判断
DL1S:
LCALLDL05S
LCALLDL05S
RET
DL05S:
MOV R3,#20H8ms*32=0.196s
DL05S1:
LCALLDISPLAY
DJNZ R3,DL05S1
RET
END 程序结束
eda编程9人表决器程序详解://本程序用VERILOG HDL语言实现,描述9人表决器。
module biaojueqi(vote,ledr,ledg,dis_out)
input [8:0] vote
reg [6:0] dis_out
integer i,sum//sum表示赞同的人数
for(i=0i<=8i=i+1)
if(vote[i]) sum<=sum+1
end
always @(sum) //结果由dis_out显示在数码管上
case (sum)
0: dis_out[6:0]<=7'b1111110
1: dis_out[6:0]<=7'b0110000
2: dis_out[6:0]<=7'b1101101
3: dis_out[6:0]<=7'b1111001
4: dis_out[6:0]<=7'b0110011
5: dis_out[6:0]<=7'b1011011
6: dis_out[6:0]<=7'b1011111
7: dis_out[6:0]<=7'b1110000
8: dis_out[6:0]<=7'b1111111
9: dis_out[6:0]<=7'b1111011
endmodule
内容简介
本书从实际应用的角度出发,全面系统地介绍了EDA技术和硬件描述语言VHDL,将VHDL的基础知识、编程技巧、实用方法与实际工程开发技术在EDA软件设计平台上很好地结合起来,使读者能够通过本书的学习迅速了解并掌握EDA技术的基本理论和工程开发实用技术。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)