首先在windows下安装make工具,并建立好ADS工程。
编译命令make -f ads.mk,执行过程请看截图http://hi.csdn.net/space-2513952-do-album-picid-507759.html
MYPATH = C:/boot/44b_flash
PAT = D:/Program Files/ARM/ADSv1_2/Bin
MYLDPATH = D:/arm7/lib
CC = $(PAT)/armcc
LD = $(PAT)/armlink
OBJTOOL = $(PAT)/fromelf
RM = del -f
#AS = $(PAT)/armasm -keep -g
AS = $(PAT)/armasm -keep -g
ASFILE = $(MYPATH)/SRC/44BINIT.S
CFLAGS = -O1 -g+ -Wa -DNO_UNDERSCORES=1 -I../inc
MODEL = test
#SRC = 29lv160.c 44BLIB.C 44BMAIN.C
SRC =$(wildcard *.c)
#OBJS = 29lv160.o 44BLIB.o 44BMAIN.o
DIR = $(notdir $(SRC))
OBJS_TMP = $(patsubst %.c, %.o, $(DIR)) 这里只是把.c转为.o,但.C未被转为.o
OBJS = $(patsubst %.C, %.o, $(OBJS_TMP )) 完成将.C转为.o
all:$(MODEL).axf $(MODEL).bin clean
$(MODEL).axf:$(OBJS) 44BINIT.o
@echo "### Linking ..."
$(LD) $(OBJS) 44BINIT.o -ro-base 0xc000000 -first 44BINIT.o(Init) -o $@ -libpath $(MYLDPATH)
# $(LD) $(OBJS) 44BINIT.o -info totals -ro-base 0xc000000 -first 44BINIT.o(Init) -o $@ -libpath $(MYLDPATH)
# $(LD) $(OBJS) 44BINIT.o -ro-base 0xc000000 -entry Main -first 44BINIT.o -o $@ -libpath $(MYLDPATH)
$(MODEL).bin: $(MODEL).axf
$(OBJTOOL) -c -bin -output $@ $<
$(OBJTOOL) -c -s -o $(<:.axf=.lst) $< 这句的意思是fromelf -c -s -o test.lst test.axf
%.o:%.c
@echo "### Compiling $<"
$(CC) $(CFLAGS) -c $< -o $@
%.o:%.s
@echo "### Compiling $<"
$(AS) $< -o $@
# $(CC) -g -c $@ $<
clean:
$(RM) 44BINIT.o $(OBJS)
test:
@echo "### Just a test ###"
@echo $(SRC)
@echo "#######"
@echo $(OBJS)
编译过程中遇到的问题及解决方案:
L6211E: Ambiguous section selection. Object <objname> contains more than one section.
This can occur when using the linker option -keep on an assembler object that contains more than
one AREA. The linker needs to know which AREA you would like to keep.
To solve this, specify the names of the AREAs that you wish to keep, using more than one -keep
option, for example: -keep boot.o(vectors) -keep boot.o(resethandler)…
Note that using assembler files with more than one AREA may give other problems elsewhere, so
this is best avoided.
附录:使用AXD中遇到的常用问题
1.DBT Warning 00135: Cannot set breakpoints in literal pools
原因:-ro-base无效。
2.串口显示乱码问题
原来是在44BINIT.S中,一些底层参数设定有问题,至于是那些还不清楚,先把.inc文件贴出来:
; *******************************************************
GET ../include/option.inc <---------- GET ../include/option.s
GET ../include/memcfg.inc <---------- GET ../include/memcfg.s
;Memory Area
;GCS6 64M 16bit(8MB) DRAM/SDRAM(0xc000000-0xc7fffff)
;APP RAM=0xc000000~0xc7effff
;44BMON RAM=0xc7f0000-0xc7fffff
;STACK =0xc7ffa00
option.inc
;**********OPTIONS*******************************
_RAM_STARTADDRESS EQU 0xc000000
;_ISR_STARTADDRESS EQU 0xc7fff00 ;GCS6:64M DRAM/SDRAM
_ISR_STARTADDRESS EQU 0xc1fff00 ;GCS6:16M DRAM
;BUSWIDTH; 16,32
GBLA BUSWIDTH
BUSWIDTH SETA 16
;"DRAM","SDRAM"
GBLS BDRAMTYPE
BDRAMTYPE SETS "SDRAM"
;This value has to be TRUE on ROM program.
;This value has to be FALSE in RAM program.
GBLL PLLONSTART
PLLONSTART SETL {TRUE}
GBLA PLLCLK
PLLCLK SETA 40000000
[ PLLCLK = 40000000
M_DIV EQU 0x48 ;Fin=10MHz Fout=40MHz
P_DIV EQU 0x3
S_DIV EQU 0x2
]
[ PLLCLK = 50000000
M_DIV EQU 0x2a ;Fin=10MHz Fout=50MHz
P_DIV EQU 0x3
S_DIV EQU 0x1
]
[ PLLCLK = 60000000
M_DIV EQU 0x34 ;Fin=10MHz Fout=60MHz
P_DIV EQU 0x3
S_DIV EQU 0x1
;M_DIV EQU 0x34 ;Fin=4MHz Fout=60MHz
;P_DIV EQU 0x0
;S_DIV EQU 0x1
;M_DIV EQU 0x48 ;Fin=3MHz Fout=60MHz
;P_DIV EQU 0x0
;S_DIV EQU 0x1
]
[ PLLCLK = 75000000
M_DIV EQU 0x43 ;Fin=10MHz Fout=75MHz
P_DIV EQU 0x3
S_DIV EQU 0x1
]
;************************************************
END
memcfg.inc
;**********MEMORY CONTROL PARAMETERS*******************************
;Bank 0 parameter
B0_Tacs EQU 0x0 ;0clk
B0_Tcos EQU 0x0 ;0clk
B0_Tacc EQU 0x6 ;10clk
B0_Tcoh EQU 0x0 ;0clk
B0_Tah EQU 0x0 ;0clk
B0_Tacp EQU 0x0 ;0clk
B0_PMC EQU 0x0 ;normal(1data)
;Bank 1 parameter
B1_Tacs EQU 0x3 ;4clk
B1_Tcos EQU 0x3 ;4clk
B1_Tacc EQU 0x7 ;14clk
B1_Tcoh EQU 0x3 ;4clk
B1_Tah EQU 0x3 ;4clk
B1_Tacp EQU 0x3 ;6clk
B1_PMC EQU 0x0 ;normal(1data)
;Bank 2 parameter
B2_Tacs EQU 0x3 ;4clk
B2_Tcos EQU 0x3 ;4clk
B2_Tacc EQU 0x7 ;14clk
B2_Tcoh EQU 0x3 ;4clk
B2_Tah EQU 0x3 ;4clk
B2_Tacp EQU 0x3 ;6clk
B2_PMC EQU 0x0 ;normal(1data)
;Bank 3 parameter
B3_Tacs EQU 0x3 ;4clk
B3_Tcos EQU 0x3 ;4clk
B3_Tacc EQU 0x7 ;14clk
B3_Tcoh EQU 0x3 ;4clk
B3_Tah EQU 0x3 ;4clk
B3_Tacp EQU 0x3 ;6clk
B3_PMC EQU 0x0 ;normal(1data)
;Bank 4 parameter
B4_Tacs EQU 0x3 ;4clk
B4_Tcos EQU 0x3 ;4clk
B4_Tacc EQU 0x7 ;14clk
B4_Tcoh EQU 0x3 ;4clk
B4_Tah EQU 0x3 ;4clk
B4_Tacp EQU 0x3 ;6clk
B4_PMC EQU 0x0 ;normal(1data)
;Bank 5 parameter
B5_Tacs EQU 0x3 ;4clk
B5_Tcos EQU 0x3 ;4clk
B5_Tacc EQU 0x7 ;14clk
B5_Tcoh EQU 0x3 ;4clk
B5_Tah EQU 0x3 ;4clk
B5_Tacp EQU 0x3 ;6clk
B5_PMC EQU 0x0 ;normal(1data)
;Bank 6(if SROM) parameter
B6_Tacs EQU 0x3 ;4clk
B6_Tcos EQU 0x3 ;4clk
B6_Tacc EQU 0x7 ;14clk
B6_Tcoh EQU 0x3 ;4clk
B6_Tah EQU 0x3 ;4clk
B6_Tacp EQU 0x3 ;6clk
B6_PMC EQU 0x0 ;normal(1data)
;Bank 7(if SROM) parameter
B7_Tacs EQU 0x3 ;4clk
B7_Tcos EQU 0x3 ;4clk
B7_Tacc EQU 0x7 ;14clk
B7_Tcoh EQU 0x3 ;4clk
B7_Tah EQU 0x3 ;4clk
B7_Tacp EQU 0x3 ;6clk
B7_PMC EQU 0x0 ;normal(1data)
;Bank 6 parameter
[ BDRAMTYPE="DRAM" ;MT=01(FP DRAM) or 10(EDO DRAM)
B6_MT EQU 0x2 ;EDO DRAM
B6_Trcd EQU 0x0 ;1clk
B6_Tcas EQU 0x0 ;1clk
B6_Tcp EQU 0x0 ;1clk
B6_CAN EQU 0x2 ;10bit
| ;"SDRAM" ;MT=11(SDRAM)
B6_MT EQU 0x3 ;SDRAM
B6_Trcd EQU 0x0 ;2clk
B6_SCAN EQU 0x0 ;8bit
]
;Bank 7 parameter
[ BDRAMTYPE="DRAM" ;MT=01(FP DRAM) or 10(EDO DRAM)
B7_MT EQU 0x2 ;EDO DRAM
B7_Trcd EQU 0x0 ;2clk
B7_Tcas EQU 0x0 ;2clk
B7_Tcp EQU 0x0 ;2clk
B7_CAN EQU 0x2 ;10bit
| ;"SDRAM" ;MT=11(SDRAM)
B7_MT EQU 0x3 ;SDRAM
B7_Trcd EQU 0x0 ;2clk
B7_SCAN EQU 0x0 ;8bit
]
;REFRESH parameter
REFEN EQU 0x1 ;Refresh enable
TREFMD EQU 0x0 ;CBR(CAS before RAS)/Auto refresh
Trp EQU 0x0 ;2clk
Trc EQU 0x1 ;5clk
Tchr EQU 0x2 ;3clk
REFCNT EQU 1113 ;period=15.6us, MCLK=60Mhz
;************************************************
END
option.s
;**********OPTIONS*******************************
;_RAM_STARTADDRESS EQU 0xc000000
_ISR_STARTADDRESS EQU 0xc7fff00 ;GCS6:64M DRAM/SDRAM
;_ISR_STARTADDRESS EQU 0xc1fff00 ;GCS6:16M DRAM
;BUSWIDTH; 16,32
GBLA BUSWIDTH
BUSWIDTH SETA 16
;"DRAM","SDRAM"
GBLS BDRAMTYPE
BDRAMTYPE SETS "SDRAM"
;This value has to be TRUE on ROM program.
;This value has to be FALSE in RAM program.
GBLL PLLONSTART
PLLONSTART SETL {TRUE}
GBLA PLLCLK
PLLCLK SETA 66000000 ;40000000
[ PLLCLK = 40000000 ;Fin=10MHz Fout=40MHz
M_DIV EQU 0x48
P_DIV EQU 0x3
S_DIV EQU 0x2
]
[ PLLCLK = 50000000 ;Fin=10MHz Fout=50MHz
M_DIV EQU 0x2a
P_DIV EQU 0x3
S_DIV EQU 0x1
]
[ PLLCLK = 60000000 ;Fin=10MHz Fout=60MHz
M_DIV EQU 0x34
P_DIV EQU 0x3
S_DIV EQU 0x1
]
; wwf changed
[ PLLCLK = 66000000 ;Fin=10MHz Fout=66MHz
M_DIV EQU 0x3a
P_DIV EQU 0x3
S_DIV EQU 0x1
]
[ PLLCLK = 75000000 ;Fin=10MHz Fout=75MHz
M_DIV EQU 0x43
P_DIV EQU 0x3
S_DIV EQU 0x1
]
;************************************************
END
memcfg.s
;**********MEMORY CONTROL PARAMETERS*******************************
;Bank 0 parameter
B0_Tacs EQU 0x0 ;0clk
B0_Tcos EQU 0x0 ;0clk
B0_Tacc EQU 0x6 ;10clk
B0_Tcoh EQU 0x0 ;0clk
B0_Tah EQU 0x0 ;0clk
B0_Tacp EQU 0x0 ;0clk
B0_PMC EQU 0x0 ;normal(1data)
;Bank 1 parameter
B1_Tacs EQU 0x3 ;4clk
B1_Tcos EQU 0x3 ;4clk
B1_Tacc EQU 0x7 ;14clk
B1_Tcoh EQU 0x3 ;4clk
B1_Tah EQU 0x3 ;4clk
B1_Tacp EQU 0x3 ;6clk
B1_PMC EQU 0x0 ;normal(1data)
;Bank 2 parameter
B2_Tacs EQU 0x3 ;4clk
B2_Tcos EQU 0x3 ;4clk
B2_Tacc EQU 0x7 ;14clk
B2_Tcoh EQU 0x3 ;4clk
B2_Tah EQU 0x3 ;4clk
B2_Tacp EQU 0x3 ;6clk
B2_PMC EQU 0x0 ;normal(1data)
;Bank 3 parameter
B3_Tacs EQU 0x3 ;4clk
B3_Tcos EQU 0x3 ;4clk
B3_Tacc EQU 0x7 ;14clk
B3_Tcoh EQU 0x3 ;4clk
B3_Tah EQU 0x3 ;4clk
B3_Tacp EQU 0x3 ;6clk
B3_PMC EQU 0x0 ;normal(1data)
;Bank 4 parameter
B4_Tacs EQU 0x3 ;4clk
B4_Tcos EQU 0x3 ;4clk
B4_Tacc EQU 0x7 ;14clk
B4_Tcoh EQU 0x3 ;4clk
B4_Tah EQU 0x3 ;4clk
B4_Tacp EQU 0x3 ;6clk
B4_PMC EQU 0x0 ;normal(1data)
;Bank 5 parameter
B5_Tacs EQU 0x3 ;4clk
B5_Tcos EQU 0x3 ;4clk
B5_Tacc EQU 0x7 ;14clk
B5_Tcoh EQU 0x3 ;4clk
B5_Tah EQU 0x3 ;4clk
B5_Tacp EQU 0x3 ;6clk
B5_PMC EQU 0x0 ;normal(1data)
;Bank 6(if SROM) parameter
B6_Tacs EQU 0x3 ;4clk
B6_Tcos EQU 0x3 ;4clk
B6_Tacc EQU 0x7 ;14clk
B6_Tcoh EQU 0x3 ;4clk
B6_Tah EQU 0x3 ;4clk
B6_Tacp EQU 0x3 ;6clk
B6_PMC EQU 0x0 ;normal(1data)
;Bank 7(if SROM) parameter
B7_Tacs EQU 0x3 ;4clk
B7_Tcos EQU 0x3 ;4clk
B7_Tacc EQU 0x7 ;14clk
B7_Tcoh EQU 0x3 ;4clk
B7_Tah EQU 0x3 ;4clk
B7_Tacp EQU 0x3 ;6clk
B7_PMC EQU 0x0 ;normal(1data)
;Bank 6 parameter
[ BDRAMTYPE="DRAM" ;MT=01(FP DRAM) or 10(EDO DRAM)
B6_MT EQU 0x2 ;EDO DRAM
B6_Trcd EQU 0x0 ;1clk
B6_Tcas EQU 0x0 ;1clk
B6_Tcp EQU 0x0 ;1clk
B6_CAN EQU 0x2 ;10bit
| ;"SDRAM" ;MT=11(SDRAM)
B6_MT EQU 0x3 ;SDRAM
B6_Trcd EQU 0x0 ;2clk
B6_SCAN EQU 0x0 ;8bit
]
;Bank 7 parameter
[ BDRAMTYPE="DRAM" ;MT=01(FP DRAM) or 10(EDO DRAM)
B7_MT EQU 0x2 ;EDO DRAM
B7_Trcd EQU 0x0 ;2clk
B7_Tcas EQU 0x0 ;2clk
B7_Tcp EQU 0x0 ;2clk
B7_CAN EQU 0x2 ;10bit
| ;"SDRAM" ;MT=11(SDRAM)
B7_MT EQU 0x3 ;SDRAM
B7_Trcd EQU 0x0 ;2clk
B7_SCAN EQU 0x0 ;8bit
]
;REFRESH parameter
REFEN EQU 0x1 ;Refresh enable
TREFMD EQU 0x0 ;CBR(CAS before RAS)/Auto refresh
Trp EQU 0x0 ;2clk
Trc EQU 0x0 ;4clk
Tchr EQU 0x2 ;3clk
REFCNT EQU 1425 ;period=15.6us, MCLK=40Mhz
;************************************************
END