blob: 47597363385316caa80ab11164eb2a57268b16bb [file] [log] [blame]
Mike Frysinger4c331892022-09-13 05:17:08 -04001# Copyright 2012 The ChromiumOS Authors
Elly Jonescd7a9042011-07-22 13:56:51 -04002# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
Kees Cookddb79702017-04-12 16:36:45 -07005BASE_VER=0
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -07006include common.mk
7
Luis Hector Chavezf6423bb2018-10-05 14:20:29 -07008LIBDIR ?= /lib
Jorge Lucangeli Obesdf4bd352012-08-29 19:12:28 -07009PRELOADNAME = libminijailpreload.so
Allen Webbee876072019-02-21 10:56:21 -080010PRELOADPATH = "$(LIBDIR)/$(PRELOADNAME)"
11CPPFLAGS += -DPRELOADPATH='$(PRELOADPATH)'
12
Mike Frysingercc061ab2021-10-29 12:53:16 -040013# We don't build static libs by default.
14BUILD_STATIC_LIBS ?= no
15
Allen Webbee876072019-02-21 10:56:21 -080016# Defines the pivot root path used by the minimalistic-mountns profile.
17DEFAULT_PIVOT_ROOT ?= /var/empty
18CPPFLAGS += -DDEFAULT_PIVOT_ROOT='"$(DEFAULT_PIVOT_ROOT)"'
Elly Jonescd7a9042011-07-22 13:56:51 -040019
Jorge Lucangeli Obes7da1f2f2022-07-20 19:33:09 -040020# These are configurable strictness settings. Not every use case for Minijail
21# has the same requirements.
22
23# Allow seccomp to fail without a warning. You probably don't want this.
Jorge Lucangeli Obes6a600a42017-04-07 15:53:06 -040024ifeq ($(USE_seccomp),no)
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070025CPPFLAGS += -DUSE_SECCOMP_SOFTFAIL
Utkarsh Sanghi0ef8a662014-08-18 15:50:11 -070026endif
Lei Zhangeee31552012-10-17 21:27:10 -070027
Jorge Lucangeli Obes7da1f2f2022-07-20 19:33:09 -040028# Prevent Minijail configuration files from residing in a noexec
29# filesystem.
30#
31# The rationale here is that a configuration file that controls how a program
32# executes should be subject to the same restrictions as the executable it
33# controls. In essence, a configuration file should be considered to have as
34# much power as an executable. Files can only be executed from filesystems *not*
35# mounted as noexec, so configuration files should not reside in noexec
36# filesystems.
37#
38# For example, on ChromeOS executable filesystems are mounted read-only. Noexec
39# filesystems are allowed to be mounted read-write. If a configuration file
40# were allowed to reside in a noexec filesystem, an attacker would be able to
41# influence how a program is executed by modifying the configuration file.
Zi Lina9e72262022-01-11 03:22:21 +000042BLOCK_NOEXEC_CONF ?= no
43ifeq ($(BLOCK_NOEXEC_CONF),yes)
44CPPFLAGS += -DBLOCK_NOEXEC_CONF
45endif
46
Jorge Lucangeli Obes7da1f2f2022-07-20 19:33:09 -040047# Prevent Minijail configuration files from residing in a partition different
48# from the partition mounted at /. This is primarily used in ChromeOS.
Zi Lina9e72262022-01-11 03:22:21 +000049ENFORCE_ROOTFS_CONF ?= no
50ifeq ($(ENFORCE_ROOTFS_CONF),yes)
51CPPFLAGS += -DENFORCE_ROOTFS_CONF
52endif
53
Mike Frysinger916c6c32018-09-27 14:17:53 -040054# Allow people to use -L and related flags.
55ALLOW_DEBUG_LOGGING ?= yes
56ifeq ($(ALLOW_DEBUG_LOGGING),yes)
57CPPFLAGS += -DALLOW_DEBUG_LOGGING
Adrian Ratiu8ef61252021-06-08 03:46:24 +030058ifeq ($(SECCOMP_DEFAULT_RET_LOG),yes)
59CPPFLAGS += -DSECCOMP_DEFAULT_RET_LOG
60endif
Mike Frysinger916c6c32018-09-27 14:17:53 -040061endif
62
Jorge Lucangeli Obesa8eef8b2022-07-20 19:20:06 -040063# Prevent Minijail from following symlinks when performing bind mounts.
64# BINDMOUNT_ALLOWED_PREFIXES allows some flexibility. This is especially useful
65# for directories that are not normally modifiable by non-root users.
66# If a process can modify these directories, they probably don't need to mess
67# with Minijail bind mounts to gain root privileges.
68BINDMOUNT_ALLOWED_PREFIXES ?= /dev,/sys
69CPPFLAGS += -DBINDMOUNT_ALLOWED_PREFIXES='"$(BINDMOUNT_ALLOWED_PREFIXES)"'
70BLOCK_SYMLINKS_IN_BINDMOUNT_PATHS ?= no
71ifeq ($(BLOCK_SYMLINKS_IN_BINDMOUNT_PATHS),yes)
72CPPFLAGS += -DBLOCK_SYMLINKS_IN_BINDMOUNT_PATHS
73endif
74
Ryan Borzellob12f5672022-08-19 22:48:06 +000075# Prevents symlinks from being followed in the /tmp folder.
76# Symlinks could be followed to modify arbitrary files when a process
77# had access to the /tmp folder.
78BLOCK_SYMLINKS_IN_NONINIT_MOUNTNS_TMP ?= no
79ifeq ($(BLOCK_SYMLINKS_IN_NONINIT_MOUNTNS_TMP),yes)
80CPPFLAGS += -DBLOCK_SYMLINKS_IN_NONINIT_MOUNTNS_TMP
81endif
82
Luis Hector Chavezdaa03712017-09-06 08:10:33 -070083ifeq ($(USE_ASAN),yes)
Luis Héctor Chávez4baeafa2021-01-03 05:47:13 -080084CPPFLAGS += -fsanitize=address -fno-omit-frame-pointer
85LDFLAGS += -fsanitize=address -fno-omit-frame-pointer
Luis Hector Chavezdaa03712017-09-06 08:10:33 -070086USE_EXIT_ON_DIE = yes
87endif
88
89# Setting this flag can be useful for both AddressSanitizer builds and running
90# fuzzing tools, which do not expect crashes on gracefully-handled malformed
91# inputs.
92ifeq ($(USE_EXIT_ON_DIE),yes)
93CPPFLAGS += -DUSE_EXIT_ON_DIE
94endif
95
Nicole Anderson-Aubcc8cfd2020-11-10 20:33:27 +000096# Setting this flag allows duplicate syscalls definitions for seccomp filters.
97ifeq ($(ALLOW_DUPLICATE_SYSCALLS),yes)
98CPPFLAGS += -DALLOW_DUPLICATE_SYSCALLS
99endif
100
Mike Frysingere131e132017-10-04 13:27:55 -0400101MJ_COMMON_FLAGS = -Wunused-parameter -Wextra -Wno-missing-field-initializers
102CFLAGS += $(MJ_COMMON_FLAGS)
103CXXFLAGS += $(MJ_COMMON_FLAGS)
Jorge Lucangeli Obesce2c3ff2017-02-01 18:04:36 -0500104
Mike Frysinger43c54d72021-10-25 14:16:02 -0400105# Dependencies that all gtest based unittests should have.
106UNITTEST_LIBS := -lcap
107UNITTEST_DEPS := testrunner.o test_util.o
108
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500109USE_SYSTEM_GTEST ?= no
110ifeq ($(USE_SYSTEM_GTEST),no)
Mike Frysingere1f046a2017-10-04 13:27:18 -0400111GTEST_CXXFLAGS := -std=gnu++14
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500112GTEST_LIBS := gtest.a
Mike Frysinger43c54d72021-10-25 14:16:02 -0400113UNITTEST_DEPS += $(GTEST_LIBS)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500114else
Allen Webbf8c21ea2019-06-14 09:24:10 -0700115GTEST_CXXFLAGS := $(shell gtest-config --cxxflags 2>/dev/null || \
116 echo "-pthread")
117GTEST_LIBS := $(shell gtest-config --libs 2>/dev/null || \
118 echo "-lgtest -pthread -lpthread")
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500119endif
Mike Frysinger43c54d72021-10-25 14:16:02 -0400120UNITTEST_LIBS += $(GTEST_LIBS)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500121
Jorge Lucangeli Obes0b208772017-04-19 14:15:46 -0400122CORE_OBJECT_FILES := libminijail.o syscall_filter.o signal_handler.o \
Ben Scarlatod7e6e682022-06-30 03:27:30 +0000123 bpf.o landlock_util.o util.o system.o syscall_wrapper.o \
Zi Lin5158f552021-10-27 00:55:52 +0000124 config_parser.o libconstants.gen.o libsyscalls.gen.o
Mike Frysinger43c54d72021-10-25 14:16:02 -0400125UNITTEST_DEPS += $(CORE_OBJECT_FILES)
Jorge Lucangeli Obes0b208772017-04-19 14:15:46 -0400126
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700127all: CC_BINARY(minijail0) CC_LIBRARY(libminijail.so) \
Zach Reizner2a93cee2019-02-01 15:13:09 -0800128 CC_LIBRARY(libminijailpreload.so)
Elly Jonescd7a9042011-07-22 13:56:51 -0400129
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -0400130parse_seccomp_policy: CXX_BINARY(parse_seccomp_policy)
Luis Hector Chavezcf504ca2020-01-30 21:39:13 -0800131dump_constants: CXX_STATIC_BINARY(dump_constants)
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -0400132
Jorge Lucangeli Obese0c5a762017-02-02 15:17:08 -0500133tests: TEST(CXX_BINARY(libminijail_unittest)) \
Mike Frysinger4d2a81e2018-01-22 16:43:33 -0500134 TEST(CXX_BINARY(minijail0_cli_unittest)) \
Mike Frysinger0b5cffa2017-08-15 18:06:18 -0400135 TEST(CXX_BINARY(syscall_filter_unittest)) \
Mike Frysinger32c39922018-01-17 17:09:54 -0500136 TEST(CXX_BINARY(system_unittest)) \
137 TEST(CXX_BINARY(util_unittest)) \
Zi Lin138761f2022-02-09 23:35:07 +0000138 TEST(CXX_BINARY(config_parser_unittest))
Will Drewry6ac91122011-10-21 16:38:58 -0500139
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700140CC_BINARY(minijail0): LDLIBS += -lcap -ldl
Mike Frysinger5ef22ca2018-01-20 13:42:10 -0500141CC_BINARY(minijail0): $(CORE_OBJECT_FILES) \
142 elfparse.o minijail0.o minijail0_cli.o
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700143clean: CLEAN(minijail0)
Elly Jonescd7a9042011-07-22 13:56:51 -0400144
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500145
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700146CC_LIBRARY(libminijail.so): LDLIBS += -lcap
Jorge Lucangeli Obes0b208772017-04-19 14:15:46 -0400147CC_LIBRARY(libminijail.so): $(CORE_OBJECT_FILES)
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700148clean: CLEAN(libminijail.so)
Ben Chan45397012011-08-23 08:15:03 -0700149
Stephen Barber27c58232019-12-09 17:20:28 -0800150CC_STATIC_LIBRARY(libminijail.pic.a): $(CORE_OBJECT_FILES)
151CC_STATIC_LIBRARY(libminijail.pie.a): $(CORE_OBJECT_FILES)
152clean: CLEAN(libminijail.*.a)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500153
Mike Frysingercc061ab2021-10-29 12:53:16 -0400154ifeq ($(BUILD_STATIC_LIBS),yes)
155all: CC_STATIC_LIBRARY(libminijail.pic.a) CC_STATIC_LIBRARY(libminijail.pie.a)
156endif
157
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500158CXX_BINARY(libminijail_unittest): CXXFLAGS += -Wno-write-strings \
159 $(GTEST_CXXFLAGS)
Mike Frysinger43c54d72021-10-25 14:16:02 -0400160CXX_BINARY(libminijail_unittest): LDLIBS += $(UNITTEST_LIBS)
161CXX_BINARY(libminijail_unittest): $(UNITTEST_DEPS) libminijail_unittest.o
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700162clean: CLEAN(libminijail_unittest)
Will Drewrydecdfdc2011-09-27 15:13:54 -0500163
Luis Hector Chavez9acba452018-10-11 10:13:25 -0700164TEST(CXX_BINARY(libminijail_unittest)): CC_LIBRARY(libminijailpreload.so)
165
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500166
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700167CC_LIBRARY(libminijailpreload.so): LDLIBS += -lcap -ldl
Jorge Lucangeli Obes0b208772017-04-19 14:15:46 -0400168CC_LIBRARY(libminijailpreload.so): libminijailpreload.o $(CORE_OBJECT_FILES)
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700169clean: CLEAN(libminijailpreload.so)
Elly Jonescd7a9042011-07-22 13:56:51 -0400170
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500171
Mike Frysinger4d2a81e2018-01-22 16:43:33 -0500172CXX_BINARY(minijail0_cli_unittest): CXXFLAGS += $(GTEST_CXXFLAGS)
Mike Frysinger43c54d72021-10-25 14:16:02 -0400173CXX_BINARY(minijail0_cli_unittest): LDLIBS += $(UNITTEST_LIBS)
174CXX_BINARY(minijail0_cli_unittest): $(UNITTEST_DEPS) minijail0_cli_unittest.o \
175 minijail0_cli.o elfparse.o
Mike Frysinger4d2a81e2018-01-22 16:43:33 -0500176clean: CLEAN(minijail0_cli_unittest)
177
178
Zi Lin5158f552021-10-27 00:55:52 +0000179CXX_BINARY(config_parser_unittest): CXXFLAGS += $(GTEST_CXXFLAGS)
180CXX_BINARY(config_parser_unittest): LDLIBS += $(UNITTEST_LIBS)
181CXX_BINARY(config_parser_unittest): $(UNITTEST_DEPS) config_parser_unittest.o
182clean: CLEAN(config_parser_unittest)
183
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500184CXX_BINARY(syscall_filter_unittest): CXXFLAGS += -Wno-write-strings \
185 $(GTEST_CXXFLAGS)
Mike Frysinger43c54d72021-10-25 14:16:02 -0400186CXX_BINARY(syscall_filter_unittest): LDLIBS += $(UNITTEST_LIBS)
187CXX_BINARY(syscall_filter_unittest): $(UNITTEST_DEPS) syscall_filter_unittest.o
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700188clean: CLEAN(syscall_filter_unittest)
Jorge Lucangeli Obesfc8ab532012-03-20 10:14:31 -0700189
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500190
Mike Frysinger0b5cffa2017-08-15 18:06:18 -0400191CXX_BINARY(system_unittest): CXXFLAGS += $(GTEST_CXXFLAGS)
Mike Frysinger43c54d72021-10-25 14:16:02 -0400192CXX_BINARY(system_unittest): LDLIBS += $(UNITTEST_LIBS)
193CXX_BINARY(system_unittest): $(UNITTEST_DEPS) system_unittest.o
Mike Frysinger0b5cffa2017-08-15 18:06:18 -0400194clean: CLEAN(system_unittest)
195
196
Mike Frysinger32c39922018-01-17 17:09:54 -0500197CXX_BINARY(util_unittest): CXXFLAGS += $(GTEST_CXXFLAGS)
Mike Frysinger43c54d72021-10-25 14:16:02 -0400198CXX_BINARY(util_unittest): LDLIBS += $(UNITTEST_LIBS)
199CXX_BINARY(util_unittest): $(UNITTEST_DEPS) util_unittest.o
Mike Frysinger32c39922018-01-17 17:09:54 -0500200clean: CLEAN(util_unittest)
201
202
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -0400203CXX_BINARY(parse_seccomp_policy): parse_seccomp_policy.o syscall_filter.o \
Ben Scarlatod7e6e682022-06-30 03:27:30 +0000204 bpf.o landlock_util.o util.o libconstants.gen.o libsyscalls.gen.o
Jorge Lucangeli Obesa1f4e0a2017-09-05 10:06:55 -0400205clean: CLEAN(parse_seccomp_policy)
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -0400206
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500207
Luis Hector Chavezcf504ca2020-01-30 21:39:13 -0800208# Compiling dump_constants as a static executable makes it easy to run under
209# qemu-user, which in turn simplifies cross-compiling bpf policies.
210CXX_STATIC_BINARY(dump_constants): dump_constants.o \
Luis Hector Chavezf7b20182018-10-28 21:39:32 -0700211 libconstants.gen.o libsyscalls.gen.o
212clean: CLEAN(dump_constants)
213
214
Luis Hector Chavezcf504ca2020-01-30 21:39:13 -0800215constants.json: CXX_STATIC_BINARY(dump_constants)
Luis Hector Chavezf7b20182018-10-28 21:39:32 -0700216 ./dump_constants > $@
217clean: CLEANFILE(constants.json)
218
219
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700220libsyscalls.gen.o: CPPFLAGS += -I$(SRC)
Jorge Lucangeli Obesfc8ab532012-03-20 10:14:31 -0700221
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700222libsyscalls.gen.o.depends: libsyscalls.gen.c
Lee Campbell1e4fc6a2014-06-06 17:40:02 -0700223
Will Drewry32ac9f52011-08-18 21:36:27 -0500224# Only regenerate libsyscalls.gen.c if the Makefile or header changes.
225# NOTE! This will not detect if the file is not appropriate for the target.
Mike Frysingerd01c6022021-10-27 01:42:59 -0400226libsyscalls.gen.c: $(SRC)/libsyscalls.h $(SRC)/Makefile
Zi Lin138761f2022-02-09 23:35:07 +0000227 @/bin/echo -e "GEN $(subst $(SRC)/,,$<) -> $@"
Dan Willemsen2acbec52017-09-14 17:28:36 -0700228 $(QUIET)CC="$(CC)" $(SRC)/gen_syscalls.sh "$@"
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700229clean: CLEAN(libsyscalls.gen.c)
Will Drewry32ac9f52011-08-18 21:36:27 -0500230
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700231$(eval $(call add_object_rules,libsyscalls.gen.o,CC,c,CFLAGS))
Luis Hector Chavez40b25742013-09-22 19:44:06 -0700232
233libconstants.gen.o: CPPFLAGS += -I$(SRC)
234
235libconstants.gen.o.depends: libconstants.gen.c
236
237# Only regenerate libconstants.gen.c if the Makefile or header changes.
238# NOTE! This will not detect if the file is not appropriate for the target.
Mike Frysingerd01c6022021-10-27 01:42:59 -0400239libconstants.gen.c: $(SRC)/libconstants.h $(SRC)/Makefile
Zi Lin138761f2022-02-09 23:35:07 +0000240 @/bin/echo -e "GEN $(subst $(SRC)/,,$<) -> $@"
Dan Willemsen2acbec52017-09-14 17:28:36 -0700241 $(QUIET)CC="$(CC)" $(SRC)/gen_constants.sh "$@"
Luis Hector Chavez40b25742013-09-22 19:44:06 -0700242clean: CLEAN(libconstants.gen.c)
243
244$(eval $(call add_object_rules,libconstants.gen.o,CC,c,CFLAGS))
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500245
246
247################################################################################
248# Google Test
249
250ifeq ($(USE_SYSTEM_GTEST),no)
251# Points to the root of Google Test, relative to where this file is.
252# Remember to tweak this if you move this file.
Mike Frysingerfd2ce622021-10-14 11:41:12 -0400253GTEST_DIR = googletest-release-1.11.0/googletest
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500254
255# Flags passed to the preprocessor.
256# Set Google Test's header directory as a system directory, such that
257# the compiler doesn't generate warnings in Google Test headers.
258CPPFLAGS += -isystem $(GTEST_DIR)/include
259
260# Flags passed to the C++ compiler.
Jorge Lucangeli Obese0c5a762017-02-02 15:17:08 -0500261GTEST_CXXFLAGS += -pthread
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500262
263# All Google Test headers. Usually you shouldn't change this
264# definition.
265GTEST_HEADERS = $(GTEST_DIR)/include/gtest/*.h \
266 $(GTEST_DIR)/include/gtest/internal/*.h
267
268# House-keeping build targets.
269clean: clean_gtest
270
271clean_gtest:
Mike Frysingerd01c6022021-10-27 01:42:59 -0400272 $(QUIET)rm -f gtest.a gtest_main.a *.o
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500273
274# Builds gtest.a and gtest_main.a.
275
276# Usually you shouldn't tweak such internal variables, indicated by a
277# trailing _.
278GTEST_SRCS_ = $(GTEST_DIR)/src/*.cc $(GTEST_DIR)/src/*.h $(GTEST_HEADERS)
279
280# For simplicity and to avoid depending on Google Test's
281# implementation details, the dependencies specified below are
282# conservative and not optimized. This is fine as Google Test
283# compiles fast and for ordinary users its source rarely changes.
284gtest-all.o : $(GTEST_SRCS_)
285 $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) $(GTEST_CXXFLAGS) -c \
286 $(GTEST_DIR)/src/gtest-all.cc -o $@
287
288gtest_main.o : $(GTEST_SRCS_)
289 $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) $(GTEST_CXXFLAGS) -c \
290 $(GTEST_DIR)/src/gtest_main.cc -o $@
291
292gtest.a : gtest-all.o
293 $(AR) $(ARFLAGS) $@ $^
294
295gtest_main.a : gtest-all.o gtest_main.o
296 $(AR) $(ARFLAGS) $@ $^
297
298endif
299################################################################################