aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--resources/makefile58
-rw-r--r--test/makefile22
2 files changed, 75 insertions, 5 deletions
diff --git a/resources/makefile b/resources/makefile
new file mode 100644
index 0000000..d5598ea
--- /dev/null
+++ b/resources/makefile
@@ -0,0 +1,58 @@
+TARGET=XXX
+CC=clang
+CC?=clang
+CC_FLAGS=-fpic
+CC_EXTRA?=
+CC_FLAGS+=$(CC_EXTRA)
+LD_FLAGS=
+EXTRA_LD_FLAGS?=
+LD_FLAGS+=$(EXTRA_LD_FLAGS)
+ADD_SANITIZERS_CC= -g -fsanitize=address -fno-omit-frame-pointer
+ADD_SANITIZERS_LD= -g -fsanitize=address
+MEM_SANITIZERS_CC= -g -fsanitize=memory -fno-omit-frame-pointer
+MEM_SANITIZERS_LD= -g -fsanitize=memory
+UB_SANITIZERS_CC= -g -fsanitize=undefined -fno-omit-frame-pointer
+UB_SANITIZERS_LD= -g -fsanitize=undefined
+BUILD_MODE?=COV_NO_CLANG_1Z
+
+SRCS=$(wildcard *.c)
+
+.DEFAULT:all
+
+.PHONY:all clean help ASM SO
+
+all:$(TARGET)
+
+depend:.depend
+
+.depend:$(SRCS)
+ rm -rf .depend
+ $(CC) -MM $(CC_FLAGS) $^ > ./.depend
+
+-include ./.depend
+
+.c.o:
+ $(CC) $(CC_FLAGS) -c $< -o $@
+
+$(TARGET): $(TARGET).o
+ $(CC) $^ $(LD_FLAGS) -o $@
+
+ASM:$(TARGET).asm
+
+SO:$(TARGET).so
+
+$(TARGET).asm: $(TARGET).o
+ objdump -r -d -M intel -S $(TARGET).o > $(TARGET).asm
+
+$(TARGET).so: $(TARGET).o
+ $(CC) $^ $(LD_FLAGS) -shared -o $@
+
+clean:
+ rm -f *.o *~ $(TARGET) $(TARGET).so $(TARGET).asm
+ rm .depend
+
+help:
+ @echo "all is the default target"
+ @echo "SO will generate the so"
+ @echo "ASM will generate assembly files"
+ @echo "clean"
diff --git a/test/makefile b/test/makefile
index 9254ad7..d5598ea 100644
--- a/test/makefile
+++ b/test/makefile
@@ -1,7 +1,7 @@
-TARGET=
+TARGET=XXX
CC=clang
CC?=clang
-CC_FLAGS=
+CC_FLAGS=-fpic
CC_EXTRA?=
CC_FLAGS+=$(CC_EXTRA)
LD_FLAGS=
@@ -19,7 +19,7 @@ SRCS=$(wildcard *.c)
.DEFAULT:all
-.PHONY:all clean help
+.PHONY:all clean help ASM SO
all:$(TARGET)
@@ -37,10 +37,22 @@ depend:.depend
$(TARGET): $(TARGET).o
$(CC) $^ $(LD_FLAGS) -o $@
+ASM:$(TARGET).asm
+
+SO:$(TARGET).so
+
+$(TARGET).asm: $(TARGET).o
+ objdump -r -d -M intel -S $(TARGET).o > $(TARGET).asm
+
+$(TARGET).so: $(TARGET).o
+ $(CC) $^ $(LD_FLAGS) -shared -o $@
+
clean:
- rm -f *.o *~ $(TARGET)
+ rm -f *.o *~ $(TARGET) $(TARGET).so $(TARGET).asm
rm .depend
help:
@echo "all is the default target"
- @echo "there is clean."
+ @echo "SO will generate the so"
+ @echo "ASM will generate assembly files"
+ @echo "clean"