summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorschodet2004-10-02 16:05:11 +0000
committerschodet2004-10-02 16:05:11 +0000
commitbf5858214ec64d4d02be9d1a9733e20307fbfd6a (patch)
tree7b3087a8db9941cdfd02b45ce1e407fc7e9076f2
parent1f14105a0465099079c06955c43e58c664b13c13 (diff)
Nouveau système de Makefile, gère les dépendences et les cibles multiples.
-rw-r--r--n/avr/howto/Makefile6
-rw-r--r--n/avr/howto/Makefile.avr54
-rw-r--r--n/avr/howto/howto-avr.txt6
3 files changed, 41 insertions, 25 deletions
diff --git a/n/avr/howto/Makefile b/n/avr/howto/Makefile
index 25dfd1a..1f09fb3 100644
--- a/n/avr/howto/Makefile
+++ b/n/avr/howto/Makefile
@@ -1,5 +1,5 @@
PROGS = example
-SOURCES = example.c
+example_OBJECTS = example.o
DOC = howto-avr.html
EXTRACTDOC =
MODULES =
@@ -11,6 +11,8 @@ MCU_TARGET = atmega8
OPTIMIZE = -O2
DEFS =
-LIBS =
+LDLIBS =
include Makefile.avr
+
+example.elf: $(example_OBJECTS)
diff --git a/n/avr/howto/Makefile.avr b/n/avr/howto/Makefile.avr
index 01c9b7b..325be3f 100644
--- a/n/avr/howto/Makefile.avr
+++ b/n/avr/howto/Makefile.avr
@@ -1,52 +1,66 @@
# Flags. {{{1
-CC = avr-gcc
-
-CFLAGS = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) \
- $(if $(CONFIGFILE), $(CONFIGFILE:%=-include %))
-CPPFLAGS = $(DEFS) -Imodules
+CFLAGS = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET)
+CPPFLAGS = $(DEFS) -MMD $(INCLUDES) \
+ $(if $(CONFIGFILE), $(CONFIGFILE:%=-include %))
+INCLUDES = -Imodules
LDFLAGS =
+CC = avr-gcc
OBJCOPY = avr-objcopy
OBJDUMP = avr-objdump
# Main rules. {{{1
-CSOURCES = $(filter %.c, $(SOURCES))
-SSOURCES = $(filter %.s, $(SOURCES))
-OBJECTS = $(CSOURCES:%.c=%.o) $(SSOURCES:%.s=%.o)
-ELFS = $(PROGS:%=%.elf)
-
all: elf lst hex
.PHONY: all clean elf lst doc text hex srec bin eeprom ehex esrec ebin
# Rules for modules. {{{1
-MODULESFILES = $(MODULES:%=modules/%/Makefile.module)
+VPATH = $(MODULES:%=modules/%)
-include $(MODULESFILES)
+modules_checkout: modules_co
-SOURCES += $(MODULESSOURCES)
+modules_co: $(MODULES:%=modules_co.%)
-$(MODULESFILES):
+$(MODULES:%=modules_co.%):
mkdir -p modules
- cd modules && cvs co $(@:modules/%/Makefile.module=%)
- test -f $@
+ cd modules && cvs co $(@:modules_co.%=%)
+
+modules_update: modules_up
+
+modules_up: $(MODULES:%=modules_up.%)
+
+$(MODULES:%=modules_up.%):
+ cd modules/$(@:modules_up.%=%) && cvs up
# General rules. {{{1
-elf: $(PROGS:%=%.elf)
+ELFS = $(PROGS:%=%.elf)
+OBJECTS = $(filter %.o,$(foreach prog,$(PROGS),$($(prog)_OBJECTS)))
+
+elf: $(ELFS)
lst: $(PROGS:%=%.lst)
-$(PROGS:%=%.elf): $(OBJECTS)
- $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
+# Great piece of rules which only works in make 3.80+.
+# define PROG_template
+# $(1).elf: $$($(1)_OBJECTS)
+# endef
+#
+# $(foreach prog,$(PROGS),$(eval $(call PROG_template,$(prog))))
+
+$(ELFS):
+ $(LINK.o) $^ $(LDLIBS) -o $@
%.lst: %.elf
$(OBJDUMP) -h -S $< > $@
+# Dependency checking.
+-include $(OBJECTS:%.o=%.d)
+
clean:
- rm -f *.o $(OBJECTS) $(PROGS:%=%.elf) *.lst *.map *.bak *~
+ rm -f *.o *.d $(ELFS) *.lst *.map *.bak *~
rm -f $(DOC) *.exd $(EXTRA_CLEAN_FILES) $(TEXTS) $(EEPROMS)
# Rules for building the doc. {{{1
diff --git a/n/avr/howto/howto-avr.txt b/n/avr/howto/howto-avr.txt
index 5c5388a..2fe7033 100644
--- a/n/avr/howto/howto-avr.txt
+++ b/n/avr/howto/howto-avr.txt
@@ -75,6 +75,6 @@ En bonus, pour reseter l'AVR depuis le PC :
Chaque module est déposé dans son répertoire séparé. Pour les utiliser dans un
projet, il suffit de créer un |avrconfig.h| qui va bien et de compiler les
sources du module avec son projet. Pour cela, il suffit de mettre le nom du
-module et du fichier de configuration dans le |Makefile|. Le module est
-cherché automatiquement sur le cvs, puis ajouté à l'édition des liens. Se
-reporter au code éxistant pour plus de détails.
+module et du fichier de configuration dans le |Makefile|. La commande
+|make modules_co| fait un checkout des modules et |make modules_up| permet de
+les mettre à jour. Se reporter au code éxistant pour plus de détails.