TAL_HOME = $(HOME)/kicad/tins_avr_lib TAL_INC = $(TAL_HOME)/inc TAL_SRC = $(TAL_HOME)/src/tal PRG_UTS = upper-tank-sensor OBJ_UTS = $(PRG_UTS).o $(TAL_SRC)/usart_funcs.o $(TAL_SRC)/prng.o PRG_WPC = water-pump-ctrl OBJ_WPC = $(PRG_WPC).o $(TAL_SRC)/usart_funcs.o $(TAL_SRC)/prng.o # $(TAL_SRC)/lcd_hd44780.o PRG_VARS = UTS WPC PRG := $(PRG_$(PRG_VAR)) OBJ := $(OBJ_$(PRG_VAR)) #MCU_TARGET = atmega8 #MCU_TARGET = atmega48 #MCU_TARGET = atmega88 MCU_TARGET = atmega168p OPTIMIZE = -O2 #LCD_PINS = -DLCD_PIN_ENABLE=C,4 -DLCD_PIN_REGSEL=C,5 -DLCD_DATA_PORT=C -DLCD_DATA_LSB=0 -DF_CPU=18432000 #DEFS = -I. -I$(TAL_INC) $(LCD_PINS) DEFS = -I. -I$(TAL_INC) -I$(TAL_SRC) LIBS = # You should not have to change anything below here. CC = avr-gcc AS = avr-gcc # Override is only needed by avr-lib build system. override CFLAGS = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) $(DEFS) override ASFLAGS = -mmcu=$(MCU_TARGET) override LDFLAGS = -Wl,-Map,$(PRG).map OBJCOPY = avr-objcopy OBJDUMP = avr-objdump all: for PRG_VAR in $(PRG_VARS); do make PRG_VAR=$$PRG_VAR prg ; done prg: print_info $(PRG).elf lst text eeprom print_info: @echo;echo;echo;echo;echo @echo "===================================================" @echo "PRG_VAR='$(PRG_VAR)'" @echo "PRG='$(PRG)'" @echo "OBJ='$(OBJ)'" @echo $(PRG).elf: $(OBJ) $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS) .c.s: $< $(CC) $(CFLAGS) -S $< # dependency: demo.o: demo.c iocompat.h clean: rm -rf *.o $(PRG).elf *.eps *.png *.pdf *.bak rm -rf *.lst *.map $(EXTRA_CLEAN_FILES) lst: $(PRG).lst burn-usbasp: $(PRG).srec avrdude -c usbasp -p $(MCU_TARGET) -U flash:w:$(PRG).srec %.lst: %.elf $(OBJDUMP) -h -S $< > $@ $(OBJDUMP) -t -j .bss $< | egrep -v '$<: *file format elf32-avr' >> $@ $(OBJDUMP) -s -j .comment $< | egrep -v '$<: *file format elf32-avr' >> $@ # 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 $< $@ \ || { echo empty $@ not generated; exit 0; } %_eeprom.srec: %.elf @$(OBJCOPY) -j .eeprom --change-section-lma .eeprom=0 -O srec $< $@ \ || { echo empty $@ not generated; exit 0; } %_eeprom.bin: %.elf @$(OBJCOPY) -j .eeprom --change-section-lma .eeprom=0 -O binary $< $@ \ || { echo empty $@ not generated; exit 0; } # Every thing below here is used by avr-libc's build system and can be ignored # by the casual user. FIG2DEV = fig2dev EXTRA_CLEAN_FILES = *.hex *.bin *.srec dox: eps png pdf eps: $(PRG).eps png: $(PRG).png pdf: $(PRG).pdf %.eps: %.fig $(FIG2DEV) -L eps $< $@ %.pdf: %.fig $(FIG2DEV) -L pdf $< $@ %.png: %.fig $(FIG2DEV) -L png $< $@