Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / native_client_sdk / src / tools / common.mk
blob1dbc3d69e44f59781f06d6895e123bcee6a44fca
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
6 # GNU Make based build file. For details on GNU Make see:
7 # http://www.gnu.org/software/make/manual/make.html
11 # Toolchain
13 # By default the VALID_TOOLCHAINS list contains pnacl, newlib and glibc. If
14 # your project only builds in one or the other then this should be overridden
15 # accordingly.
17 ifneq ($(ENABLE_BIONIC),)
18 ALL_TOOLCHAINS ?= pnacl newlib glibc clang-newlib bionic
19 else
20 ALL_TOOLCHAINS ?= pnacl newlib glibc clang-newlib
21 endif
23 VALID_TOOLCHAINS ?= $(ALL_TOOLCHAINS)
24 TOOLCHAIN ?= $(word 1,$(VALID_TOOLCHAINS))
27 # Top Make file, which we want to trigger a rebuild on if it changes
29 TOP_MAKE := $(word 1,$(MAKEFILE_LIST))
33 # Figure out which OS we are running on.
35 GETOS := python $(NACL_SDK_ROOT)/tools/getos.py
36 NACL_CONFIG := python $(NACL_SDK_ROOT)/tools/nacl_config.py
37 FIXDEPS := python $(NACL_SDK_ROOT)/tools/fix_deps.py -c
38 OSNAME := $(shell $(GETOS))
42 # TOOLCHAIN=all recursively calls this Makefile for all VALID_TOOLCHAINS.
44 ifeq ($(TOOLCHAIN),all)
46 # Define the default target
47 all:
50 # Generate a new MAKE command for each TOOLCHAIN.
52 # Note: We use targets for each toolchain (instead of an explicit recipe) so
53 # each toolchain can be built in parallel.
55 # $1 = Toolchain Name
57 define TOOLCHAIN_RULE
58 TOOLCHAIN_TARGETS += $(1)_TARGET
59 .PHONY: $(1)_TARGET
60 $(1)_TARGET:
61 +$(MAKE) TOOLCHAIN=$(1) $(MAKECMDGOALS)
62 endef
65 # The target for all versions
67 USABLE_TOOLCHAINS=$(filter $(OSNAME) $(ALL_TOOLCHAINS),$(VALID_TOOLCHAINS))
69 ifeq ($(NO_HOST_BUILDS),1)
70 USABLE_TOOLCHAINS:=$(filter-out $(OSNAME),$(USABLE_TOOLCHAINS))
71 endif
73 # Define the toolchain targets for all usable toolchains via the macro.
74 $(foreach tool,$(USABLE_TOOLCHAINS),$(eval $(call TOOLCHAIN_RULE,$(tool))))
76 .PHONY: all clean install
77 all: $(TOOLCHAIN_TARGETS)
78 clean: $(TOOLCHAIN_TARGETS)
79 install: $(TOOLCHAIN_TARGETS)
81 else # TOOLCHAIN=all
84 # Verify we selected a valid toolchain for this example
86 ifeq (,$(findstring $(TOOLCHAIN),$(VALID_TOOLCHAINS)))
88 # Only fail to build if this is a top-level make. When building recursively, we
89 # don't care if an example can't build with this toolchain.
90 ifeq ($(MAKELEVEL),0)
91 $(warning Availbile choices are: $(VALID_TOOLCHAINS))
92 $(error Can not use TOOLCHAIN=$(TOOLCHAIN) on this example.)
93 else
95 # Dummy targets for recursive make with unsupported toolchain...
96 .PHONY: all clean install
97 all:
98 clean:
99 install:
101 endif
103 else # TOOLCHAIN is valid...
106 # Build Configuration
108 # The SDK provides two sets of libraries, Debug and Release. Debug libraries
109 # are compiled without optimizations to make debugging easier. By default
110 # this will build a Release configuration. When debugging via "make debug",
111 # build the debug configuration by default instead.
113 ifneq (,$(findstring debug,$(MAKECMDGOALS)))
114 CONFIG ?= Debug
115 else
116 CONFIG ?= Release
117 endif
121 # Verify we selected a valid configuration for this example.
123 VALID_CONFIGS ?= Debug Release
124 ifeq (,$(findstring $(CONFIG),$(VALID_CONFIGS)))
125 $(warning Availbile choices are: $(VALID_CONFIGS))
126 $(error Can not use CONFIG=$(CONFIG) on this example.)
127 endif
131 # Note for Windows:
132 # The GCC and LLVM toolchains (include the version of Make.exe that comes
133 # with the SDK) expect and are capable of dealing with the '/' seperator.
134 # For this reason, the tools in the SDK, including Makefiles and build scripts
135 # have a preference for POSIX style command-line arguments.
137 # Keep in mind however that the shell is responsible for command-line escaping,
138 # globbing, and variable expansion, so those may change based on which shell
139 # is used. For Cygwin shells this can include automatic and incorrect expansion
140 # of response files (files starting with '@').
142 # Disable DOS PATH warning when using Cygwin based NaCl tools on Windows.
144 ifeq ($(OSNAME),win)
145 # Always use cmd.exe as the shell on Windows. Otherwise Make may try to
146 # search the path for sh.exe. If it is found in a path with a space, the
147 # command will fail.
148 SHELL := cmd.exe
149 CYGWIN ?= nodosfilewarning
150 export CYGWIN
151 endif
155 # If NACL_SDK_ROOT is not already set, then set it relative to this makefile.
157 THIS_MAKEFILE := $(CURDIR)/$(lastword $(MAKEFILE_LIST))
158 NACL_SDK_ROOT ?= $(realpath $(dir $(THIS_MAKEFILE))/..)
162 # Check that NACL_SDK_ROOT is set to a valid location.
163 # We use the existence of tools/oshelpers.py to verify the validity of the SDK
164 # root.
166 ifeq (,$(wildcard $(NACL_SDK_ROOT)/tools/oshelpers.py))
167 $(error NACL_SDK_ROOT is set to an invalid location: $(NACL_SDK_ROOT))
168 endif
172 # If this makefile is part of a valid nacl SDK, but NACL_SDK_ROOT is set
173 # to a different location this is almost certainly a local configuration
174 # error.
176 LOCAL_ROOT := $(realpath $(dir $(THIS_MAKEFILE))/..)
177 ifneq (,$(wildcard $(LOCAL_ROOT)/tools/oshelpers.py))
178 ifneq ($(realpath $(NACL_SDK_ROOT)), $(realpath $(LOCAL_ROOT)))
179 $(error common.mk included from an SDK that does not match the current NACL_SDK_ROOT)
180 endif
181 endif
185 # Alias for standard POSIX file system commands
187 OSHELPERS = python $(NACL_SDK_ROOT)/tools/oshelpers.py
188 WHICH := $(OSHELPERS) which
189 ifdef V
190 RM := $(OSHELPERS) rm
191 CP := $(OSHELPERS) cp
192 MKDIR := $(OSHELPERS) mkdir
193 MV := $(OSHELPERS) mv
194 else
195 RM := @$(OSHELPERS) rm
196 CP := @$(OSHELPERS) cp
197 MKDIR := @$(OSHELPERS) mkdir
198 MV := @$(OSHELPERS) mv
199 endif
204 # Compute path to requested NaCl Toolchain
206 TC_PATH := $(abspath $(NACL_SDK_ROOT)/toolchain)
210 # Check for required minimum SDK version.
211 # A makefile can declare NACL_SDK_VERSION_MIN of the form "<major>.<position>",
212 # where <major> is the major Chromium version number, and <position> is the
213 # Chromium Cr-Commit-Position number. eg. "39.295386".
215 ifdef NACL_SDK_VERSION_MIN
216 VERSION_CHECK:=$(shell $(GETOS) --check-version=$(NACL_SDK_VERSION_MIN) 2>&1)
217 ifneq ($(VERSION_CHECK),)
218 $(error $(VERSION_CHECK))
219 endif
220 endif
224 # The default target
226 # If no targets are specified on the command-line, the first target listed in
227 # the makefile becomes the default target. By convention this is usually called
228 # the 'all' target. Here we leave it blank to be first, but define it later
230 all:
231 .PHONY: all
235 # The install target is used to install built libraries to thier final destination.
236 # By default this is the NaCl SDK 'lib' folder.
238 install:
239 .PHONY: install
241 ifdef SEL_LDR
242 STANDALONE = 1
243 endif
245 OUTBASE ?= .
246 CONFIG_DIR := $(CONFIG)
247 ifdef STANDALONE
248 CONFIG_DIR := standalone_$(CONFIG_DIR)
249 endif
250 ifdef MSAN
251 CONFIG_DIR := msan_$(CONFIG_DIR)
252 endif
253 ifdef TSAN
254 CONFIG_DIR := tsan_$(CONFIG_DIR)
255 endif
256 ifdef ASAN
257 CONFIG_DIR := asan_$(CONFIG_DIR)
258 endif
260 OUTDIR := $(OUTBASE)/$(TOOLCHAIN)/$(CONFIG_DIR)
261 STAMPDIR ?= $(OUTDIR)
262 LIBDIR ?= $(NACL_SDK_ROOT)/lib
266 # Target to remove temporary files
268 .PHONY: clean
269 clean:
270 $(RM) -f $(TARGET).nmf
271 $(RM) -rf $(OUTDIR)
272 $(RM) -rf user-data-dir
276 # Rules for output directories.
278 # Output will be places in a directory name based on Toolchain and configuration
279 # be default this will be "newlib/Debug". We use a python wrapped MKDIR to
280 # proivde a cross platform solution. The use of '|' checks for existance instead
281 # of timestamp, since the directory can update when files change.
283 %dir.stamp :
284 $(MKDIR) -p $(dir $@)
285 @echo Directory Stamp > $@
289 # Dependency Macro
291 # $1 = Name of stamp
292 # $2 = Directory for the sub-make
293 # $3 = Extra Settings
295 define DEPEND_RULE
296 ifndef IGNORE_DEPS
297 .PHONY: rebuild_$(1)
299 rebuild_$(1) :| $(STAMPDIR)/dir.stamp
300 ifeq (,$(2))
301 +$(MAKE) -C $(NACL_SDK_ROOT)/src/$(1) STAMPDIR=$(abspath $(STAMPDIR)) $(abspath $(STAMPDIR)/$(1).stamp) $(3)
302 else
303 +$(MAKE) -C $(2) STAMPDIR=$(abspath $(STAMPDIR)) $(abspath $(STAMPDIR)/$(1).stamp) $(3)
304 endif
306 all: rebuild_$(1)
307 $(STAMPDIR)/$(1).stamp: rebuild_$(1)
309 else
311 .PHONY: $(STAMPDIR)/$(1).stamp
312 $(STAMPDIR)/$(1).stamp:
313 @echo Ignore $(1)
314 endif
315 endef
317 ifeq ($(TOOLCHAIN),win)
318 ifdef STANDALONE
319 HOST_EXT = .exe
320 else
321 HOST_EXT = .dll
322 endif
323 else
324 ifdef STANDALONE
325 HOST_EXT =
326 else
327 HOST_EXT = .so
328 endif
329 endif
333 # Common Compile Options
335 # For example, -DNDEBUG is added to release builds by default
336 # so that calls to assert(3) are not included in the build.
338 ifeq ($(CONFIG),Release)
339 POSIX_CFLAGS ?= -g -O2 -pthread -MMD -DNDEBUG
340 NACL_LDFLAGS ?= -O2
341 PNACL_LDFLAGS ?= -O2
342 else
343 POSIX_CFLAGS ?= -g -O0 -pthread -MMD -DNACL_SDK_DEBUG
344 endif
346 NACL_CFLAGS ?= -Wno-long-long -Werror
347 NACL_CXXFLAGS ?= -Wno-long-long -Werror
348 NACL_LDFLAGS += -Wl,-as-needed -pthread
351 # Default Paths
353 INC_PATHS := $(shell $(NACL_CONFIG) -t $(TOOLCHAIN) --include-dirs) $(EXTRA_INC_PATHS)
354 LIB_PATHS := $(NACL_SDK_ROOT)/lib $(EXTRA_LIB_PATHS)
357 # Define a LOG macro that allow a command to be run in quiet mode where
358 # the command echoed is not the same as the actual command executed.
359 # The primary use case for this is to avoid echoing the full compiler
360 # and linker command in the default case. Defining V=1 will restore
361 # the verbose behavior
363 # $1 = The name of the tool being run
364 # $2 = The target file being built
365 # $3 = The full command to run
367 ifdef V
368 define LOG
369 $(3)
370 endef
371 else
372 ifeq ($(OSNAME),win)
373 define LOG
374 @echo $(1) $(2) && $(3)
375 endef
376 else
377 define LOG
378 @echo " $(1) $(2)" && $(3)
379 endef
380 endif
381 endif
385 # Convert a source path to a object file path.
387 # $1 = Source Name
388 # $2 = Arch suffix
390 define SRC_TO_OBJ
391 $(OUTDIR)/$(basename $(subst ..,__,$(1)))$(2).o
392 endef
396 # Convert a source path to a dependency file path.
397 # We use the .deps extension for dependencies. These files are generated by
398 # fix_deps.py based on the .d files which gcc generates. We don't reference
399 # the .d files directly so that we can avoid the the case where the compile
400 # failed but still generated a .d file (in that case the .d file would not
401 # be processed by fix_deps.py)
403 # $1 = Source Name
404 # $2 = Arch suffix
406 define SRC_TO_DEP
407 $(patsubst %.o,%.deps,$(call SRC_TO_OBJ,$(1),$(2)))
408 endef
411 # The gcc-generated deps files end in .d
413 define SRC_TO_DEP_PRE_FIXUP
414 $(patsubst %.o,%.d,$(call SRC_TO_OBJ,$(1),$(2)))
415 endef
419 # If the requested toolchain is a NaCl or PNaCl toolchain, the use the
420 # macros and targets defined in nacl.mk, otherwise use the host sepecific
421 # macros and targets.
423 ifneq (,$(findstring $(TOOLCHAIN),linux mac))
424 include $(NACL_SDK_ROOT)/tools/host_gcc.mk
425 endif
427 ifneq (,$(findstring $(TOOLCHAIN),win))
428 include $(NACL_SDK_ROOT)/tools/host_vc.mk
429 endif
431 ifneq (,$(findstring $(TOOLCHAIN),glibc newlib bionic clang-newlib))
432 include $(NACL_SDK_ROOT)/tools/nacl_gcc.mk
433 endif
435 ifneq (,$(findstring $(TOOLCHAIN),pnacl))
436 include $(NACL_SDK_ROOT)/tools/nacl_llvm.mk
437 endif
440 # File to redirect to to in order to hide output.
442 ifeq ($(OSNAME),win)
443 DEV_NULL = nul
444 else
445 DEV_NULL = /dev/null
446 endif
450 # Variables for running examples with Chrome.
452 RUN_PY := python $(NACL_SDK_ROOT)/tools/run.py
453 HTTPD_PY := python $(NACL_SDK_ROOT)/tools/httpd.py
455 # Add this to launch Chrome with additional environment variables defined.
456 # Each element should be specified as KEY=VALUE, with whitespace separating
457 # key-value pairs. e.g.
458 # CHROME_ENV=FOO=1 BAR=2 BAZ=3
459 CHROME_ENV ?=
461 # Additional arguments to pass to Chrome.
462 CHROME_ARGS += --enable-nacl --enable-pnacl --no-first-run
463 CHROME_ARGS += --user-data-dir=$(CURDIR)/user-data-dir
466 # Paths to Debug and Release versions of the Host Pepper plugins
467 PPAPI_DEBUG = $(abspath $(OSNAME)/Debug/$(TARGET)$(HOST_EXT));application/x-ppapi-debug
468 PPAPI_RELEASE = $(abspath $(OSNAME)/Release/$(TARGET)$(HOST_EXT));application/x-ppapi-release
471 SYSARCH := $(shell $(GETOS) --nacl-arch)
472 SEL_LDR_PATH := python $(NACL_SDK_ROOT)/tools/sel_ldr.py
474 ifndef STANDALONE
476 # Assign a sensible default to CHROME_PATH.
478 CHROME_PATH ?= $(shell $(GETOS) --chrome 2> $(DEV_NULL))
481 # Verify we can find the Chrome executable if we need to launch it.
484 NULL :=
485 SPACE := $(NULL) # one space after NULL is required
486 CHROME_PATH_ESCAPE := $(subst $(SPACE),\ ,$(CHROME_PATH))
488 ifeq ($(OSNAME),win)
489 SANDBOX_ARGS := --no-sandbox
490 endif
492 GDB_PATH := $(shell $(NACL_CONFIG) -t $(TOOLCHAIN) --tool=gdb)
494 .PHONY: check_for_chrome
495 check_for_chrome:
496 ifeq (,$(wildcard $(CHROME_PATH_ESCAPE)))
497 $(warning No valid Chrome found at CHROME_PATH=$(CHROME_PATH))
498 $(error Set CHROME_PATH via an environment variable, or command-line.)
499 else
500 $(warning Using chrome at: $(CHROME_PATH))
501 endif
502 PAGE ?= index.html
503 PAGE_TC_CONFIG ?= "$(PAGE)?tc=$(TOOLCHAIN)&config=$(CONFIG)"
505 .PHONY: run
506 run: check_for_chrome all $(PAGE)
507 $(RUN_PY) -C $(CURDIR) -P $(PAGE_TC_CONFIG) \
508 $(addprefix -E ,$(CHROME_ENV)) -- "$(CHROME_PATH)" \
509 $(CHROME_ARGS) \
510 --register-pepper-plugins="$(PPAPI_DEBUG),$(PPAPI_RELEASE)"
512 .PHONY: run_package
513 run_package: check_for_chrome all
514 @echo "$(TOOLCHAIN) $(CONFIG)" > $(CURDIR)/run_package_config
515 "$(CHROME_PATH)" --load-and-launch-app=$(CURDIR) $(CHROME_ARGS)
517 GDB_ARGS += -D $(GDB_PATH)
518 # PNaCl's nexe is acquired with "remote get nexe <path>" instead of the NMF.
519 ifeq (,$(findstring $(TOOLCHAIN),pnacl))
520 GDB_ARGS += -D --eval-command="nacl-manifest $(abspath $(OUTDIR))/$(TARGET).nmf"
521 GDB_ARGS += -D $(GDB_DEBUG_TARGET)
522 endif
524 .PHONY: debug
525 debug: check_for_chrome all $(PAGE)
526 $(RUN_PY) $(GDB_ARGS) \
527 -C $(CURDIR) -P $(PAGE_TC_CONFIG) \
528 $(addprefix -E ,$(CHROME_ENV)) -- "$(CHROME_PATH)" \
529 $(CHROME_ARGS) $(SANDBOX_ARGS) --enable-nacl-debug \
530 --register-pepper-plugins="$(PPAPI_DEBUG),$(PPAPI_RELEASE)"
532 .PHONY: serve
533 serve: all
534 $(HTTPD_PY) -C $(CURDIR)
535 endif
537 # uppercase aliases (for backward compatibility)
538 .PHONY: CHECK_FOR_CHROME DEBUG LAUNCH RUN
539 CHECK_FOR_CHROME: check_for_chrome
540 DEBUG: debug
541 LAUNCH: run
542 RUN: run
544 endif # TOOLCHAIN is valid...
546 endif # TOOLCHAIN=all