最近要用STC单片机写个程序,但STC在KEIL的单片机库中没有,就随意找了个替代,可是刚好找到的keil没有增加StartUp.A51文件,刚开端时分写程序调程序也没什么,挺正常。但后来越来越古怪,常常上电时犯错,找了好久才发现有个变量没有初始化为0。遽然发觉是不是keil上电时没有帮我清空内存空间!一看才知道没有StartUp.A51文件。加上后,设置内部空间及外部空间地址,一切正常。足足浪费了我一天的时刻。 因为CPU和程序发动代码文件STARTUP.a51的重要性,一些8051派生的CPU产品要求初始化CPU来满意规划中的相应的硬件,因而,有时分用户需求对STARTUP.a51进行修正,所以进行注释一下: ;————————————————— ;startup.A51: 用户上电初始化程序 ;—————————————————- ; ;运用以下EQU指令可界说在CPU复位时需求用0进行初始化的内存空间 ; ;IDATA存储器的空间的肯定开端地址总是零 IDATALEN EQU 80H ;需用0进行初始化的IDATA存储器空间的字节数 ; XDATASTART EQU 0H ;XDATA存储器空间的肯定开端地址 XDATALEN EQU 0H ;需用0进行初始化的XDATA存储器的空间字节数 ; PDATASTART EQU 0H ;PDATA存储器的空间的肯定开端地址 PDATALEN EQU 0H ;需用0进行初始化的PDATA存储器的空间字节数 ;留意:IDATA存储器的空间在物理上包含了8051单片机的DATA和BIT存储空间 ;至少要确保与C51编译器运行库有关的存储器的空间进行0初始化 ; ;再入函数模拟初始化 ;———————————————————– ;以下用EQU指令界说了再入函数模仿仓库指针的初始化 ; ;运用SMALL存储器形式时再入函数的仓库空间 IBPSACK EQU 0 ;运用SMALL存储器形式再入函数时将其设置成1 IBPSTACKTOP EQU 0FFH+1 ;将仓库顶设置为最高地址加1 ; ;运用LARGE存储器形式时再入函数的仓库空间 XBPSTACK EQU 0 ;运用LARGE存储器形式再入函数时将其设置成1 XBPSTACKTOP WQU 0FFFFH+1 ;将仓库顶设置为最高地址加1 ; ;运用COMPACT存储器形式时再入函数的仓库空间 PBPSTACK EQU 0 ; 运用COMPACT存储器形式再入函数时将其设置成1 PBPSTACKTOP WQU 0FFFFH+1 ;将仓库顶设置为最高地址加1 ;;—————————————————- ;运用COMPACT存储器形式时,64KB X DATA存储器空间的分页界说 ; ;以下用EQU指令界说PDATA类型变量在XDATA存储器空间的页地址 ;运用EQU指令界说PFAGE时有必要与L51衔接定位器PDATA指令的操控参数共同
; PPAGEENABLE EQU 0 ;运用PDATA类型变量时将其设置成1 PPAGE EQU 0 ;界说页号 ; ;———————————————— NAME ? C_STARTUP ;模块名为 ? C_STARTUP ? C_51STARTUP SEGMENT CODE ;代码段 ? STACK SEGMENT IDATA ;仓库段 RSEG ? STACK ;仓库 DS 1 EXTRN COE(? C_START) ;程序开端地址 PUBLIC ? C_STARTUP CSEG AT 0x8000 ;界说用户程序的开端地址,用MON51仿真器时或许有用 ? C_STARTUP: LFMP STARTUP1 RSEG ? C_51STARTUP STARTUP1: ; ;初始化串口 MOV SCOM, #40H MOV TMOD, #20H MOV TH1, #0FDH SETB TR1 CLR T1 ;单片机上电IDATA内存清零,假如不需求上电清零IDATA,能够刊出IF到IFEDN之间的 ;句子,或许修正IDTALEN的长度,为了让CPU具有掉电维护功用,需求确认IDTALEN的长度 IF IDATALEN <> 0 MOV R0, # IDATALEN-1 CLR A IDATALOOP: MOV @R0,A DJNZ R0,IDATALOOP ENDIF ; ;单片机上电XDATA内存清零,假如不需求上电清零XDATA,能够刊出IF到IFEDN之间的 ;句子,或许修正XDTALEN的长度 IF XDATALEN <> 0 MOV DPTR, #XDATASTART MOV R7,#LOW (XDATALEN) IF (LOW(XDATALEN)) <> 0 MOV R6, #(HIGH(XDATALEN))+1 ELSE MOV R6, #HIGH (XDATALEN) ENDIF CLR A XDATALOOP: MOVX @DPTR, A
INC DPTR DJNZ R7, XDATALOOP DJNZ R6, XDATALOOP END IF ; ;送PDATA存储器页面高位地址 IF PPAGEENABLE <> 0 MOV P2, #PPAGE ENDIF ; ;单片机上电PDATA内存清零,假如不需求上电清零XDATA,可刊出IF到IFEDN之 ;间的句子或许修正PDATALEN的长度 IF PDATALEN <> 0 MOV R0, #PDATASTART MOV R7, #LOW (PDATALEN) CLR A PDATALOOP: MOV @R0, A INC R0 DJNZ R7,PDATALOOP ENDIF ; ;设置运用SMALL存储器形式时再入函数的仓库空间 IF IBPSTACK <> 0 EXTRN DATA(? C_IBP) MOV ? C_IBP, #LOW IBPSTACKTOP ENDIF ; ;设置运用LARGE存储器形式时再入函数的仓库空间 IF XBPSTACK <> 0 EXTRN DATA (? C_XBP) MOV ? C_XBP, #HIGH XBPSTACKTOP MOV ? C_XBP +1, #LOW XBPSTACKTOP ENDIF ; ;设置运用COMPACT存储器形式时再入函数的仓库空间 IF PBPSTACK <> 0 EXTRN DATA(? C_PBP) MOV ? C_PBP, #LOW PBPSTACKTOP END IF ; ;设置仓库的开端地址 MOV SP, #? STACK-1 ;例如 MOV SP, #4FH ; ;假如程序超越64K,则运用程序分组技能,发动下面的程序
;EXTRN CODE(? B_SWITCH0) ;CALL ? B_SWITCH0 ;程序从第一组bank 0 块开端履行 ;跳转到用户程序MAIN函数 LJMP ? C_START END startup.a51的效果和汇编相同,在C中界说的那些变量和数组的初始化就在startup.a51中进行,假如你在界说全局变量时带有数值,如unsigned char data xxx=”100″;,那startup.a51 中就会有相关的赋值。假如没有=100,startup.a51就会把他清0。(startup.a51==变量的初始化)。 这些初始化结束后,还会设置SP指针。对非变量区域,如仓库区,将不会有赋值或清零动作。 有人喜爱改startup.a51,为了满意自己一些想当然的喜好,这是不必要的,有或许过错的。比方掉电维护的时分想保存一些变量, 但改startup.a51来完成是很笨的办法,实践只需使用非变量区域的特性,界说一个指针变量指向仓库低部:0xff处就可完成。, 为什么还要去改? 能够这么说:任何时分都能够不需求改startup.a51,假如你理解它的特性
keil中StartUp.A51的重要性
最近要用STC单片机写个程序,但STC在KEIL的单片机库中没有,就随便找了个代替,但是刚好找到的keil没有添加StartUp.A51文件,刚开始时候写…
声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/yingyong/276893.html