?? 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.# hex file.hex Create Intel HEX image from ELF output file.# bin file.bin Create binary image from ELF output file.# sizes Display target size information.# isp Use ISP instead of JTAGICE mkII when programming.# cpuinfo Get CPU information.# halt Stop CPU execution.# chiperase Perform a JTAG Chip Erase command.# erase Perform a flash chip erase.# program Program MCU memory from ELF output file.# secureflash Protect chip by setting security bit.# reset Reset MCU.# 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) \ $(PLATFORM_INC_PATH:%=-Wa,-I%) $(INC_PATH:%=-Wa,-I%) $(AS_EXTRA_FLAGS)ASFILES = $(CSRCS:.c=.x) $(ASSRCS:.S=.x)AS = avr32-asASFLAGS = $(DEBUG) \ $(PLATFORM_INC_PATH:%=-Wa,-I%) $(INC_PATH:%=-Wa,-I%) $(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-objcopyHEX = $(TGTFILE:$(TGTTYPE)=.hex)BIN = $(TGTFILE:$(TGTTYPE)=.bin)SIZE = avr32-sizeSLEEP = sleepSLEEPUSB = 9PROGRAM = avr32programISP = batchispISPFLAGS = -device at32$(PART) -hardware usb -operationDBGPROXY = 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_IHEX_IMAGE = Creating Intel HEX image to \`$@\'.MSG_BINARY_IMAGE = Creating binary image to \`$@\'.MSG_GETTING_CPU_INFO = Getting CPU information.MSG_HALTING = Stopping CPU execution.MSG_ERASING_CHIP = Performing a JTAG Chip Erase command.MSG_ERASING = Performing a flash chip erase.MSG_PROGRAMMING = Programming MCU memory from \`$(TGTFILE)\'.MSG_SECURING_FLASH = Protecting chip by setting security bit.MSG_RESETTING = Resetting MCU.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 sym sizeselseifeq ($(TGTTYPE),.elf).PHONY: allall: ccversion elf lss sym hex bin sizeselse$(error $(ERR_TARGET_TYPE))endifendif# Clean up the project..PHONY: cleanclean: @echo $(MSG_CLEANING) -$(VERBOSE_CMD)$(RM) $(BIN) -$(VERBOSE_CMD)$(RM) $(HEX) -$(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 Intel HEX image from ELF output file..PHONY: hexhex: $(HEX)# Create binary image from ELF output file..PHONY: binbin: $(BIN)endif# Display target size information..PHONY: sizessizes: $(TGTFILE) @echo @echoifeq ($(TGTTYPE),.a) @$(SIZE) -Bxt $<elseifeq ($(TGTTYPE),.elf) @$(SIZE) -Ax $< @$(SIZE) -Bx $<endifendif @echo @echoifeq ($(TGTTYPE),.elf)# Use ISP instead of JTAGICE mkII when programming..PHONY: ispifeq ($(filter-out isp verbose,$(MAKECMDGOALS)),)isp: allelseisp: @:endififeq ($(findstring isp,$(MAKECMDGOALS)),)# Get CPU information..PHONY: cpuinfocpuinfo: @echo @echo $(MSG_GETTING_CPU_INFO) $(VERBOSE_CMD)$(PROGRAM) cpuinfoifneq ($(call LastWord,$(filter cpuinfo chiperase erase program secureflash reset debug run readregs,$(MAKECMDGOALS))),cpuinfo) @$(SLEEP) $(SLEEPUSB)else @echoendif# Stop CPU execution..PHONY: halthalt:ifeq ($(filter cpuinfo chiperase erase program secureflash reset run readregs,$(MAKECMDGOALS)),) @echo @echo $(MSG_HALTING) $(VERBOSE_CMD)$(PROGRAM) haltifneq ($(call LastWord,$(filter halt debug,$(MAKECMDGOALS))),halt) @$(SLEEP) $(SLEEPUSB)else @echoendifelse @:endif# Perform a JTAG Chip Erase command..PHONY: chiperasechiperase: @echo @echo $(MSG_ERASING_CHIP) $(VERBOSE_CMD)$(PROGRAM) chiperaseifneq ($(call LastWord,$(filter cpuinfo chiperase program secureflash reset debug run readregs,$(MAKECMDGOALS))),chiperase)
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -