blob: 434dc68a7c14df794e75d45a0734e3f26edce53e (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
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 read.o aggregate.o structs.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"
|