2019-08-18 02:28:23 -04:00
|
|
|
CONFIG_WERROR := true
|
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-12-09 11:02:53 -05:00
|
|
|
CONFIG_ZERO_ON_FREE := true
|
2018-11-02 21:35:09 -04:00
|
|
|
CONFIG_WRITE_AFTER_FREE_CHECK := true
|
|
|
|
CONFIG_SLOT_RANDOMIZE := true
|
|
|
|
CONFIG_SLAB_CANARY := true
|
2019-01-02 14:59:19 -05:00
|
|
|
CONFIG_SLAB_QUARANTINE_RANDOM_LENGTH := 1
|
|
|
|
CONFIG_SLAB_QUARANTINE_QUEUE_LENGTH := 1
|
2018-09-16 13:26:59 -04:00
|
|
|
CONFIG_EXTENDED_SIZE_CLASSES := true
|
2019-04-07 08:04:06 -04:00
|
|
|
CONFIG_LARGE_SIZE_CLASSES := true
|
2018-11-16 15:25:35 -05:00
|
|
|
CONFIG_GUARD_SLABS_INTERVAL := 1
|
|
|
|
CONFIG_GUARD_SIZE_DIVISOR := 2
|
2021-03-18 06:27:46 -04:00
|
|
|
CONFIG_REGION_QUARANTINE_RANDOM_LENGTH := 256
|
2019-01-02 13:40:02 -05:00
|
|
|
CONFIG_REGION_QUARANTINE_QUEUE_LENGTH := 1024
|
2018-12-05 09:23:05 -05:00
|
|
|
CONFIG_REGION_QUARANTINE_SKIP_THRESHOLD := 33554432 # 32MiB
|
2019-01-02 13:40:02 -05:00
|
|
|
CONFIG_FREE_SLABS_QUARANTINE_RANDOM_LENGTH := 32
|
2019-06-19 01:00:22 -04:00
|
|
|
CONFIG_CLASS_REGION_SIZE := 34359738368 # 32GiB
|
2019-04-10 08:12:59 -04:00
|
|
|
CONFIG_N_ARENA := 4
|
2019-04-06 20:49:52 -04:00
|
|
|
CONFIG_STATS := false
|
2018-09-19 13:57:35 -04:00
|
|
|
|
2018-10-23 07:23:07 -04:00
|
|
|
define safe_flag
|
2019-08-18 01:14:45 -04:00
|
|
|
$(shell $(CC) $(if $(filter clang,$(CC)),-Werror=unknown-warning-option) -E $1 - </dev/null >/dev/null 2>&1 && echo $1 || echo $2)
|
2018-10-23 07:23:07 -04:00
|
|
|
endef
|
|
|
|
|
2020-09-14 05:52:53 -04:00
|
|
|
CPPFLAGS := $(CPPFLAGS) -D_GNU_SOURCE -I include
|
2019-08-18 08:41:12 -04:00
|
|
|
SHARED_FLAGS := -O3 -flto -fPIC -fvisibility=hidden $(call safe_flag,-fno-plt) \
|
|
|
|
$(call safe_flag,-fstack-clash-protection) -fstack-protector-strong -pipe -Wall -Wextra \
|
|
|
|
$(call safe_flag,-Wcast-align=strict,-Wcast-align) -Wcast-qual -Wwrite-strings
|
2018-10-28 22:31:46 -04:00
|
|
|
|
2020-04-30 16:36:47 -04:00
|
|
|
ifeq ($(CC),clang)
|
|
|
|
SHARED_FLAGS += -Wno-constant-logical-operand
|
|
|
|
endif
|
|
|
|
|
2019-08-18 02:28:23 -04:00
|
|
|
ifeq ($(CONFIG_WERROR),true)
|
|
|
|
SHARED_FLAGS += -Werror
|
|
|
|
endif
|
|
|
|
|
2018-10-28 22:31:46 -04:00
|
|
|
ifeq ($(CONFIG_NATIVE),true)
|
|
|
|
SHARED_FLAGS += -march=native
|
|
|
|
endif
|
|
|
|
|
2019-07-29 13:52:55 -04:00
|
|
|
CFLAGS := $(CFLAGS) -std=c11 $(SHARED_FLAGS) -Wmissing-prototypes
|
2019-09-26 14:50:58 -04:00
|
|
|
CXXFLAGS := $(CXXFLAGS) $(call safe_flag,-std=c++17,-std=c++14) $(SHARED_FLAGS)
|
2019-07-29 13:52:55 -04:00
|
|
|
LDFLAGS := $(LDFLAGS) -Wl,--as-needed,-z,defs,-z,relro,-z,now,-z,nodlopen,-z,text
|
2018-10-14 18:33:40 -04:00
|
|
|
|
2018-12-05 02:21:28 -05:00
|
|
|
SOURCES := chacha.c h_malloc.c memory.c pages.c random.c util.c
|
2018-10-14 18:01:40 -04:00
|
|
|
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)
|
2019-08-18 01:27:02 -04:00
|
|
|
# make sure LTO is compatible in case CC and CXX don't match (such as clang and g++)
|
|
|
|
CXX := $(CC)
|
2019-08-18 04:53:51 -04:00
|
|
|
LDLIBS += -lstdc++ -lgcc_s
|
2019-08-18 01:27:02 -04:00
|
|
|
|
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)
|
2019-08-18 01:59:48 -04:00
|
|
|
CFLAGS += -fsanitize=undefined -fno-sanitize-recover=undefined
|
|
|
|
CXXFLAGS += -fsanitize=undefined -fno-sanitize-recover=undefined
|
2018-10-14 18:58:54 -04:00
|
|
|
endif
|
|
|
|
|
2019-08-18 01:56:20 -04:00
|
|
|
ifeq (,$(filter $(CONFIG_SEAL_METADATA),true false))
|
|
|
|
$(error CONFIG_SEAL_METADATA must be true or false)
|
2018-10-19 21:29:40 -04:00
|
|
|
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
|
|
|
|
|
2018-09-16 13:26:59 -04:00
|
|
|
ifeq (,$(filter $(CONFIG_EXTENDED_SIZE_CLASSES),true false))
|
|
|
|
$(error CONFIG_EXTENDED_SIZE_CLASSES must be true or false)
|
|
|
|
endif
|
|
|
|
|
2019-04-07 08:04:06 -04:00
|
|
|
ifeq (,$(filter $(CONFIG_LARGE_SIZE_CLASSES),true false))
|
|
|
|
$(error CONFIG_LARGE_SIZE_CLASSES must be true or false)
|
|
|
|
endif
|
|
|
|
|
2019-04-07 09:06:03 -04:00
|
|
|
ifeq (,$(filter $(CONFIG_STATS),true false))
|
|
|
|
$(error CONFIG_STATS must be true or false)
|
|
|
|
endif
|
|
|
|
|
2018-11-02 21:35:09 -04:00
|
|
|
CPPFLAGS += \
|
2019-08-18 01:56:20 -04:00
|
|
|
-DCONFIG_SEAL_METADATA=$(CONFIG_SEAL_METADATA) \
|
2018-11-02 21:35:09 -04:00
|
|
|
-DZERO_ON_FREE=$(CONFIG_ZERO_ON_FREE) \
|
|
|
|
-DWRITE_AFTER_FREE_CHECK=$(CONFIG_WRITE_AFTER_FREE_CHECK) \
|
|
|
|
-DSLOT_RANDOMIZE=$(CONFIG_SLOT_RANDOMIZE) \
|
2018-11-16 15:25:35 -05:00
|
|
|
-DSLAB_CANARY=$(CONFIG_SLAB_CANARY) \
|
2019-01-02 13:40:02 -05:00
|
|
|
-DSLAB_QUARANTINE_RANDOM_LENGTH=$(CONFIG_SLAB_QUARANTINE_RANDOM_LENGTH) \
|
|
|
|
-DSLAB_QUARANTINE_QUEUE_LENGTH=$(CONFIG_SLAB_QUARANTINE_QUEUE_LENGTH) \
|
2018-09-16 13:26:59 -04:00
|
|
|
-DCONFIG_EXTENDED_SIZE_CLASSES=$(CONFIG_EXTENDED_SIZE_CLASSES) \
|
2019-04-07 08:04:06 -04:00
|
|
|
-DCONFIG_LARGE_SIZE_CLASSES=$(CONFIG_LARGE_SIZE_CLASSES) \
|
2018-11-16 15:25:35 -05:00
|
|
|
-DGUARD_SLABS_INTERVAL=$(CONFIG_GUARD_SLABS_INTERVAL) \
|
|
|
|
-DGUARD_SIZE_DIVISOR=$(CONFIG_GUARD_SIZE_DIVISOR) \
|
2019-01-02 13:40:02 -05:00
|
|
|
-DREGION_QUARANTINE_RANDOM_LENGTH=$(CONFIG_REGION_QUARANTINE_RANDOM_LENGTH) \
|
|
|
|
-DREGION_QUARANTINE_QUEUE_LENGTH=$(CONFIG_REGION_QUARANTINE_QUEUE_LENGTH) \
|
2018-11-16 15:25:35 -05:00
|
|
|
-DREGION_QUARANTINE_SKIP_THRESHOLD=$(CONFIG_REGION_QUARANTINE_SKIP_THRESHOLD) \
|
2019-01-02 13:40:02 -05:00
|
|
|
-DFREE_SLABS_QUARANTINE_RANDOM_LENGTH=$(CONFIG_FREE_SLABS_QUARANTINE_RANDOM_LENGTH) \
|
2019-03-25 14:49:50 -04:00
|
|
|
-DCONFIG_CLASS_REGION_SIZE=$(CONFIG_CLASS_REGION_SIZE) \
|
2019-04-06 20:49:52 -04:00
|
|
|
-DN_ARENA=$(CONFIG_N_ARENA) \
|
2019-04-07 09:06:03 -04:00
|
|
|
-DCONFIG_STATS=$(CONFIG_STATS)
|
2018-11-02 21:35:09 -04:00
|
|
|
|
2018-12-05 02:05:37 -05:00
|
|
|
libhardened_malloc.so: $(OBJECTS)
|
2018-08-21 15:23:22 -04:00
|
|
|
$(CC) $(CFLAGS) $(LDFLAGS) -shared $^ $(LDLIBS) -o $@
|
|
|
|
|
2018-10-07 11:28:50 -04:00
|
|
|
chacha.o: chacha.c chacha.h util.h
|
2020-09-14 05:52:53 -04:00
|
|
|
h_malloc.o: h_malloc.c include/h_malloc.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
|
2020-09-14 05:52:53 -04:00
|
|
|
new.o: new.cc include/h_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
|
|
|
|
|
2019-08-18 02:19:51 -04:00
|
|
|
check: tidy
|
|
|
|
|
2018-10-14 18:01:40 -04:00
|
|
|
tidy:
|
2021-09-30 11:05:47 -04:00
|
|
|
clang-tidy --extra-arg=-std=c11 $(filter %.c,$(SOURCES)) -- $(CPPFLAGS)
|
|
|
|
clang-tidy --extra-arg=-std=c++17 $(filter %.cc,$(SOURCES)) -- $(CPPFLAGS)
|
2018-10-14 18:01:40 -04:00
|
|
|
|
2018-08-21 15:23:22 -04:00
|
|
|
clean:
|
2018-12-05 02:05:37 -05:00
|
|
|
rm -f libhardened_malloc.so $(OBJECTS)
|
2018-10-14 18:01:40 -04:00
|
|
|
|
2020-03-30 19:36:11 -04:00
|
|
|
test: libhardened_malloc.so
|
|
|
|
make -C test/
|
2020-09-19 09:40:41 -04:00
|
|
|
-python3 -m unittest discover --start-directory test/
|
2020-03-30 19:36:11 -04:00
|
|
|
|
|
|
|
.PHONY: check clean tidy test
|