add missing avr458 Makefile
authorKevin Rosenberg <kevin@rosenberg.net>
Sat, 29 Mar 2008 00:41:07 +0000 (18:41 -0600)
committerKevin Rosenberg <kevin@rosenberg.net>
Sat, 29 Mar 2008 00:41:07 +0000 (18:41 -0600)
BaseTinyFirmware/GCC/ChangeLog
BaseTinyFirmware/GCC/avr458/Makefile [new file with mode: 0644]
BaseTinyFirmware/GCC/avr463/Makefile

index 07131e92ca0cd2929212cc6bec9f4a7edc667f98..87d741b31a28ae41dc36fb8166c54102bc9f9385 100644 (file)
@@ -1,8 +1,9 @@
-2008-03-12 Kevin Rosenberg <kevin@rosenberg.net>\r
+2008-03-28 Kevin Rosenberg <kevin@rosenberg.net>\r
        * BaseTinyFirmware/GCC/avr463/Makefile: Added -Wl,-relax to linker\r
        flags. On my system this crashes avr-ld.exe, but others have reported\r
        a large reduction in firmware size with this option. I added this\r
        option for others to try.\r
+       * BaseTinyFirmware/GCC/avr458/Makefile: Added missing file\r
        \r
 2008-03-14 Martin Thomas <mthomas@rhrk.uni-kl.de>\r
        * added "volatile" to structure object and array declarations for\r
diff --git a/BaseTinyFirmware/GCC/avr458/Makefile b/BaseTinyFirmware/GCC/avr458/Makefile
new file mode 100644 (file)
index 0000000..d74f9d4
--- /dev/null
@@ -0,0 +1,107 @@
+ ###############################################################################\r
+# Makefile for the project avr458\r
+###############################################################################\r
+\r
+## General Flags\r
+PROJECT = avr458\r
+MCU = attiny861\r
+TARGET = $(PROJECT).elf\r
+CC = avr-gcc.exe\r
+\r
+## Options common to compile, link and assembly rules\r
+COMMON = -mmcu=$(MCU)\r
+\r
+## Compile options common for all C compilation units.\r
+CFLAGS = $(COMMON)\r
+CFLAGS += -Wall -gdwarf-2 -std=gnu99 -Os -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums -DLIION\r
+CFLAGS += -MD -MP -MT $(*F).o -MF dep/$(@F).d \r
+\r
+## Assembly specific flags\r
+ASMFLAGS = $(COMMON)\r
+ASMFLAGS += $(CFLAGS)\r
+ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2\r
+\r
+## Linker flags\r
+LDFLAGS = $(COMMON)\r
+LDFLAGS +=  -Wl,-Map=$(PROJECT).map -Wl,-relax\r
+\r
+\r
+## Intel Hex file production flags\r
+HEX_FLASH_FLAGS = -R .eeprom\r
+\r
+HEX_EEPROM_FLAGS = -j .eeprom\r
+HEX_EEPROM_FLAGS += --set-section-flags=.eeprom="alloc,load"\r
+HEX_EEPROM_FLAGS += --change-section-lma .eeprom=0 --no-change-warnings\r
+\r
+\r
+## Libraries\r
+LIBS = -lm \r
+\r
+## Objects that must be built in order to link\r
+OBJECTS = ADC.o battery.o chargefunc.o main.o menu.o LIIONcharge.o OWI.o PWM.o statefunc.o time.o USI.o \r
+\r
+## Objects explicitly added by the user\r
+LINKONLYOBJECTS = \r
+\r
+## Build\r
+all: $(TARGET) $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss size\r
+\r
+## Compile\r
+ADC.o: ../ADC.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+battery.o: ../battery.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+chargefunc.o: ../chargefunc.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+main.o: ../main.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+menu.o: ../menu.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+LIIONcharge.o: ../LIIONcharge.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+OWI.o: ../OWI.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+PWM.o: ../PWM.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+statefunc.o: ../statefunc.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+time.o: ../time.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+USI.o: ../USI.c\r
+       $(CC) $(INCLUDES) $(CFLAGS) -c  $<\r
+\r
+##Link\r
+$(TARGET): $(OBJECTS)\r
+        $(CC) $(LDFLAGS) $(OBJECTS) $(LINKONLYOBJECTS) $(LIBDIRS) $(LIBS) -o $(TARGET)\r
+\r
+%.hex: $(TARGET)\r
+       avr-objcopy -O ihex $(HEX_FLASH_FLAGS)  $< $@\r
+\r
+%.eep: $(TARGET)\r
+       -avr-objcopy $(HEX_EEPROM_FLAGS) -O ihex $< $@ || exit 0\r
+\r
+%.lss: $(TARGET)\r
+       avr-objdump -h -S $< > $@\r
+\r
+size: ${TARGET}\r
+       @echo\r
+       @avr-size -C --mcu=${MCU} ${TARGET}\r
+\r
+## Clean target\r
+.PHONY: clean\r
+clean:\r
+       -rm -rf $(OBJECTS) $(PROJECT).elf dep $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss $(PROJECT).map\r
+\r
+\r
+## Other dependencies\r
+-include $(shell mkdir dep 2>/dev/null) $(wildcard dep/*)\r
index 44c49e4ee106af91dd3409db9bed26c9a69cf767..826b34552aaca3dd8b62852a644d1af88bd738b9 100644 (file)
@@ -1,11 +1,11 @@
-###############################################################################\r
+ ###############################################################################\r
 # Makefile for the project avr463\r
 ###############################################################################\r
 \r
 ## General Flags\r
 PROJECT = avr463\r
 MCU = attiny861\r
-TARGET = avr463.elf\r
+TARGET = $(PROJECT).elf\r
 CC = avr-gcc.exe\r
 \r
 ## Options common to compile, link and assembly rules\r
@@ -23,7 +23,7 @@ ASMFLAGS += -x assembler-with-cpp -Wa,-gdwarf2
 \r
 ## Linker flags\r
 LDFLAGS = $(COMMON)\r
-LDFLAGS +=  -Wl,-Map=avr463.map -Wl,-relax\r
+LDFLAGS +=  -Wl,-Map=$(PROJECT).map -Wl,-relax\r
 \r
 \r
 ## Intel Hex file production flags\r
@@ -44,7 +44,7 @@ OBJECTS = ADC.o battery.o chargefunc.o main.o menu.o NIMHcharge.o OWI.o PWM.o st
 LINKONLYOBJECTS = \r
 \r
 ## Build\r
-all: $(TARGET) avr463.hex avr463.eep avr463.lss size\r
+all: $(TARGET) $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss size\r
 \r
 ## Compile\r
 ADC.o: ../ADC.c\r
@@ -100,9 +100,8 @@ size: ${TARGET}
 ## Clean target\r
 .PHONY: clean\r
 clean:\r
-       -rm -rf $(OBJECTS) avr463.elf dep avr463.hex avr463.eep avr463.lss avr463.map\r
+       -rm -rf $(OBJECTS) $(PROJECT).elf dep $(PROJECT).hex $(PROJECT).eep $(PROJECT).lss $(PROJECT).map\r
 \r
 \r
 ## Other dependencies\r
 -include $(shell mkdir dep 2>/dev/null) $(wildcard dep/*)\r
-\r