2018-10-28 22:31:46 -04:00
|
|
|
CONFIG_NATIVE := true
|
2018-09-19 13:57:35 -04:00
|
|
|
CONFIG_CXX_ALLOCATOR := true
|
2018-10-14 18:58:54 -04:00
|
|
|
CONFIG_UBSAN := false
|
2018-10-19 21:29:40 -04:00
|
|
|
CONFIG_SEAL_METADATA := false
|
2018-11-02 21:35:09 -04:00
|
|
|
CONFIG_WRITE_AFTER_FREE_CHECK := true
|
|
|
|
CONFIG_SLOT_RANDOMIZE := true
|
|
|
|
CONFIG_ZERO_ON_FREE := true
|
|
|
|
CONFIG_SLAB_CANARY := true
|
2018-09-19 13:57:35 -04:00
|
|
|
|
2018-10-23 07:23:07 -04:00
|
|
|
define safe_flag
|
2018-10-23 15:55:45 -04:00
|
|
|
$(shell $(CC) -E $1 - </dev/null >/dev/null 2>&1 && echo $1)
|
2018-10-23 07:23:07 -04:00
|
|
|
endef
|
|
|
|
|
2018-08-21 15:23:22 -04:00
|
|
|
CPPFLAGS := -D_GNU_SOURCE
|
2018-11-04 19:45:04 -05:00
|
|
|
SHARED_FLAGS := -O3 -flto -fPIC -fvisibility=hidden -fno-plt -pipe -Wall -Wextra $(call safe_flag,-Wcast-align=strict) -Wcast-qual -Wwrite-strings
|
2018-10-28 22:31:46 -04:00
|
|
|
|
|
|
|
ifeq ($(CONFIG_NATIVE),true)
|
|
|
|
SHARED_FLAGS += -march=native
|
|
|
|
endif
|
|
|
|
|
2018-10-05 02:45:40 -04:00
|
|
|
CFLAGS := -std=c11 $(SHARED_FLAGS) -Wmissing-prototypes
|
|
|
|
CXXFLAGS := -std=c++14 $(SHARED_FLAGS)
|
2018-11-04 14:32:03 -05:00
|
|
|
LDFLAGS := -Wl,--as-needed,-z,defs,-z,relro,-z,now,-z,nodlopen,-z,text
|
2018-10-19 17:07:30 -04:00
|
|
|
TIDY_CHECKS := -checks=bugprone-*,-bugprone-macro-parentheses,cert-*,clang-analyzer-*,readability-*,-readability-else-after-return,-readability-inconsistent-declaration-parameter-name,-readability-named-parameter
|
2018-10-14 18:33:40 -04:00
|
|
|
|
2018-10-14 18:01:40 -04:00
|
|
|
SOURCES := chacha.c malloc.c memory.c pages.c random.c util.c
|
|
|
|
OBJECTS := $(SOURCES:.c=.o)
|
2018-08-21 15:23:22 -04:00
|
|
|
|
2018-09-19 13:57:35 -04:00
|
|
|
ifeq ($(CONFIG_CXX_ALLOCATOR),true)
|
|
|
|
LDLIBS += -lstdc++
|
2018-10-14 18:01:40 -04:00
|
|
|
SOURCES += new.cc
|
2018-09-19 13:57:35 -04:00
|
|
|
OBJECTS += new.o
|
|
|
|
endif
|
|
|
|
|
2018-10-14 18:58:54 -04:00
|
|
|
ifeq ($(CONFIG_UBSAN),true)
|
|
|
|
CFLAGS += -fsanitize=undefined
|
|
|
|
CXXFLAGS += -fsanitize=undefined
|
|
|
|
endif
|
|
|
|
|
2018-10-19 21:29:40 -04:00
|
|
|
ifeq ($(CONFIG_SEAL_METADATA),true)
|
|
|
|
CPPFLAGS += -DCONFIG_SEAL_METADATA
|
|
|
|
endif
|
|
|
|
|
2018-11-02 21:35:09 -04:00
|
|
|
ifeq (,$(filter $(CONFIG_ZERO_ON_FREE),true false))
|
|
|
|
$(error CONFIG_ZERO_ON_FREE must be true or false)
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq (,$(filter $(CONFIG_WRITE_AFTER_FREE_CHECK),true false))
|
|
|
|
$(error CONFIG_WRITE_AFTER_FREE_CHECK must be true or false)
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq (,$(filter $(CONFIG_SLOT_RANDOMIZE),true false))
|
|
|
|
$(error CONFIG_SLOT_RANDOMIZE must be true or false)
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq (,$(filter $(CONFIG_SLAB_CANARY),true false))
|
|
|
|
$(error CONFIG_SLAB_CANARY must be true or false)
|
|
|
|
endif
|
|
|
|
|
|
|
|
CPPFLAGS += \
|
|
|
|
-DZERO_ON_FREE=$(CONFIG_ZERO_ON_FREE) \
|
|
|
|
-DWRITE_AFTER_FREE_CHECK=$(CONFIG_WRITE_AFTER_FREE_CHECK) \
|
|
|
|
-DSLOT_RANDOMIZE=$(CONFIG_SLOT_RANDOMIZE) \
|
|
|
|
-DSLAB_CANARY=$(CONFIG_SLAB_CANARY)
|
|
|
|
|
2018-08-21 15:23:22 -04:00
|
|
|
hardened_malloc.so: $(OBJECTS)
|
|
|
|
$(CC) $(CFLAGS) $(LDFLAGS) -shared $^ $(LDLIBS) -o $@
|
|
|
|
|
2018-10-07 11:28:50 -04:00
|
|
|
chacha.o: chacha.c chacha.h util.h
|
|
|
|
malloc.o: malloc.c malloc.h config.h mutex.h memory.h pages.h random.h util.h
|
2018-08-29 00:53:12 -04:00
|
|
|
memory.o: memory.c memory.h util.h
|
2018-10-07 11:28:50 -04:00
|
|
|
new.o: new.cc malloc.h util.h
|
2018-09-02 02:03:27 -04:00
|
|
|
pages.o: pages.c pages.h memory.h util.h
|
2018-08-25 23:00:00 -04:00
|
|
|
random.o: random.c random.h chacha.h util.h
|
2018-08-21 15:23:22 -04:00
|
|
|
util.o: util.c util.h
|
|
|
|
|
2018-10-14 18:01:40 -04:00
|
|
|
tidy:
|
2018-10-14 18:33:40 -04:00
|
|
|
clang-tidy $(TIDY_CHECKS) $(SOURCES) -- $(CPPFLAGS)
|
2018-10-14 18:01:40 -04:00
|
|
|
|
2018-08-21 15:23:22 -04:00
|
|
|
clean:
|
|
|
|
rm -f hardened_malloc.so $(OBJECTS)
|
2018-10-14 18:01:40 -04:00
|
|
|
|
|
|
|
.PHONY: clean tidy
|