|
@@ -1,6 +1,8 @@
|
|
|
PERF := .
|
|
|
MK := Makefile
|
|
|
|
|
|
+has = $(shell which $1 2>/dev/null)
|
|
|
+
|
|
|
# standard single make variable specified
|
|
|
make_clean_all := clean all
|
|
|
make_python_perf_so := python/perf.so
|
|
@@ -25,6 +27,13 @@ make_help := help
|
|
|
make_doc := doc
|
|
|
make_perf_o := perf.o
|
|
|
make_util_map_o := util/map.o
|
|
|
+make_install := install
|
|
|
+make_install_bin := install-bin
|
|
|
+make_install_doc := install-doc
|
|
|
+make_install_man := install-man
|
|
|
+make_install_html := install-html
|
|
|
+make_install_info := install-info
|
|
|
+make_install_pdf := install-pdf
|
|
|
|
|
|
# all the NO_* variable combined
|
|
|
make_minimal := NO_LIBPERL=1 NO_LIBPYTHON=1 NO_NEWT=1 NO_GTK2=1
|
|
@@ -50,14 +59,27 @@ run += make_no_backtrace
|
|
|
run += make_no_libnuma
|
|
|
run += make_no_libaudit
|
|
|
run += make_no_libbionic
|
|
|
-run += make_tags
|
|
|
-run += make_cscope
|
|
|
run += make_help
|
|
|
run += make_doc
|
|
|
run += make_perf_o
|
|
|
run += make_util_map_o
|
|
|
+run += make_install
|
|
|
+run += make_install_bin
|
|
|
+# FIXME 'install-*' commented out till they're fixed
|
|
|
+# run += make_install_doc
|
|
|
+# run += make_install_man
|
|
|
+# run += make_install_html
|
|
|
+# run += make_install_info
|
|
|
+# run += make_install_pdf
|
|
|
run += make_minimal
|
|
|
|
|
|
+ifneq ($(call has,ctags),)
|
|
|
+run += make_tags
|
|
|
+endif
|
|
|
+ifneq ($(call has,cscope),)
|
|
|
+run += make_cscope
|
|
|
+endif
|
|
|
+
|
|
|
# $(run_O) contains same portion of $(run) tests with '_O' attached
|
|
|
# to distinguish O=... tests
|
|
|
run_O := $(addsuffix _O,$(run))
|
|
@@ -84,6 +106,31 @@ test_make_python_perf_so := test -f $(PERF)/python/perf.so
|
|
|
test_make_perf_o := test -f $(PERF)/perf.o
|
|
|
test_make_util_map_o := test -f $(PERF)/util/map.o
|
|
|
|
|
|
+test_make_install := test -x $$TMP_DEST/bin/perf
|
|
|
+test_make_install_O := $(test_make_install)
|
|
|
+test_make_install_bin := $(test_make_install)
|
|
|
+test_make_install_bin_O := $(test_make_install)
|
|
|
+
|
|
|
+# FIXME nothing gets installed
|
|
|
+test_make_install_man := test -f $$TMP_DEST/share/man/man1/perf.1
|
|
|
+test_make_install_man_O := $(test_make_install_man)
|
|
|
+
|
|
|
+# FIXME nothing gets installed
|
|
|
+test_make_install_doc := $(test_ok)
|
|
|
+test_make_install_doc_O := $(test_ok)
|
|
|
+
|
|
|
+# FIXME nothing gets installed
|
|
|
+test_make_install_html := $(test_ok)
|
|
|
+test_make_install_html_O := $(test_ok)
|
|
|
+
|
|
|
+# FIXME nothing gets installed
|
|
|
+test_make_install_info := $(test_ok)
|
|
|
+test_make_install_info_O := $(test_ok)
|
|
|
+
|
|
|
+# FIXME nothing gets installed
|
|
|
+test_make_install_pdf := $(test_ok)
|
|
|
+test_make_install_pdf_O := $(test_ok)
|
|
|
+
|
|
|
# Kbuild tests only
|
|
|
#test_make_python_perf_so_O := test -f $$TMP/tools/perf/python/perf.so
|
|
|
#test_make_perf_o_O := test -f $$TMP/tools/perf/perf.o
|
|
@@ -95,7 +142,7 @@ test_make_util_map_o_O := true
|
|
|
test_default = test -x $(PERF)/perf
|
|
|
test = $(if $(test_$1),$(test_$1),$(test_default))
|
|
|
|
|
|
-test_default_O = test -x $$TMP/perf
|
|
|
+test_default_O = test -x $$TMP_O/perf
|
|
|
test_O = $(if $(test_$1),$(test_$1),$(test_default_O))
|
|
|
|
|
|
all:
|
|
@@ -111,23 +158,27 @@ clean := @(cd $(PERF); make -s -f $(MK) clean >/dev/null)
|
|
|
|
|
|
$(run):
|
|
|
$(call clean)
|
|
|
- @cmd="cd $(PERF) && make -f $(MK) $($@)"; \
|
|
|
+ @TMP_DEST=$$(mktemp -d); \
|
|
|
+ cmd="cd $(PERF) && make -f $(MK) DESTDIR=$$TMP_DEST $($@)"; \
|
|
|
echo "- $@: $$cmd" && echo $$cmd > $@ && \
|
|
|
( eval $$cmd ) >> $@ 2>&1; \
|
|
|
echo " test: $(call test,$@)"; \
|
|
|
$(call test,$@) && \
|
|
|
- rm -f $@
|
|
|
+ rm -f $@ \
|
|
|
+ rm -rf $$TMP_DEST
|
|
|
|
|
|
$(run_O):
|
|
|
$(call clean)
|
|
|
- @TMP=$$(mktemp -d); \
|
|
|
- cmd="cd $(PERF) && make -f $(MK) $($(patsubst %_O,%,$@)) O=$$TMP"; \
|
|
|
+ @TMP_O=$$(mktemp -d); \
|
|
|
+ TMP_DEST=$$(mktemp -d); \
|
|
|
+ cmd="cd $(PERF) && make -f $(MK) O=$$TMP_O DESTDIR=$$TMP_DEST $($(patsubst %_O,%,$@))"; \
|
|
|
echo "- $@: $$cmd" && echo $$cmd > $@ && \
|
|
|
( eval $$cmd ) >> $@ 2>&1 && \
|
|
|
echo " test: $(call test_O,$@)"; \
|
|
|
$(call test_O,$@) && \
|
|
|
rm -f $@ && \
|
|
|
- rm -rf $$TMP
|
|
|
+ rm -rf $$TMP_O \
|
|
|
+ rm -rf $$TMP_DEST
|
|
|
|
|
|
all: $(run) $(run_O)
|
|
|
@echo OK
|