Название: Почему отладчик не показывеат переменные?
Отправлено: juvf от Август 27, 2009, 11:53
Использую AVR Studio 4.17. Пишу код на С++. Например MapModbus::MapModbus() : timer(0,0) { timer.stop(); pItem = 0; unsigned char *addressTable = findTableIOS(); if( addressTable != 0 ) { //бла-бла-бла } }
Потом в отладке останавливаю на строчке с if. Добавляю переменную addressTable в WatchWindow - получаю значение "Not in scope". Почему? Как-то с конструктором может связанно? Замечал такой эффект не только при работе в AVRStudio, но и в других средах и для других платформ (например в KDevelop при написании программ с использованием Qt для PC). Как мне в конструкторе смотреть переменные?
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: lit-uriy от Август 27, 2009, 12:30
>>Как-то с конструктором может связанно? нет не связано, связано с оптимизацией. Во-вторых, при некоторых ситуациях (из-за оптимизации) отладчик может не видеть самой переменной, однако если разжится её адресом, то можно её посмотреть. Во-первых, сложный тип данных (не типа int, structure...) для отладчика может быть не понятен.
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: Igors от Август 27, 2009, 19:18
Замечал такой эффект не только при работе в AVRStudio, но и в других средах и для других платформ (например в KDevelop при написании программ с использованием Qt для PC). В других средах - но тоже замечал. Если оптимизация включена. то вообще что показывать а что нет - выглядит как личное дело отладчика :) Но даже и без оптимизации переменные часто обновляются в окнах отладки только после следующего шага
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: max1983 от Август 27, 2009, 19:28
Короче полная ОПА с дебагерами. Но не переживай! черз лет 10 это все исправят. ::)
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: Rcus от Август 27, 2009, 19:34
Короче полная ОПА с дебагерами. Но не переживай! черз лет 10 это все исправят. ::)
Точно, все забьют на пошаговые отладчики, потому что таким образом невозможно будет отлаживать программу на 512 ядерных машинах :)
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: juvf от Август 28, 2009, 11:11
Естественно оптимизация вся отключенна. Делаю временные кастыли, которые выводят отладку за пределы конструктора. например void f(int *p) { int b; b = *p; b++; }
MyClass::MyClass { //блабла for(int i = 0; i<100: i++) { //бла бла f(&i) } } И вот уже в функции f(int *p) могу наблюдать переменную i. Но в конструкторе - никак >:(
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: lit-uriy от Август 28, 2009, 11:34
да это явно из-за оптимизации, ты случаем не IAR'ом пользуешся, у него даже при выключеной оптимизации она на всю катушку работает (т.е. посути и выключить нельзя).
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: juvf от Август 28, 2009, 12:50
да это явно из-за оптимизации, ты случаем не IAR'ом пользуешся Нет. AVR Studio 4.17 + avr-g++ от WinAVR. Я почему в этот форум вопрос закинул - просто я такие вещи наблюдал и в других средах, в которых отладчиком был gdb. И я подумал - может это табу? Что типа, переменные, у которых область видимости есть конструктор, в конструкторе наблюдать нельзя. Не зависимо от отладчика. Когда включена оптимизация, то код вообще не создается, т.е. если оптимизатор решит, что вот этот цикл for - пустой, то код не сгенерируется и при пошаговой отладке вообше не войдем в цикл for, т.к. его нет. Просто перешагнем весь for за шаг. А при отключенной оптимизации весь код генерится и пошагово можно войти в цикл for, прошогать его и посмотреть на переменную i. У меня же пошагово входит в цикл, шагает по нему, переменную i где-то в регистрах держет (по дизасемблеру вижу), но в окне переменных пишет что переменная "Not in scope". Похоже придется опять на "костылях" ковылять ((
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: kuzulis от Август 28, 2009, 13:15
А дебаг версию создавали? Или просто отключали оптимизацию?
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: juvf от Август 28, 2009, 14:38
А дебаг версию создавали? Или просто отключали оптимизацию? Де черт его знает. Нет ни киких настроек или указаний на дебаг-релиз. Нашел вот на другом форуме А это такая особенность студии - переменные размещенные в регистрах не показывать Если их сделать глобальными, gcc разместит их в раме и студия будет их отображать. Неудобно, но что делать... Теперь уже дальше со студией буду разбираться.
Название: Re: Почему отладчик не показывеат переменные?
Отправлено: lit-uriy от Август 28, 2009, 16:37
>>которых отладчиком был gdb. Ты что не в оригинальном отладчике (AVRStudio) отлаживаешся. Я вообще пишу PN-2, который в составе WinAVR'а идёт. В WinAVR есть шаблон makefile, в нём всё и задаётся. Вот он: Bash # Hey Emacs, this is a -*- makefile -*- #---------------------------------------------------------------------------- # WinAVR Makefile Template written by Eric B. Weddington, Jцrg Wunsch, et al. # # Released to the Public Domain # # Additional material for this makefile was written by: # Peter Fleury # Tim Henigan # Colin O'Flynn # Reiner Patommel # Markus Pfaff # Sander Pool # Frederik Rouleau # Carlos Lamas # and Yuriy Litkevich #---------------------------------------------------------------------------- # On command line: # # make all = Make software. # # make clean = Clean out built project files. # # make coff = Convert ELF to AVR COFF. # # make extcoff = Convert ELF to AVR Extended COFF. # # make program = Download the hex file to the device, using avrdude. # Please customize the avrdude settings below first! # # make debug = Start either simulavr or avarice as specified for debugging, # with avr-gdb or avr-insight as the front end for debugging. # # make filename.s = Just compile filename.c into the assembler code only. # # make filename.i = Create a preprocessed source file for use in submitting # bug reports to the GCC project. # # To rebuild project do "make clean" then "make all". #---------------------------------------------------------------------------- # MCU name MCU = atmega16 # Processor frequency. # This will define a symbol, F_CPU, in all source code files equal to the # processor frequency. You can then use this symbol in your source code to # calculate timings. Do NOT tack on a 'UL' at the end, this will be done # automatically to create a 32-bit value in your source code. # Typical values are: # F_CPU = 1000000 # F_CPU = 1843200 # F_CPU = 2000000 # F_CPU = 3686400 # F_CPU = 4000000 # F_CPU = 7372800 # F_CPU = 8000000 # F_CPU = 11059200 # F_CPU = 14745600 # F_CPU = 16000000 # F_CPU = 18432000 # F_CPU = 20000000 F_CPU = 6000000 # Output format. (can be srec, ihex, binary) FORMAT = ihex # Target file name (without extension). TARGET = myfirmware # Object files directory OBJDIR = obj # List C source files here. (C dependencies are automatically generated.) SRC_1 = systimer20.c keyled.c adc10.c uart.c pwm.c pwr.c sensor.c ppk.c tmr2.c tm.c crc.c myE2P.c SRC = $(SRC_1) SRC += $(TARGET).c # List C++ source files here. (C dependencies are automatically generated.) CPPSRC = # List Assembler source files here. # Make them always end in a capital .S. Files ending in a lowercase .s # will not be considered source files but generated files (assembler # output from the compiler), and will be deleted upon "make clean"! # Even though the DOS/Win* filesystem matches both .s and .S the same, # it will preserve the spelling of the filenames, and gcc itself does # care about how the name is spelled on its command-line. ASRC = # Optimization level, can be [0, 1, 2, 3, s]. # 0 = turn off optimization. s = optimize for size. # (Note: 3 is not always the best optimization level. See avr-libc FAQ.) OPT = s # #OPT += -fsched2-use-superblocks #OPT += -fsched2-use-traces #OPT += -fsignaling-nans #OPT += -fsingle-precision-constant #OPT += -fstrength-reduce #OPT += -fstrict-aliasing #OPT += -ftracer #OPT += -fthread-jumps #OPT += -funroll-all-loops #OPT += -funroll-loops #OPT += -fpeel-loops #OPT += -funswitch-loops #OPT += -fold-unroll-loops #OPT += -fold-unroll-all-loops #OPT += --param name=value # Debugging format. # Native formats for AVR-GCC's -g are dwarf-2 [default] or stabs. # AVR Studio 4.10 requires dwarf-2. # AVR [Extended] COFF format requires stabs, plus an avr-objcopy run. #DEBUG = dwarf-2 # List any extra directories to look for include files here. # Each directory must be seperated by a space. # Use forward slashes for directory separators. # For a directory that has spaces, enclose it in quotes. EXTRAINCDIRS = # Compiler flag to set the C Standard level. # c89 = "ANSI" C # gnu89 = c89 plus GCC extensions # c99 = ISO C99 standard (not yet fully implemented) # gnu99 = c99 plus GCC extensions CSTANDARD = -std=gnu99 #CSTANDARD = -std=c99 #CSTANDARD = -std=gnu89 # Place -D or -U options here for C sources CDEFS = -DF_CPU=$(F_CPU)UL # Place -D or -U options here for C++ sources CPPDEFS = -DF_CPU=$(F_CPU)UL #CPPDEFS += -D__STDC_LIMIT_MACROS #CPPDEFS += -D__STDC_CONSTANT_MACROS #---------------- Compiler Options C ---------------- # -g*: generate debugging information # -O*: optimization level # -f...: tuning, see GCC manual and avr-libc documentation # -Wall...: warning level # -Wa,...: tell GCC to pass this to the assembler. # -adhlns...: create assembler listing CFLAGS = -g$(DEBUG) CFLAGS += $(CDEFS) CFLAGS += -O$(OPT) #CFLAGS += -mint8 #CFLAGS += -mshort-calls CFLAGS += -funsigned-char CFLAGS += -funsigned-bitfields #CFLAGS += -fpack-struct CFLAGS += -fshort-enums #CFLAGS += -fno-unit-at-a-time #CFLAGS += -pedantic CFLAGS += -Wall CFLAGS += -Wstrict-prototypes CFLAGS += -Wundef CFLAGS += -Wunreachable-code CFLAGS += -Wswitch #CFLAGS += -Wsign-compare CFLAGS += -Wa,-adhlns=$(<:%.c=$(OBJDIR)/%.lst) CFLAGS += $(patsubst %,-I%,$(EXTRAINCDIRS)) CFLAGS += $(CSTANDARD) #---------------- Compiler Options C++ ---------------- # -g*: generate debugging information # -O*: optimization level # -f...: tuning, see GCC manual and avr-libc documentation # -Wall...: warning level # -Wa,...: tell GCC to pass this to the assembler. # -adhlns...: create assembler listing CPPFLAGS = -g$(DEBUG) CPPFLAGS += $(CPPDEFS) CPPFLAGS += -O$(OPT) #CPPFLAGS += -mint8 #CPPFLAGS += -mshort-calls CPPFLAGS += -funsigned-char CPPFLAGS += -funsigned-bitfields CPPFLAGS += -fpack-struct CPPFLAGS += -fshort-enums CPPFLAGS += -fno-exceptions #CPPFLAGS += -fno-unit-at-a-time CPPFLAGS += -Wall #CPPFLAGS += -Wstrict-prototypes CFLAGS += -Wundef #CPPFLAGS += -Wunreachable-code #CPPFLAGS += -Wsign-compare CPPFLAGS += -Wa,-adhlns=$(<:%.cpp=$(OBJDIR)/%.lst) CPPFLAGS += $(patsubst %,-I%,$(EXTRAINCDIRS)) #CPPFLAGS += $(CSTANDARD) #---------------- Assembler Options ---------------- # -Wa,...: tell GCC to pass this to the assembler. # -ahlms: create listing # -gstabs: have the assembler create line number information; note that # for use in COFF files, additional information about filenames # and function names needs to be present in the assembler source # files -- see avr-libc docs [FIXME: not yet described there] ASFLAGS = -Wa,-adhlns=$(<:%.S=$(OBJDIR)/%.lst),-gstabs #---------------- Library Options ---------------- # Minimalistic printf version PRINTF_LIB_MIN = -Wl,-u,vfprintf -lprintf_min # Floating point printf version (requires MATH_LIB = -lm below) PRINTF_LIB_FLOAT = -Wl,-u,vfprintf -lprintf_flt # If this is left blank, then it will use the Standard printf version. PRINTF_LIB = #PRINTF_LIB = $(PRINTF_LIB_MIN) #PRINTF_LIB = $(PRINTF_LIB_FLOAT) # Minimalistic scanf version SCANF_LIB_MIN = -Wl,-u,vfscanf -lscanf_min # Floating point + %[ scanf version (requires MATH_LIB = -lm below) SCANF_LIB_FLOAT = -Wl,-u,vfscanf -lscanf_flt # If this is left blank, then it will use the Standard scanf version. SCANF_LIB = #SCANF_LIB = $(SCANF_LIB_MIN) #SCANF_LIB = $(SCANF_LIB_FLOAT) MATH_LIB = -lm #---------------- External Memory Options ---------------- # 64 KB of external RAM, starting after internal RAM (ATmega128!), # used for variables (.data/.bss) and heap (malloc()). #EXTMEMOPTS = -Wl,-Tdata=0x801100,--defsym=__heap_end=0x80ffff # 64 KB of external RAM, starting after internal RAM (ATmega128!), # only used for heap (malloc()). #EXTMEMOPTS = -Wl,--defsym=__heap_start=0x801100,--defsym=__heap_end=0x80ffff EXTMEMOPTS = #---------------- Linker Options ---------------- # -Wl,...: tell GCC to pass this to linker. # -Map: create map file # --cref: add cross reference to map file LDFLAGS = -Wl,-Map=$(TARGET).map,--cref LDFLAGS += $(EXTMEMOPTS) LDFLAGS += $(PRINTF_LIB) $(SCANF_LIB) $(MATH_LIB) #LDFLAGS += -T linker_script.x #---------------- Programming Options (avrdude) ---------------- # Programming hardware: alf avr910 avrisp bascom bsd # dt006 pavr picoweb pony-stk200 sp12 stk200 stk500 # # Type: avrdude -c ? # to get a full listing. # #AVRDUDE_PROGRAMMER = stk500 AVRDUDE_PROGRAMMER = avrispv2 # com1 = serial port. Use lpt1 to connect to parallel port. AVRDUDE_PORT = com1 # programmer connected to serial device AVRDUDE_WRITE_FLASH = -U flash:w:$(TARGET).hex #AVRDUDE_WRITE_EEPROM = -U eeprom:w:$(TARGET).eep # Uncomment the following if you want avrdude's erase cycle counter. # Note that this counter needs to be initialized first using -Yn, # see avrdude manual. #AVRDUDE_ERASE_COUNTER = -y # Uncomment the following if you do /not/ wish a verification to be # performed after programming the device. #AVRDUDE_NO_VERIFY = -V # Increase verbosity level. Please use this when submitting bug # reports about avrdude. See <http://savannah.nongnu.org/projects/avrdude> # to submit bug reports. #AVRDUDE_VERBOSE = -v -v AVRDUDE_FLAGS = -p $(MCU) -P $(AVRDUDE_PORT) -c $(AVRDUDE_PROGRAMMER) AVRDUDE_FLAGS += $(AVRDUDE_NO_VERIFY) AVRDUDE_FLAGS += $(AVRDUDE_VERBOSE) AVRDUDE_FLAGS += $(AVRDUDE_ERASE_COUNTER) #---------------- Debugging Options ---------------- # For simulavr only - target MCU frequency. DEBUG_MFREQ = $(F_CPU) # Set the DEBUG_UI to either gdb or insight. # DEBUG_UI = gdb DEBUG_UI = insight # Set the debugging back-end to either avarice, simulavr. #DEBUG_BACKEND = avarice DEBUG_BACKEND = simulavr # GDB Init Filename. GDBINIT_FILE = __avr_gdbinit # When using avarice settings for the JTAG JTAG_DEV = /dev/com1 # Debugging port used to communicate between GDB / avarice / simulavr. DEBUG_PORT = 4242 # Debugging host used to communicate between GDB / avarice / simulavr, normally # just set to localhost unless doing some sort of crazy debugging when # avarice is running on a different computer. DEBUG_HOST = localhost #============================================================================ # Define programs and commands. SHELL = sh CC = avr-gcc OBJCOPY = avr-objcopy OBJDUMP = avr-objdump SIZE = avr-size NM = avr-nm AVRDUDE = avrdude REMOVE = rm -f REMOVEDIR = rm -rf COPY = cp WINSHELL = cmd # Define Messages # Russian MSG_ERRORS_NONE = --- Errors: нет --- MSG_BEGIN = ---------------------- Начало ------------------------------ MSG_BEGIN_COMPILE = -------------------- Компиляция -------------------------- MSG_END = ----------------------- Конец. ----------------------------- MSG_SIZE_BEFORE = --- Размер до ---: MSG_SIZE_AFTER = --- Размер после ---: MSG_COFF = Converting to AVR COFF: MSG_EXTENDED_COFF = Converting to AVR Extended COFF: MSG_FLASH = --- Создание прошивки "Flash" ---: MSG_EEPROM = --- Создание прошивки "EEPROM" ---: MSG_EXTENDED_LISTING = --- Создание расшириного листинга ---: MSG_SYMBOL_TABLE = --- Создание таблицы символов ---: MSG_LINKING = --- Линковка ---: MSG_COMPILING = --- Компиляция "C" ---: MSG_COMPILING_CPP = --- Компиляция "C++" ---: MSG_ASSEMBLING = --- Assembling ---: MSG_CLEANING = --- Cleaning project ---: MSG_CREATING_LIBRARY = Creating library: MSG_SIZE_STRING = --- Подсчет строк --- # Define all object files. OBJ = $(SRC:%.c=$(OBJDIR)/%.o) $(CPPSRC:%.cpp=$(OBJDIR)/%.o) $(ASRC:%.S=$(OBJDIR)/%.o) # Define all listing files. LST = $(SRC:%.c=$(OBJDIR)/%.lst) $(CPPSRC:%.cpp=$(OBJDIR)/%.lst) $(ASRC:%.S=$(OBJDIR)/%.lst) # Compiler flags to generate dependency files. GENDEPFLAGS = -MD -MP -MF .dep/$(@F).d # Combine all necessary flags and optional flags. # Add target processor to flags. ALL_CFLAGS = -mmcu=$(MCU) -I. $(CFLAGS) $(GENDEPFLAGS) ALL_CPPFLAGS = -mmcu=$(MCU) -I. -x c++ $(CPPFLAGS) $(GENDEPFLAGS) ALL_ASFLAGS = -mmcu=$(MCU) -I. -x assembler-with-cpp $(ASFLAGS) # Default target. all: begin sizebefore gccversion sizestring begincompile build sizeafter end # Change the build target to build a HEX file or a library. build: elf hex eep lss sym #build: lib elf: $(TARGET).elf hex: $(TARGET).hex eep: $(TARGET).eep lss: $(TARGET).lss sym: $(TARGET).sym LIBNAME=lib$(TARGET).a lib: $(LIBNAME) # Eye candy. # AVR Studio 3.x does not check make's exit code but relies on # the following magic strings to be generated by the compile job. begin: @echo @echo $(MSG_BEGIN) begincompile: @echo @echo $(MSG_BEGIN_COMPILE) end: @echo $(MSG_END) @echo # Display size of file. HEXSIZE = $(SIZE) --target=$(FORMAT) $(TARGET).hex ELFSIZE = $(SIZE) -B $(TARGET).elf OBJSIZE = $(SIZE) -B $(OBJ) AVRMEM = avr-mem.sh $(TARGET).elf $(MCU) FILES_TO_SIZE = $(SRC_1) FILES_TO_SIZE += $(SRC_1:%.c=%.h) FILES_TO_SIZE += $(TARGET).c STRSIZE = wc -l $(FILES_TO_SIZE) sizebefore: @if test -f $(TARGET).elf; then echo; echo $(MSG_SIZE_BEFORE); \ $(ELFSIZE); $(AVRMEM) 2>/dev/null; echo; fi sizeafter: @if test -f $(TARGET).elf; then echo; echo $(MSG_SIZE_AFTER); \ $(ELFSIZE); $(AVRMEM) 2>/dev/null; echo; fi sizestring: @echo $(MSG_SIZE_STRING); $(STRSIZE) 2>/dev/null; # Display compiler version information. gccversion : @$(CC) --version # Program the device. program: $(TARGET).hex $(TARGET).eep $(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH) $(AVRDUDE_WRITE_EEPROM) # Generate avr-gdb config/init file which does the following: # define the reset signal, load the target file, connect to target, and set # a breakpoint at main(). gdb-config: @$(REMOVE) $(GDBINIT_FILE) @echo define reset >> $(GDBINIT_FILE) @echo SIGNAL SIGHUP >> $(GDBINIT_FILE) @echo end >> $(GDBINIT_FILE) @echo file $(TARGET).elf >> $(GDBINIT_FILE) @echo target remote $(DEBUG_HOST):$(DEBUG_PORT) >> $(GDBINIT_FILE) ifeq ($(DEBUG_BACKEND),simulavr) @echo load >> $(GDBINIT_FILE) endif @echo break main >> $(GDBINIT_FILE) debug: gdb-config $(TARGET).elf ifeq ($(DEBUG_BACKEND), avarice) @echo Starting AVaRICE - Press enter when "waiting to connect" message displays. @$(WINSHELL) /c start avarice --jtag $(JTAG_DEV) --erase --program --file \ $(TARGET).elf $(DEBUG_HOST):$(DEBUG_PORT) @$(WINSHELL) /c pause else @echo Starting SimulAVR. @$(WINSHELL) /c start simulavr --gdbserver --device $(MCU) --clock-freq \ $(DEBUG_MFREQ) --port $(DEBUG_PORT) endif @$(WINSHELL) /c start avr-$(DEBUG_UI) --command=$(GDBINIT_FILE) # Convert ELF to COFF for use in debugging / simulating in AVR Studio or VMLAB. COFFCONVERT = $(OBJCOPY) --debugging COFFCONVERT += --change-section-address .data-0x800000 COFFCONVERT += --change-section-address .bss-0x800000 COFFCONVERT += --change-section-address .noinit-0x800000 COFFCONVERT += --change-section-address .eeprom-0x810000 coff: $(TARGET).elf @echo @echo $(MSG_COFF) $(TARGET).cof $(COFFCONVERT) -O coff-avr $< $(TARGET).cof extcoff: $(TARGET).elf @echo @echo $(MSG_EXTENDED_COFF) $(TARGET).cof $(COFFCONVERT) -O coff-ext-avr $< $(TARGET).cof # Create final output files (.hex, .eep) from ELF output file. %.hex: %.elf @echo @echo $(MSG_FLASH) $@ $(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@ %.eep: %.elf @echo @echo $(MSG_EEPROM) $@ -$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" --change-section-lma .eeprom=0 -O $(FORMAT) $< $@ # Create extended listing file from ELF output file. %.lss: %.elf @echo @echo $(MSG_EXTENDED_LISTING) $@ $(OBJDUMP) -x -g -S $< > $@ # Create a symbol table from ELF output file. %.sym: %.elf @echo @echo $(MSG_SYMBOL_TABLE) $@ $(NM) -n $< > $@ # Create library from object files. .SECONDARY : $(TARGET).a .PRECIOUS : $(OBJ) %.a: $(OBJ) @echo @echo $(MSG_CREATING_LIBRARY) $@ $(AR) $@ $(OBJ) # Link: create ELF output file from object files. .SECONDARY : $(TARGET).elf .PRECIOUS : $(OBJ) %.elf: $(OBJ) @echo @echo $(MSG_LINKING) $@ $(CC) $(ALL_CFLAGS) $^ --output $@ $(LDFLAGS) # Compile: create object files from C source files. $(OBJDIR)/%.o : %.c @echo @echo $(MSG_COMPILING) $< $(CC) -c $(ALL_CFLAGS) $< -o $@ # Compile: create object files from C++ source files. $(OBJDIR)/%.o : %.cpp @echo @echo $(MSG_COMPILING_CPP) $< $(CC) -c $(ALL_CPPFLAGS) $< -o $@ # Compile: create assembler files from C source files. %.s : %.c $(CC) -S $(ALL_CFLAGS) $< -o $@ # Compile: create assembler files from C++ source files. %.s : %.cpp $(CC) -S $(ALL_CPPFLAGS) $< -o $@ # Assemble: create object files from assembler source files. $(OBJDIR)/%.o : %.S @echo @echo $(MSG_ASSEMBLING) $< $(CC) -c $(ALL_ASFLAGS) $< -o $@ # Create preprocessed source for use in sending a bug report. %.i : %.c $(CC) -E -mmcu=$(MCU) -I. $(CFLAGS) $< -o $@ # Target: clean project. clean: begin clean_list end clean_list : @echo @echo $(MSG_CLEANING) $(REMOVE) $(TARGET).hex $(REMOVE) *.aps $(REMOVE) $(TARGET).eep $(REMOVE) $(TARGET).cof $(REMOVE) $(TARGET).elf $(REMOVE) $(TARGET).map $(REMOVE) $(TARGET).sym $(REMOVE) $(TARGET).lss $(REMOVEDIR) $(OBJDIR) $(REMOVE) $(SRC:.c=.s) $(REMOVE) $(SRC:.c=.i) $(REMOVE) $(SRC:.c=.d) $(REMOVEDIR) .dep # Create object files directory $(shell mkdir $(OBJDIR) 2>/dev/null) # Include the dependency files. -include $(shell mkdir .dep 2>/dev/null) $(wildcard .dep/*) # Listing of phony targets. .PHONY : all begin finish end sizebefore sizeafter gccversion \ build elf hex eep lss sym coff extcoff \ clean clean_list program debug gdb-config
|