X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=src%2FMakefile;h=0ca101c07c526a3457fcfa9d0e0171d1eff621f2;hp=a4f6a5545c5f2e02ff0d783898d4f98cc1772fd2;hb=262ee65885d55902df96f4aec6a114f5ac6f2c61;hpb=424638446b7c7bb3f4aa6b4764d3e68175dcbf8c diff --git a/src/Makefile b/src/Makefile index a4f6a554..0ca101c0 100644 --- a/src/Makefile +++ b/src/Makefile @@ -8,35 +8,67 @@ vpath make-kalman util vpath make-whiten util vpath kalman.5c kalman vpath kalman_filter.5c kalman +vpath kalman_micro.5c kalman vpath load_csv.5c kalman vpath matrix.5c kalman include Version +include Makedefs -ifneq ($(shell which sdcc),) - SUBDIRS+=\ +SDCCDIRS=\ telemetrum-v1.2 telemetrum-v1.1 telemetrum-v1.0 \ - teledongle-v0.2 teledongle-v0.1 \ - telemini-v1.0 telenano-v0.1 \ - telebt-v0.0 telebt-v0.1 \ - telemetrum-v0.1-sky telemetrum-v0.1-sirf \ - telelaunch-v0.1 tidongle test \ + teledongle-v0.2 \ + telemini-v1.0 \ + telebt-v1.0 \ teleterra-v0.2 teleshield-v0.1 \ - telefire-v0.1 \ - spiradio-v0.1 + telefire-v0.1 telefire-v0.2 \ + telemini-v2.0 + +ARMM3DIRS=\ + telemega-v0.1 telemega-v0.1/flash-loader \ + telemega-v1.0 telemega-v1.0/flash-loader \ + telemetrum-v2.0 telemetrum-v2.0/flash-loader \ + megadongle-v0.1 megadongle-v0.1/flash-loader \ + telegps-v0.3 telegps-v0.3/flash-loader \ + telelco-v0.2 telelco-v0.2/flash-loader \ + telescience-v0.2 telescience-v0.2/flash-loader + +ARMM0DIRS=\ + easymini-v1.0 easymini-v1.0/flash-loader + +AVRDIRS=\ + telescience-v0.1 telescience-pwm micropeak nanopeak-v0.1 + +SUBDIRS= + +ifeq ($(strip $(HAVE_PDCLIB)),yes) +PDCLIB=pdclib +CLEAN_PDCLIB=clean-pdclib +endif + +ifeq ($(strip $(HAVE_SDCC)),yes) +SUBDIRS+=$(SDCCDIRS) +endif + +ifeq ($(strip $(HAVE_ARM_M3_CC)),yes) +SUBDIRS+=$(ARMM3DIRS) +foo=bar endif -ifneq ($(shell which avr-gcc),) - SUBDIRS += telescience-v0.1 telescience-pwm telepyro-v0.1 micropeak +ifeq ($(strip $(HAVE_ARM_M0_CC)),yes) +SUBDIRS+=$(ARMM0DIRS) +baz=bletch endif -ifneq ($(shell which arm-none-eabi-gcc),) - SUBDIRS += megametrum-v0.1 stm-bringup stm-demo telelco-v0.1 +ifeq ($(strip $(HAVE_AVR_CC)),yes) +SUBDIRS += $(AVRDIRS) endif +ALLDIRS=$(SDCCDIRS) $(ARMM3DIRS) $(ARMM0DIRS) $(AVRDIRS) + all: all-local all-recursive -RECURSIVE_TARGETS = all-recursive clean-recursive install-recursive +RECURSIVE_TARGETS = all-recursive install-recursive $(RECURSIVE_TARGETS): @target=`echo $@ | sed 's/-recursive//'`; \ @@ -45,6 +77,15 @@ $(RECURSIVE_TARGETS): (cd $$subdir && $(MAKE) $$target) || exit 1; \ done +ALL_RECURSIVE_TARGETS = clean-recursive + +$(ALL_RECURSIVE_TARGETS): + @target=`echo $@ | sed 's/-recursive//'`; \ + for subdir in $(ALLDIRS); do \ + echo "Making $$target in $$subdir"; \ + (cd $$subdir && $(MAKE) $$target) || exit 1; \ + done + distclean: clean clean: clean-local clean-recursive @@ -55,7 +96,7 @@ uninstall: all-recursive: all-local -all-local: altitude.h altitude-pa.h ao_kalman.h ao_whiten.h +all-local: altitude.h altitude-pa.h ao_kalman.h ao_whiten.h $(PDCLIB) altitude.h: make-altitude nickle $< > $@ @@ -69,5 +110,11 @@ ao_kalman.h: make-kalman kalman.5c kalman_filter.5c load_csv.5c matrix.5c ao_whiten.h: make-whiten nickle $< > $@ -clean-local: +clean-local: $(CLEAN_PDCLIB) rm -f altitude.h ao_kalman.h + +pdclib: + cd ../pdclib && mkdir -p opt/include opt/lib && make && make prefix=`pwd`/opt install + +clean-pdclib: + cd ../pdclib && make clean && rm -rf opt \ No newline at end of file