1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- #
- # This is a simple wrapper Makefile that calls the main Makefile.perf
- # with a -j option to do parallel builds
- #
- # If you want to invoke the perf build in some non-standard way then
- # you can use the 'make -f Makefile.perf' method to invoke it.
- #
- #
- # Clear out the built-in rules GNU make defines by default (such as .o targets),
- # so that we pass through all targets to Makefile.perf:
- #
- .SUFFIXES:
- #
- # We don't want to pass along options like -j:
- #
- unexport MAKEFLAGS
- #
- # Do a parallel build with multiple jobs, based on the number of CPUs online
- # in this system: 'make -j8' on a 8-CPU system, etc.
- #
- # (To override it, run 'make JOBS=1' and similar.)
- #
- ifeq ($(JOBS),)
- JOBS := $(shell grep -c ^processor /proc/cpuinfo 2>/dev/null)
- ifeq ($(JOBS),)
- JOBS := 1
- endif
- endif
- define print_msg
- @printf ' BUILD: Doing '\''make \033[33m-j'$(JOBS)'\033[m'\'' parallel build\n'
- endef
- define make
- @$(MAKE) -f Makefile.perf --no-print-directory -j$(JOBS) O=$(O) $@
- endef
- #
- # Needed if no target specified:
- #
- all:
- $(print_msg)
- $(make)
- #
- # The clean target is not really parallel, don't print the jobs info:
- #
- clean:
- $(make)
- #
- # All other targets get passed through:
- #
- %:
- $(print_msg)
- $(make)
|