blob: a7c4357c3448e830d11beea0b7334e643cfd1c3c [file] [log] [blame]
Jorge Lucangeli Obesfc8ab532012-03-20 10:14:31 -07001# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
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
13# Defines the pivot root path used by the minimalistic-mountns profile.
14DEFAULT_PIVOT_ROOT ?= /var/empty
15CPPFLAGS += -DDEFAULT_PIVOT_ROOT='"$(DEFAULT_PIVOT_ROOT)"'
Elly Jonescd7a9042011-07-22 13:56:51 -040016
Jorge Lucangeli Obes6a600a42017-04-07 15:53:06 -040017ifeq ($(USE_seccomp),no)
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070018CPPFLAGS += -DUSE_SECCOMP_SOFTFAIL
Utkarsh Sanghi0ef8a662014-08-18 15:50:11 -070019endif
Lei Zhangeee31552012-10-17 21:27:10 -070020
Mike Frysinger916c6c32018-09-27 14:17:53 -040021# Allow people to use -L and related flags.
22ALLOW_DEBUG_LOGGING ?= yes
23ifeq ($(ALLOW_DEBUG_LOGGING),yes)
24CPPFLAGS += -DALLOW_DEBUG_LOGGING
25endif
26
Luis Hector Chavezdaa03712017-09-06 08:10:33 -070027ifeq ($(USE_ASAN),yes)
28CPPFLAGS += -fsanitize=address
29LDFLAGS += -fsanitize=address
30USE_EXIT_ON_DIE = yes
31endif
32
33# Setting this flag can be useful for both AddressSanitizer builds and running
34# fuzzing tools, which do not expect crashes on gracefully-handled malformed
35# inputs.
36ifeq ($(USE_EXIT_ON_DIE),yes)
37CPPFLAGS += -DUSE_EXIT_ON_DIE
38endif
39
Mike Frysingere131e132017-10-04 13:27:55 -040040MJ_COMMON_FLAGS = -Wunused-parameter -Wextra -Wno-missing-field-initializers
41CFLAGS += $(MJ_COMMON_FLAGS)
42CXXFLAGS += $(MJ_COMMON_FLAGS)
Jorge Lucangeli Obesce2c3ff2017-02-01 18:04:36 -050043
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050044USE_SYSTEM_GTEST ?= no
45ifeq ($(USE_SYSTEM_GTEST),no)
Mike Frysingere1f046a2017-10-04 13:27:18 -040046GTEST_CXXFLAGS := -std=gnu++14
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050047GTEST_LIBS := gtest.a
48else
Allen Webbf8c21ea2019-06-14 09:24:10 -070049GTEST_CXXFLAGS := $(shell gtest-config --cxxflags 2>/dev/null || \
50 echo "-pthread")
51GTEST_LIBS := $(shell gtest-config --libs 2>/dev/null || \
52 echo "-lgtest -pthread -lpthread")
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050053endif
54
Jorge Lucangeli Obes0b208772017-04-19 14:15:46 -040055CORE_OBJECT_FILES := libminijail.o syscall_filter.o signal_handler.o \
56 bpf.o util.o system.o syscall_wrapper.o \
57 libconstants.gen.o libsyscalls.gen.o
58
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070059all: CC_BINARY(minijail0) CC_LIBRARY(libminijail.so) \
Zach Reizner2a93cee2019-02-01 15:13:09 -080060 CC_LIBRARY(libminijailpreload.so)
Elly Jonescd7a9042011-07-22 13:56:51 -040061
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -040062parse_seccomp_policy: CXX_BINARY(parse_seccomp_policy)
Luis Hector Chavezcf504ca2020-01-30 21:39:13 -080063dump_constants: CXX_STATIC_BINARY(dump_constants)
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -040064
Jorge Lucangeli Obese0c5a762017-02-02 15:17:08 -050065tests: TEST(CXX_BINARY(libminijail_unittest)) \
Mike Frysinger4d2a81e2018-01-22 16:43:33 -050066 TEST(CXX_BINARY(minijail0_cli_unittest)) \
Mike Frysinger0b5cffa2017-08-15 18:06:18 -040067 TEST(CXX_BINARY(syscall_filter_unittest)) \
Mike Frysinger32c39922018-01-17 17:09:54 -050068 TEST(CXX_BINARY(system_unittest)) \
69 TEST(CXX_BINARY(util_unittest)) \
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050070
Will Drewry6ac91122011-10-21 16:38:58 -050071
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070072CC_BINARY(minijail0): LDLIBS += -lcap -ldl
Mike Frysinger5ef22ca2018-01-20 13:42:10 -050073CC_BINARY(minijail0): $(CORE_OBJECT_FILES) \
74 elfparse.o minijail0.o minijail0_cli.o
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070075clean: CLEAN(minijail0)
Elly Jonescd7a9042011-07-22 13:56:51 -040076
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050077
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070078CC_LIBRARY(libminijail.so): LDLIBS += -lcap
Jorge Lucangeli Obes0b208772017-04-19 14:15:46 -040079CC_LIBRARY(libminijail.so): $(CORE_OBJECT_FILES)
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070080clean: CLEAN(libminijail.so)
Ben Chan45397012011-08-23 08:15:03 -070081
Stephen Barber27c58232019-12-09 17:20:28 -080082CC_STATIC_LIBRARY(libminijail.pic.a): $(CORE_OBJECT_FILES)
83CC_STATIC_LIBRARY(libminijail.pie.a): $(CORE_OBJECT_FILES)
84clean: CLEAN(libminijail.*.a)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050085
86CXX_BINARY(libminijail_unittest): CXXFLAGS += -Wno-write-strings \
87 $(GTEST_CXXFLAGS)
Luis Hector Chavez114a9302017-09-05 20:36:58 -070088CXX_BINARY(libminijail_unittest): LDLIBS += -lcap $(GTEST_LIBS)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050089ifeq ($(USE_SYSTEM_GTEST),no)
Luis Hector Chavez114a9302017-09-05 20:36:58 -070090CXX_BINARY(libminijail_unittest): $(GTEST_LIBS)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050091endif
Luis Hector Chavez114a9302017-09-05 20:36:58 -070092CXX_BINARY(libminijail_unittest): libminijail_unittest.o $(CORE_OBJECT_FILES) \
93 testrunner.o
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070094clean: CLEAN(libminijail_unittest)
Will Drewrydecdfdc2011-09-27 15:13:54 -050095
Luis Hector Chavez9acba452018-10-11 10:13:25 -070096TEST(CXX_BINARY(libminijail_unittest)): CC_LIBRARY(libminijailpreload.so)
97
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -050098
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -070099CC_LIBRARY(libminijailpreload.so): LDLIBS += -lcap -ldl
Jorge Lucangeli Obes0b208772017-04-19 14:15:46 -0400100CC_LIBRARY(libminijailpreload.so): libminijailpreload.o $(CORE_OBJECT_FILES)
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700101clean: CLEAN(libminijailpreload.so)
Elly Jonescd7a9042011-07-22 13:56:51 -0400102
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500103
Mike Frysinger4d2a81e2018-01-22 16:43:33 -0500104CXX_BINARY(minijail0_cli_unittest): CXXFLAGS += $(GTEST_CXXFLAGS)
105CXX_BINARY(minijail0_cli_unittest): LDLIBS += -lcap $(GTEST_LIBS)
106ifeq ($(USE_SYSTEM_GTEST),no)
107CXX_BINARY(minijail0_cli_unittest): $(GTEST_LIBS)
108endif
109CXX_BINARY(minijail0_cli_unittest): minijail0_cli_unittest.o \
110 $(CORE_OBJECT_FILES) minijail0_cli.o elfparse.o testrunner.o
111clean: CLEAN(minijail0_cli_unittest)
112
113
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500114CXX_BINARY(syscall_filter_unittest): CXXFLAGS += -Wno-write-strings \
115 $(GTEST_CXXFLAGS)
Luis Hector Chavez114a9302017-09-05 20:36:58 -0700116CXX_BINARY(syscall_filter_unittest): LDLIBS += -lcap $(GTEST_LIBS)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500117ifeq ($(USE_SYSTEM_GTEST),no)
Luis Hector Chavez114a9302017-09-05 20:36:58 -0700118CXX_BINARY(syscall_filter_unittest): $(GTEST_LIBS)
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500119endif
120CXX_BINARY(syscall_filter_unittest): syscall_filter_unittest.o \
Luis Hector Chavez114a9302017-09-05 20:36:58 -0700121 $(CORE_OBJECT_FILES) testrunner.o
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700122clean: CLEAN(syscall_filter_unittest)
Jorge Lucangeli Obesfc8ab532012-03-20 10:14:31 -0700123
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500124
Mike Frysinger0b5cffa2017-08-15 18:06:18 -0400125CXX_BINARY(system_unittest): CXXFLAGS += $(GTEST_CXXFLAGS)
Luis Hector Chavez114a9302017-09-05 20:36:58 -0700126CXX_BINARY(system_unittest): LDLIBS += -lcap $(GTEST_LIBS)
Mike Frysinger0b5cffa2017-08-15 18:06:18 -0400127ifeq ($(USE_SYSTEM_GTEST),no)
Luis Hector Chavez114a9302017-09-05 20:36:58 -0700128CXX_BINARY(system_unittest): $(GTEST_LIBS)
Mike Frysinger0b5cffa2017-08-15 18:06:18 -0400129endif
Luis Hector Chavez114a9302017-09-05 20:36:58 -0700130CXX_BINARY(system_unittest): system_unittest.o \
131 $(CORE_OBJECT_FILES) testrunner.o
Mike Frysinger0b5cffa2017-08-15 18:06:18 -0400132clean: CLEAN(system_unittest)
133
134
Mike Frysinger32c39922018-01-17 17:09:54 -0500135CXX_BINARY(util_unittest): CXXFLAGS += $(GTEST_CXXFLAGS)
136CXX_BINARY(util_unittest): LDLIBS += -lcap $(GTEST_LIBS)
137ifeq ($(USE_SYSTEM_GTEST),no)
138CXX_BINARY(util_unittest): $(GTEST_LIBS)
139endif
140CXX_BINARY(util_unittest): util_unittest.o \
141 $(CORE_OBJECT_FILES) testrunner.o
142clean: CLEAN(util_unittest)
143
144
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -0400145CXX_BINARY(parse_seccomp_policy): parse_seccomp_policy.o syscall_filter.o \
146 bpf.o util.o libconstants.gen.o libsyscalls.gen.o
Jorge Lucangeli Obesa1f4e0a2017-09-05 10:06:55 -0400147clean: CLEAN(parse_seccomp_policy)
Jorge Lucangeli Obesf16d6d12016-09-29 20:25:27 -0400148
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500149
Luis Hector Chavezcf504ca2020-01-30 21:39:13 -0800150# Compiling dump_constants as a static executable makes it easy to run under
151# qemu-user, which in turn simplifies cross-compiling bpf policies.
152CXX_STATIC_BINARY(dump_constants): dump_constants.o \
Luis Hector Chavezf7b20182018-10-28 21:39:32 -0700153 libconstants.gen.o libsyscalls.gen.o
154clean: CLEAN(dump_constants)
155
156
Luis Hector Chavezcf504ca2020-01-30 21:39:13 -0800157constants.json: CXX_STATIC_BINARY(dump_constants)
Luis Hector Chavezf7b20182018-10-28 21:39:32 -0700158 ./dump_constants > $@
159clean: CLEANFILE(constants.json)
160
161
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700162libsyscalls.gen.o: CPPFLAGS += -I$(SRC)
Jorge Lucangeli Obesfc8ab532012-03-20 10:14:31 -0700163
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700164libsyscalls.gen.o.depends: libsyscalls.gen.c
Lee Campbell1e4fc6a2014-06-06 17:40:02 -0700165
Will Drewry32ac9f52011-08-18 21:36:27 -0500166# Only regenerate libsyscalls.gen.c if the Makefile or header changes.
167# NOTE! This will not detect if the file is not appropriate for the target.
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700168libsyscalls.gen.c: $(SRC)/Makefile $(SRC)/libsyscalls.h
Jorge Lucangeli Obesae57f092016-11-23 15:04:55 -0500169 @printf "Generating target-arch specific $@...\n"
Dan Willemsen2acbec52017-09-14 17:28:36 -0700170 $(QUIET)CC="$(CC)" $(SRC)/gen_syscalls.sh "$@"
Jorge Lucangeli Obesae57f092016-11-23 15:04:55 -0500171 @printf "$@ done.\n"
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700172clean: CLEAN(libsyscalls.gen.c)
Will Drewry32ac9f52011-08-18 21:36:27 -0500173
Jorge Lucangeli Obesbc9dc1c2014-08-25 09:12:36 -0700174$(eval $(call add_object_rules,libsyscalls.gen.o,CC,c,CFLAGS))
Luis Hector Chavez40b25742013-09-22 19:44:06 -0700175
176libconstants.gen.o: CPPFLAGS += -I$(SRC)
177
178libconstants.gen.o.depends: libconstants.gen.c
179
180# Only regenerate libconstants.gen.c if the Makefile or header changes.
181# NOTE! This will not detect if the file is not appropriate for the target.
Luis Hector Chavez40b25742013-09-22 19:44:06 -0700182libconstants.gen.c: $(SRC)/Makefile $(SRC)/libconstants.h
Jorge Lucangeli Obesae57f092016-11-23 15:04:55 -0500183 @printf "Generating target-arch specific $@...\n"
Dan Willemsen2acbec52017-09-14 17:28:36 -0700184 $(QUIET)CC="$(CC)" $(SRC)/gen_constants.sh "$@"
Jorge Lucangeli Obesae57f092016-11-23 15:04:55 -0500185 @printf "$@ done.\n"
Luis Hector Chavez40b25742013-09-22 19:44:06 -0700186clean: CLEAN(libconstants.gen.c)
187
188$(eval $(call add_object_rules,libconstants.gen.o,CC,c,CFLAGS))
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500189
190
191################################################################################
192# Google Test
193
194ifeq ($(USE_SYSTEM_GTEST),no)
195# Points to the root of Google Test, relative to where this file is.
196# Remember to tweak this if you move this file.
197GTEST_DIR = googletest-release-1.8.0/googletest
198
199# Flags passed to the preprocessor.
200# Set Google Test's header directory as a system directory, such that
201# the compiler doesn't generate warnings in Google Test headers.
202CPPFLAGS += -isystem $(GTEST_DIR)/include
203
204# Flags passed to the C++ compiler.
Jorge Lucangeli Obese0c5a762017-02-02 15:17:08 -0500205GTEST_CXXFLAGS += -pthread
Jorge Lucangeli Obes9bd316b2017-01-26 17:21:16 -0500206
207# All Google Test headers. Usually you shouldn't change this
208# definition.
209GTEST_HEADERS = $(GTEST_DIR)/include/gtest/*.h \
210 $(GTEST_DIR)/include/gtest/internal/*.h
211
212# House-keeping build targets.
213clean: clean_gtest
214
215clean_gtest:
216 rm -f gtest.a gtest_main.a *.o
217
218# Builds gtest.a and gtest_main.a.
219
220# Usually you shouldn't tweak such internal variables, indicated by a
221# trailing _.
222GTEST_SRCS_ = $(GTEST_DIR)/src/*.cc $(GTEST_DIR)/src/*.h $(GTEST_HEADERS)
223
224# For simplicity and to avoid depending on Google Test's
225# implementation details, the dependencies specified below are
226# conservative and not optimized. This is fine as Google Test
227# compiles fast and for ordinary users its source rarely changes.
228gtest-all.o : $(GTEST_SRCS_)
229 $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) $(GTEST_CXXFLAGS) -c \
230 $(GTEST_DIR)/src/gtest-all.cc -o $@
231
232gtest_main.o : $(GTEST_SRCS_)
233 $(CXX) $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) $(GTEST_CXXFLAGS) -c \
234 $(GTEST_DIR)/src/gtest_main.cc -o $@
235
236gtest.a : gtest-all.o
237 $(AR) $(ARFLAGS) $@ $^
238
239gtest_main.a : gtest-all.o gtest_main.o
240 $(AR) $(ARFLAGS) $@ $^
241
242endif
243################################################################################