📄 makefile
字号:
# Hey Emacs, this is a -*- makefile -*-# Goals available on make command line:## [all] Default goal: build the project.# clean Clean up the project.# rebuild Rebuild the project.# ccversion Display CC version information.# cppfiles file.i Generate preprocessed files from C source files.# asfiles file.x Generate preprocessed assembler files from C and assembler source files.# objfiles file.o Generate object files from C and assembler source files.# a file.a Archive: create A output file from object files.# elf file.elf Link: create ELF output file from object files.# lss file.lss Create extended listing from target output file.# sym file.sym Create symbol table from target output file.# bin file.bin Create binary image from ELF output file.# sizes Display target size information.# cpuinfo Get CPU information.# halt Stop CPU execution.# program Program MCU memory from ELF output file.# reset Reset CPU.# debug Open a debug connection with the MCU.# run Start CPU execution.# readregs Read CPU registers.# doc Build the documentation.# cleandoc Clean up the documentation.# rebuilddoc Rebuild the documentation.# verbose Display main executed commands.# Copyright (c) 2007, Atmel Corporation All rights reserved.## Redistribution and use in source and binary forms, with or without# modification, are permitted provided that the following conditions are met:## 1. Redistributions of source code must retain the above copyright notice, this# list of conditions and the following disclaimer.## 2. Redistributions in binary form must reproduce the above copyright notice,# this list of conditions and the following disclaimer in the documentation and/# or other materials provided with the distribution.## 3. The name of ATMEL may not be used to endorse or promote products derived# from this software without specific prior written permission.## THIS SOFTWARE IS PROVIDED BY ATMEL ``AS IS'' AND ANY EXPRESS OR IMPLIED# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE EXPRESSLY AND# SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT,# INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY# OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,# EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.# ** ** ** *** ** ** ** ** ** ** ** ** ** ** **# ENVIRONMENT SETTINGS# ** ** ** *** ** ** ** ** ** ** ** ** ** ** **FirstWord = $(if $(1),$(word 1,$(1)))LastWord = $(if $(1),$(word $(words $(1)),$(1)))MAKE = makeMAKECFG = config.mkTGTTYPE = $(suffix $(TARGET))TGTFILE = $(PART)-$(TARGET)RM = rm -RfAR = avr32-arARFLAGS = rcsCPP = $(CC) -ECPPFLAGS = -march=$(ARCH) -mpart=$(PART) $(WARNINGS) $(DEFS) \ $(PLATFORM_INC_PATH:%=-I%) $(INC_PATH:%=-I%) $(CPP_EXTRA_FLAGS)DPNDFILES = $(CSRCS:.c=.d) $(ASSRCS:.S=.d)CPPFILES = $(CSRCS:.c=.i)CC = avr32-gccCFLAGS = $(DEBUG) $(OPTIMIZATION) $(C_EXTRA_FLAGS)ASFILES = $(CSRCS:.c=.x) $(ASSRCS:.S=.x)AS = avr32-asASFLAGS = $(DEBUG) $(AS_EXTRA_FLAGS)OBJFILES = $(CSRCS:.c=.o) $(ASSRCS:.S=.o)LD = avr32-ldLDFLAGS = -march=$(ARCH) -mpart=$(PART) \ $(LIB_PATH:%=-L%) $(LINKER_SCRIPT:%=-T%) $(LD_EXTRA_FLAGS)LOADLIBES =LDLIBS = $(LIBS:%=-l%)OBJDUMP = avr32-objdumpLSS = $(TGTFILE:$(TGTTYPE)=.lss)NM = avr32-nmSYM = $(TGTFILE:$(TGTTYPE)=.sym)OBJCOPY = avr32-objcopyBIN = $(TGTFILE:$(TGTTYPE)=.bin)SIZE = avr32-sizeSUDO = $(shell if [ -x /usr/bin/sudo ]; then echo sudo; fi)SLEEP = sleepSLEEPUSB = 9PROGRAM = avr32programDBGPROXY = avr32gdbproxyDOCGEN = doxygen# ** ** ** *** ** ** ** ** ** ** ** ** ** ** **# MESSAGES# ** ** ** *** ** ** ** ** ** ** ** ** ** ** **ERR_TARGET_TYPE = Target type not supported: `$(TGTTYPE)'MSG_CLEANING = Cleaning project.MSG_PREPROCESSING = Preprocessing \`$<\' to \`$@\'.MSG_COMPILING = Compiling \`$<\' to \`$@\'.MSG_ASSEMBLING = Assembling \`$<\' to \`$@\'.MSG_ARCHIVING = Archiving to \`$@\'.MSG_LINKING = Linking to \`$@\'.MSG_EXTENDED_LISTING = Creating extended listing to \`$@\'.MSG_SYMBOL_TABLE = Creating symbol table to \`$@\'.MSG_BINARY_IMAGE = Creating binary image to \`$@\'.MSG_GETTING_CPU_INFO = Getting CPU information.MSG_HALTING = Stopping CPU execution.MSG_PROGRAMMING = Programming MCU memory from \`$<\'.MSG_RESETTING = Resetting CPU.MSG_DEBUGGING = Opening debug connection with MCU.MSG_RUNNING = Starting CPU execution.MSG_READING_CPU_REGS = Reading CPU registers.MSG_CLEANING_DOC = Cleaning documentation.MSG_GENERATING_DOC = Generating documentation to \`$(DOC_PATH)\'.# ** ** ** *** ** ** ** ** ** ** ** ** ** ** **# MAKE RULES# ** ** ** *** ** ** ** ** ** ** ** ** ** ** **# Include the make configuration file.include $(MAKECFG)# ** ** TOP-LEVEL RULES ** **# Default goal: build the project.ifeq ($(TGTTYPE),.a).PHONY: allall: ccversion a lss symelseifeq ($(TGTTYPE),.elf).PHONY: allall: ccversion elf lss sym bin sizeselse$(error $(ERR_TARGET_TYPE))endifendif# Clean up the project..PHONY: cleanclean: @echo $(MSG_CLEANING) -$(VERBOSE_CMD)$(RM) $(BIN) -$(VERBOSE_CMD)$(RM) $(SYM) -$(VERBOSE_CMD)$(RM) $(LSS) -$(VERBOSE_CMD)$(RM) $(TGTFILE) -$(VERBOSE_CMD)$(RM) $(OBJFILES) -$(VERBOSE_CMD)$(RM) $(ASFILES) -$(VERBOSE_CMD)$(RM) $(CPPFILES) -$(VERBOSE_CMD)$(RM) $(DPNDFILES) $(VERBOSE_NL)# Rebuild the project..PHONY: rebuildrebuild: clean all# Display CC version information..PHONY: ccversionccversion: @echo @echo @$(CC) --version# Generate preprocessed files from C source files..PHONY: cppfilescppfiles: $(CPPFILES)# Generate preprocessed assembler files from C and assembler source files..PHONY: asfilesasfiles: $(ASFILES)# Generate object files from C and assembler source files..PHONY: objfilesobjfiles: $(OBJFILES)ifeq ($(TGTTYPE),.a)# Archive: create A output file from object files..PHONY: aa: $(TGTFILE)elseifeq ($(TGTTYPE),.elf)# Link: create ELF output file from object files..PHONY: elfelf: $(TGTFILE)endifendif# Create extended listing from target output file..PHONY: lsslss: $(LSS)# Create symbol table from target output file..PHONY: symsym: $(SYM)ifeq ($(TGTTYPE),.elf)# Create binary image from ELF output file..PHONY: binbin: $(BIN)endif# Display target size information..PHONY: sizessizes: $(TGTFILE) @echo @echo @$(SIZE) -Ax $<ifeq ($(TGTTYPE),.elf)# Get CPU information..PHONY: cpuinfocpuinfo: @echo @echo $(MSG_GETTING_CPU_INFO) $(VERBOSE_CMD)$(SUDO) $(PROGRAM) -cUSB cpuinfoifneq ($(call LastWord,$(filter cpuinfo program reset debug run readregs,$(MAKECMDGOALS))),cpuinfo) @$(SLEEP) $(SLEEPUSB)else @echoendif# Stop CPU execution..PHONY: halthalt:ifeq ($(filter cpuinfo program reset run readregs,$(MAKECMDGOALS)),) @echo @echo $(MSG_HALTING) $(VERBOSE_CMD)$(SUDO) $(PROGRAM) -cUSB haltifneq ($(call LastWord,$(filter halt debug,$(MAKECMDGOALS))),halt) @$(SLEEP) $(SLEEPUSB)else @echoendifelse @echo > /dev/nullendif# Program MCU memory from ELF output file..PHONY: programprogram: $(TGTFILE) @echo @echo $(MSG_PROGRAMMING) $(VERBOSE_CMD)$(SUDO) $(PROGRAM) -cUSB program $(FLASH:%=-f%) -e -v -R $(if $(findstring run,$(MAKECMDGOALS)),-r) $<ifneq ($(call LastWord,$(filter cpuinfo program debug readregs,$(MAKECMDGOALS))),program) @$(SLEEP) $(SLEEPUSB)else @echoendif# Reset CPU..PHONY: resetreset:ifeq ($(filter program run,$(MAKECMDGOALS)),) @echo @echo $(MSG_RESETTING) $(VERBOSE_CMD)$(SUDO) $(PROGRAM) -cUSB resetifneq ($(call LastWord,$(filter cpuinfo reset debug readregs,$(MAKECMDGOALS))),reset) @$(SLEEP) $(SLEEPUSB)else @echoendifelse @echo > /dev/nullendif# Open a debug connection with the MCU..PHONY: debugdebug: @echo @echo $(MSG_DEBUGGING) $(VERBOSE_CMD)$(SUDO) $(DBGPROXY) -cUSB $(patsubst cfi@%,-f%,$(FLASH:internal@%=-f%))ifneq ($(call LastWord,$(filter cpuinfo halt program reset debug run readregs,$(MAKECMDGOALS))),debug) @$(SLEEP) $(SLEEPUSB)else @echoendif# Start CPU execution..PHONY: runrun:ifeq ($(findstring program,$(MAKECMDGOALS)),) @echo @echo $(MSG_RUNNING) $(VERBOSE_CMD)$(SUDO) $(PROGRAM) -cUSB run $(if $(findstring reset,$(MAKECMDGOALS)),-R)ifneq ($(call LastWord,$(filter cpuinfo debug run readregs,$(MAKECMDGOALS))),run) @$(SLEEP) $(SLEEPUSB)else @echoendifelse @echo > /dev/nullendif# Read CPU registers..PHONY: readregsreadregs: @echo @echo $(MSG_READING_CPU_REGS) $(VERBOSE_CMD)$(SUDO) $(PROGRAM) -cUSB readregsifneq ($(call LastWord,$(filter cpuinfo program reset debug run readregs,$(MAKECMDGOALS))),readregs) @$(SLEEP) $(SLEEPUSB)else @echoendifendif# Build the documentation..PHONY: docdoc: @echo @echo $(MSG_GENERATING_DOC) $(VERBOSE_CMD)cd $(dir $(DOC_CFG)) && $(DOCGEN) $(notdir $(DOC_CFG)) @echo# Clean up the documentation..PHONY: cleandoccleandoc: @echo $(MSG_CLEANING_DOC) -$(VERBOSE_CMD)$(RM) $(DOC_PATH) $(VERBOSE_NL)# Rebuild the documentation..PHONY: rebuilddocrebuilddoc: cleandoc doc# Display main executed commands..PHONY: verboseifeq ($(MAKECMDGOALS),verbose)verbose: allelseverbose: @echo > /dev/nullendififneq ($(findstring verbose,$(MAKECMDGOALS)),)# Prefix displaying the following command if and only if verbose is a goal.VERBOSE_CMD =# New line displayed if and only if verbose is a goal.VERBOSE_NL = @echoelseVERBOSE_CMD = @VERBOSE_NL =endif# ** ** COMPILATION RULES ** **# Include silently the dependency files.-include $(DPNDFILES)# The dependency files are not built alone but along with first generation files.$(DPNDFILES):# First generation files depend on make files.$(CPPFILES) $(ASFILES) $(OBJFILES): Makefile $(MAKECFG)ifeq ($(TGTTYPE),.elf)# Files resulting from linking depend on linker script.$(TGTFILE): $(LINKER_SCRIPT)endif# Preprocess: create preprocessed files from C source files.%.i: %.c %.d @echo $(MSG_PREPROCESSING) $(VERBOSE_CMD)$(CPP) $(CPPFLAGS) -MD -MP -MT '$*.i $*.x $*.o' -o $@ $< @touch $*.d @touch $@ $(VERBOSE_NL)# Preprocess & compile: create assembler files from C source files.%.x: %.c %.d @echo $(MSG_COMPILING) $(VERBOSE_CMD)$(CC) -S $(CPPFLAGS) -MD -MP -MT '$*.i $*.o' $(CFLAGS) -o $@ $< @touch $*.d @touch $@ $(VERBOSE_NL)# Preprocess: create preprocessed files from assembler source files.%.x: %.S %.d @echo $(MSG_PREPROCESSING) $(VERBOSE_CMD)$(CPP) $(CPPFLAGS) -MD -MP -MT '$*.x $*.o' -o $@ $< @touch $*.d @touch $@ $(VERBOSE_NL)# Preprocess, compile & assemble: create object files from C source files.%.o: %.c %.d @echo $(MSG_COMPILING) $(VERBOSE_CMD)$(CC) -c $(CPPFLAGS) -MD -MP -MT '$*.i $*.x' $(CFLAGS) -o $@ $< @touch $*.d @touch $@ $(VERBOSE_NL)# Preprocess & assemble: create object files from assembler source files.%.o: %.S %.d @echo $(MSG_ASSEMBLING) $(VERBOSE_CMD)$(CC) -c $(CPPFLAGS) -MD -MP -MT '$*.x' $(ASFLAGS) -o $@ $< @touch $*.d @touch $@ $(VERBOSE_NL).PRECIOUS: $(OBJFILES)ifeq ($(TGTTYPE),.a)# Archive: create A output file from object files..SECONDARY: $(TGTFILE)$(TGTFILE): $(OBJFILES) @echo $(MSG_ARCHIVING) $(VERBOSE_CMD)$(AR) $(ARFLAGS) $@ $(filter %.o,$+) $(VERBOSE_NL)elseifeq ($(TGTTYPE),.elf)# Link: create ELF output file from object files..SECONDARY: $(TGTFILE)$(TGTFILE): $(OBJFILES) @echo $(MSG_LINKING) $(VERBOSE_CMD)$(CC) $(LDFLAGS) $(filter %.o,$+) $(LOADLIBES) $(LDLIBS) -o $@ $(VERBOSE_NL)endifendif# Create extended listing from target output file.$(LSS): $(TGTFILE) @echo $(MSG_EXTENDED_LISTING) $(VERBOSE_CMD)$(OBJDUMP) -h -S $< > $@ $(VERBOSE_NL)# Create symbol table from target output file.$(SYM): $(TGTFILE) @echo $(MSG_SYMBOL_TABLE) $(VERBOSE_CMD)$(NM) -n $< > $@ $(VERBOSE_NL)ifeq ($(TGTTYPE),.elf)# Create binary image from ELF output file.$(BIN): $(TGTFILE) @echo $(MSG_BINARY_IMAGE) $(VERBOSE_CMD)$(OBJCOPY) -O binary $< $@ $(VERBOSE_NL)endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -