ADS1.2+GNUWinMake编译arm测试工程

首先在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 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


你可能感兴趣的:(linux)