Makefile дающий .cof в примере WinAVR
На телесистемах помогли -
http://telesys.ru/wwwboards/mcontrol/2300/...es/729474.shtmlВот
http://slil.ru/27013651мэйкфайл дающий .cof в примере WinAVR
C:\WinAVR\doc\avr-libc\examples\stdiodemo
его текст:
Код
PRG = stdiodemo
OBJ = stdiodemo.o hd44780.o lcd.o uart.o
MCU_TARGET = atmega16
OPTIMIZE = -Os
DEFS =
LIBS =
# You should not have to change anything below here.
CC = avr-gcc
CFLAGS = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) $(DEFS)
LDFLAGS = -Wl,-Map,$(PRG).map
OBJCOPY = avr-objcopy
OBJDUMP = avr-objdump
all: $(PRG).elf lst text eeprom coff
$(PRG).elf: $(OBJ)
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
clean:
rm -rf *.o $(PRG).elf *.eps *.png *.pdf *.bak
rm -rf *.lst *.map $(EXTRA_CLEAN_FILES)
lst: $(PRG).lst
%.lst: %.elf
$(OBJDUMP) -h -S $< > $@
# Rules for building the .text rom images
text: hex bin srec
hex: $(PRG).hex
bin: $(PRG).bin
srec: $(PRG).srec
%.hex: %.elf
$(OBJCOPY) -j .text -j .data -O ihex $< $@
%.srec: %.elf
$(OBJCOPY) -j .text -j .data -O srec $< $@
%.bin: %.elf
$(OBJCOPY) -j .text -j .data -O binary $< $@
# Rules for building the .eeprom rom images
eeprom: ehex ebin esrec
ehex: $(PRG)_eeprom.hex
ebin: $(PRG)_eeprom.bin
esrec: $(PRG)_eeprom.srec
%_eeprom.hex: %.elf
$(OBJCOPY) -j .eeprom --change-section-lma .eeprom=0 -O ihex $< $@
%_eeprom.srec: %.elf
$(OBJCOPY) -j .eeprom --change-section-lma .eeprom=0 -O srec $< $@
%_eeprom.bin: %.elf
$(OBJCOPY) -j .eeprom --change-section-lma .eeprom=0 -O binary $< $@
# Every thing below here is used by avr-libc's build system and can be ignored
# by the casual user.
JPEGFILES = stdiodemo-setup.jpg
JPEG2PNM = jpegtopnm
PNM2EPS = pnmtops
JPEGRESOLUTION = 180
EXTRA_CLEAN_FILES = *.hex *.bin *.srec *.eps
dox: ${JPEGFILES:.jpg=.eps}
%.eps: %.jpg
$(JPEG2PNM) $< |\
$(PNM2EPS) -noturn -dpi $(JPEGRESOLUTION) -equalpixels \
> $@
# 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: $(PRG).elf
@echo
@echo $(MSG_COFF) $(PRG).cof
$(COFFCONVERT) -O coff-avr $< $(PRG).cof
extcoff: $(PRG).elf
@echo
@echo $(MSG_EXTENDED_COFF) $(PRG).cof
$(COFFCONVERT) -O coff-ext-avr $< $(PRG).cof