]> git.localhorst.tv Git - blank.git/commitdiff
increased convenience in build process
authorDaniel Karbach <daniel.karbach@localhorst.tv>
Wed, 11 Mar 2015 12:39:16 +0000 (13:39 +0100)
committerDaniel Karbach <daniel.karbach@localhorst.tv>
Wed, 11 Mar 2015 12:39:16 +0000 (13:39 +0100)
* make "release" the default target
* add "profile" build
* add shorthand targets for launching, debugging, profiling

.gitignore
Makefile

index e8f25c75e23b793ea16401b7e46891caf25cc567..d599a315e946d9f7ffa8f1bbb9ac715230ac7cd0 100644 (file)
@@ -2,4 +2,7 @@
 *.swo
 blank
 blank.debug
+blank.profile
 build
+cachegrind.out.*
+callgrind.out.*
index e44a8710e7fd5d19f0e51172632114b128dad588..67b9bf1b5f200ba9c2b8f9a0b4ec088d362ef15e 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -14,43 +14,60 @@ LDXXFLAGS ?=
 LDXXFLAGS += $(PKGLIBS)
 
 DEBUG_FLAGS = -g3 -O0
+PROFILE_FLAGS = -DNDEBUG -O1 -g3
 RELEASE_FLAGS = -DNDEBUG -O2
 
 SOURCE_DIR := src
 DEBUG_DIR := build/debug
+PROFILE_DIR := build/profile
 RELEASE_DIR := build/release
-DIR := $(RELEASE_DIR) $(DEBUG_DIR) build
+DIR := $(RELEASE_DIR) $(DEBUG_DIR) $(PROFILE_DIR) build
 
 SRC := $(wildcard $(SOURCE_DIR)/*.cpp)
 RELEASE_OBJ := $(patsubst $(SOURCE_DIR)/%.cpp, $(RELEASE_DIR)/%.o, $(SRC))
 DEBUG_OBJ := $(patsubst $(SOURCE_DIR)/%.cpp, $(DEBUG_DIR)/%.o, $(SRC))
+PROFILE_OBJ := $(patsubst $(SOURCE_DIR)/%.cpp, $(PROFILE_DIR)/%.o, $(SRC))
 RELEASE_DEP := $(RELEASE_OBJ:.o=.d)
 DEBUG_DEP := $(DEBUG_OBJ:.o=.d)
+PROFILE_DEP := $(PROFILE_OBJ:.o=.d)
 RELEASE_BIN := blank
 DEBUG_BIN := blank.debug
-OBJ := $(RELEASE_OBJ) $(DEBUG_OBJ)
-DEP := $(RELEASE_DEP) $(DEBUG_DEP)
-BIN := $(RELEASE_BIN) $(DEBUG_BIN)
-
-all: $(BIN)
+PROFILE_BIN := blank.profile
+OBJ := $(RELEASE_OBJ) $(DEBUG_OBJ) $(PROFILE_OBJ)
+DEP := $(RELEASE_DEP) $(DEBUG_DEP) $(PROFILE_DEP)
+BIN := $(RELEASE_BIN) $(DEBUG_BIN) $(PROFILE_BIN)
 
 release: $(RELEASE_BIN)
 
+all: $(BIN)
+
 debug: $(DEBUG_BIN)
 
+profile: $(PROFILE_BIN)
+
 run: blank
        ./blank
 
 gdb: blank.debug
        gdb ./blank.debug
 
+cachegrind: blank.profile
+       valgrind ./blank.profile
+
+callgrind: blank.profile
+       valgrind --tool=callgrind \
+               --branch-sim=yes --cacheuse=yes --cache-sim=yes \
+               --collect-bus=yes --collect-systime=yes --collect-jumps=yes \
+               --dump-instr=yes --simulate-hwpref=yes --simulate-wb=yes \
+               ./blank.profile
+
 clean:
        rm -df $(OBJ) $(DEP) $(DIR)
 
 distclean: clean
-       rm -f $(BIN)
+       rm -f $(BIN) cachegrind.out.* callgrind.out.*
 
-.PHONY: all release debug run gdb clean distclean
+.PHONY: all release debug profile run gdb cachegrind callgrind clean distclean
 
 -include $(DEP)
 
@@ -62,6 +79,10 @@ $(DEBUG_BIN): $(DEBUG_OBJ)
        @echo link: $@
        @$(LDXX) -o $@ $(CXXFLAGS) $(LDXXFLAGS) $(DEBUG_FLAGS) $^
 
+$(PROFILE_BIN): $(PROFILE_OBJ)
+       @echo link: $@
+       @$(LDXX) -o $@ $(CXXFLAGS) $(LDXXFLAGS) $(PROFILE_FLAGS) $^
+
 $(RELEASE_DIR)/%.o: $(SOURCE_DIR)/%.cpp | $(RELEASE_DIR)
        @echo compile: $@
        @$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $(RELEASE_FLAGS) -o $@ -MMD -MP -MF"$(@:.o=.d)" -MT"$@" $<
@@ -70,5 +91,9 @@ $(DEBUG_DIR)/%.o: $(SOURCE_DIR)/%.cpp | $(DEBUG_DIR)
        @echo compile: $@
        @$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $(DEBUG_FLAGS) -o $@ -MMD -MP -MF"$(@:.o=.d)" -MT"$@" $<
 
+$(PROFILE_DIR)/%.o: $(SOURCE_DIR)/%.cpp | $(PROFILE_DIR)
+       @echo compile: $@
+       @$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $(PROFILE_FLAGS) -o $@ -MMD -MP -MF"$(@:.o=.d)" -MT"$@" $<
+
 $(DIR):
        @mkdir -p "$@"