| # |
| # Copyright (c) 1995, 2012, Oracle and/or its affiliates. All rights reserved. |
| # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
| # |
| # This code is free software; you can redistribute it and/or modify it |
| # under the terms of the GNU General Public License version 2 only, as |
| # published by the Free Software Foundation. Oracle designates this |
| # particular file as subject to the "Classpath" exception as provided |
| # by Oracle in the LICENSE file that accompanied this code. |
| # |
| # This code is distributed in the hope that it will be useful, but WITHOUT |
| # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
| # version 2 for more details (a copy is included in the LICENSE file that |
| # accompanied this code). |
| # |
| # You should have received a copy of the GNU General Public License version |
| # 2 along with this work; if not, write to the Free Software Foundation, |
| # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
| # |
| # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
| # or visit www.oracle.com if you need additional information or have any |
| # questions. |
| # |
| |
| # |
| # Generic makefile for building executables. |
| # |
| |
| # WARNING: This file is shared with other workspaces. |
| # So when it includes other files, it must use JDK_TOPDIR. |
| # |
| |
| # |
| # If building programs, use a normal compile approach |
| # |
| ifeq ($(COMPILE_APPROACH),batch) |
| override COMPILE_APPROACH = normal |
| endif |
| |
| # set the platform specific directory for macosx, also this platform shares |
| # substantial family ties with its siblings (solaris and linux), thus we add |
| # solaris src path to its compilation dependencies. |
| ifeq ($(PLATFORM), macosx) |
| LAUNCHER_PLATFORM_SRC = $(BUILDDIR)/../src/macosx |
| LAUNCHER_SOLARIS_PLATFORM_SRC = $(BUILDDIR)/../src/solaris |
| else |
| LAUNCHER_PLATFORM_SRC = $(PLATFORM_SRC) |
| endif |
| |
| ifndef LAUNCHER_SHARE_SRC |
| LAUNCHER_SHARE_SRC = $(SHARE_SRC) |
| endif |
| |
| ACTUAL_PROGRAM_NAME = $(PROGRAM)$(EXE_SUFFIX) |
| ACTUAL_PROGRAM_DIR = $(BINDIR) |
| ACTUAL_PROGRAM = $(ACTUAL_PROGRAM_DIR)/$(ACTUAL_PROGRAM_NAME) |
| |
| # Make sure the default rule is all |
| program_default_rule: all |
| |
| program: $(ACTUAL_PROGRAM) |
| |
| # Work-around for missing processor specific mapfiles |
| ifndef CROSS_COMPILE_ARCH |
| # reuse the mapfiles in the launcher's directory, the same should |
| # be applicable to the tool launchers as well. |
| FILES_m = $(BUILDDIR)/java/main/java/mapfile-$(ARCH) |
| include $(BUILDDIR)/common/Mapfile-vers.gmk |
| endif |
| |
| include $(JDK_TOPDIR)/make/common/Rules.gmk |
| |
| ifdef NEVER_ACT_AS_SERVER_CLASS_MACHINE |
| OTHER_CPPFLAGS += -DNEVER_ACT_AS_SERVER_CLASS_MACHINE |
| endif |
| |
| # |
| # Create a dependency on libjli (Java Launcher Infrastructure) |
| # |
| # On UNIX, this is a relative dependency using $ORIGIN. Unfortunately, to |
| # do this reliably on Linux takes a different syntax than Solaris. |
| # |
| # On Windows, this is done by using the same directory as the executable |
| # itself, as with all the Windows libraries. |
| # |
| ifeq ($(PLATFORM), macosx) |
| ifneq ($(ARCH), universal) |
| LDFLAGS += -Wl,-all_load |
| endif |
| LDFLAGS += $(OUTPUTDIR)/tmp/java/jli/$(OBJDIRNAME)/static/libjli.a |
| |
| ifeq ($(SYSTEM_ZLIB),true) |
| OTHER_LDLIBS += $(ZLIB_LIBS) |
| endif |
| endif |
| |
| ifneq (,$(findstring $(PLATFORM), linux solaris)) # UNIX systems |
| LDFLAGS += -L $(LIBDIR)/$(LIBARCH)/jli |
| OTHER_LDLIBS += -ljli |
| ifeq ($(PLATFORM), solaris) |
| ifeq ($(ARCH_DATA_MODEL), 32) |
| LDFLAGS += -R \$$ORIGIN/../lib/$(LIBARCH)/jli |
| LDFLAGS += -R \$$ORIGIN/../jre/lib/$(LIBARCH)/jli |
| else |
| LDFLAGS += -R \$$ORIGIN/../../lib/$(LIBARCH)/jli |
| LDFLAGS += -R \$$ORIGIN/../../jre/lib/$(LIBARCH)/jli |
| endif |
| endif |
| ifeq ($(PLATFORM), linux) |
| LDFLAGS += $(LDFLAG_Z_ORIGIN) |
| LDFLAGS += -Wl,--allow-shlib-undefined |
| LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../lib/$(LIBARCH)/jli |
| LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../jre/lib/$(LIBARCH)/jli |
| endif |
| endif |
| |
| ifeq ($(PLATFORM), windows) |
| JLI_LCF = $(OUTPUTDIR)/tmp/java/jli/$(OBJDIRNAME)/jli.lcf |
| ifdef STATIC_JLI |
| LDFLAGS += -libpath:$(OUTPUTDIR)/tmp/java/jli/$(OBJDIRNAME)/static |
| else |
| LDFLAGS += -libpath:$(OUTPUTDIR)/tmp/java/jli/$(OBJDIRNAME) |
| endif |
| OTHER_LDLIBS += jli.lib |
| endif |
| |
| # |
| # Applications expect to be able to link against libjawt without invoking |
| # System.loadLibrary("jawt") first. This was the behaviour described in the |
| # devloper documentation of JAWT and what worked with OpenJDK6. |
| # |
| ifeq ($(PLATFORM), solaris) |
| ifeq ($(ARCH_DATA_MODEL), 32) |
| LDFLAGS += -R \$$ORIGIN/../lib/$(LIBARCH) |
| LDFLAGS += -R \$$ORIGIN/../jre/lib/$(LIBARCH) |
| else # ! ARCH_DATA_MODEL 64-bit |
| LDFLAGS += -R \$$ORIGIN/../../lib/$(LIBARCH) |
| LDFLAGS += -R \$$ORIGIN/../../jre/lib/$(LIBARCH) |
| endif # ARCH_DATA_MODEL |
| endif # PLATFORM SOLARIS |
| ifeq ($(PLATFORM), linux) |
| LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../lib/$(LIBARCH) |
| LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../jre/lib/$(LIBARCH) |
| endif # PLATFORM LINUX |
| |
| |
| # |
| # Launcher specific files. |
| # |
| FILES_o = $(OBJDIR)/main.$(OBJECT_SUFFIX) |
| |
| $(ACTUAL_PROGRAM):: classes $(INIT) |
| |
| # |
| # Windows only |
| # |
| ifeq ($(PLATFORM), windows) |
| # JDK name required here |
| RC_FLAGS += -D "JDK_FNAME=$(PROGRAM)$(EXE_SUFFIX)" \ |
| -D "JDK_INTERNAL_NAME=$(PROGRAM)" \ |
| -D "JDK_FTYPE=0x1L" |
| |
| $(OBJDIR)/$(PROGRAM).res: $(VERSIONINFO_RESOURCE) |
| @$(prep-target) |
| ifndef LOCAL_RESOURCE_FILE |
| $(RC) $(RC_FLAGS) $(CC_OBJECT_OUTPUT_FLAG)$(@) $(VERSIONINFO_RESOURCE) |
| endif |
| |
| $(OBJDIR)/$(PROGRAM).lcf: $(OBJDIR)/$(PROGRAM).res $(FILES_o) |
| @$(prep-target) |
| @$(ECHO) $(FILES_o) > $@ |
| ifndef LOCAL_RESOURCE_FILE |
| @$(ECHO) $(OBJDIR)/$(PROGRAM).res >> $@ |
| endif |
| @$(ECHO) Created $@ |
| |
| $(ACTUAL_PROGRAM):: $(OBJDIR)/$(PROGRAM)$(EXE_SUFFIX) |
| @$(install-file) |
| |
| ifeq ($(ARCH_DATA_MODEL), 32) |
| STACK_SIZE=327680 |
| else |
| # We need more Stack for Windows 64bit |
| STACK_SIZE=1048576 |
| endif |
| |
| IMVERSION=$(JDK_MINOR_VERSION).$(JDK_MICRO_VERSION).$(JDK_UPDATE_VER).$(COOKED_BUILD_NUMBER) |
| $(OBJDIR)/$(PROGRAM).exe.manifest: $(JDK_TOPDIR)/src/windows/resource/java.manifest |
| @$(prep-target) |
| $(SED) 's%IMVERSION%$(IMVERSION)%g;s%PROGRAM%$(PROGRAM)%g' $< > $@ |
| |
| ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1) |
| MAP_OPTION="-map:$(OBJDIR)/$(PROGRAM).map" |
| endif |
| |
| # We used a hand-crafted manifest file for all executables. |
| # It is tweaked to embed the build number and executable name. |
| # Use ";#2" for .dll and ";#1" for .exe in the MT command below: |
| $(OBJDIR)/$(PROGRAM)$(EXE_SUFFIX):: $(OBJDIR)/$(PROGRAM).lcf $(FILES_o) $(JLI_LCF) $(OBJDIR)/$(PROGRAM).exe.manifest |
| @$(prep-target) |
| @set -- $?; \ |
| $(ECHO) Rebuilding $@ because of $$1 $$2 $$3 $$4 $$5 $$6 $${7:+...}; |
| $(LINK) -out:$@ -STACK:$(STACK_SIZE) \ |
| $(MAP_OPTION) $(LFLAGS) $(LDFLAGS) \ |
| @$(OBJDIR)/$(PROGRAM).lcf $(LDLIBS) |
| ifdef MT |
| $(MT) -manifest $(OBJDIR)/$(PROGRAM).exe.manifest /outputresource:$@;#1 |
| endif |
| @$(call binary_file_verification,$@) |
| ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1) |
| ifeq ($(ZIP_DEBUGINFO_FILES),1) |
| (set -e ; \ |
| $(CD) $(OBJDIR) ; \ |
| $(ZIPEXE) -q $(PROGRAM).diz $(PROGRAM).map $(PROGRAM).pdb ; \ |
| $(RM) $(PROGRAM).map $(PROGRAM).pdb ; \ |
| ) |
| endif |
| endif |
| else |
| # |
| # Note that we have to link -lthread even when USE_PTHREADS is true. |
| # This is becuase checkForCorrectLibthread() croaks otherwise. |
| # |
| LIBTHREAD = -lthread |
| ifeq ($(USE_PTHREADS),true) |
| THREADLIBS = -lpthread $(LIBTHREAD) |
| else |
| THREADLIBS = $(LIBTHREAD) |
| endif |
| |
| ifeq ($(PLATFORM), macosx) |
| THREADLIBS = -pthread |
| # Needed for linking the various launchers |
| LDFLAGS += -framework Cocoa -framework Security \ |
| -framework ApplicationServices |
| OTHER_CPPFLAGS += -DPACKAGE_PATH='"$(PACKAGE_PATH)"' |
| |
| # Default Info.plist file for the command line tools. This gets overridden by |
| # some of the jvmstat tools so that they have task_for_pid() privileges |
| ifndef INFO_PLIST_FILE |
| INFO_PLIST_FILE = Info-cmdline.plist |
| endif |
| LDFLAGS += -sectcreate __TEXT __info_plist $(LAUNCHER_PLATFORM_SRC)/lib/$(INFO_PLIST_FILE) |
| else |
| INFO_PLIST_FILE= |
| endif |
| |
| # |
| # This rule only applies on unix. It supports quantify and its ilk. |
| # |
| |
| ifeq ($(PLATFORM), solaris) |
| ifeq ($(PROGRAM_SUPPORTS_FULL_DEBUG_SYMBOLS),1) |
| $(ACTUAL_PROGRAM):: $(ADD_GNU_DEBUGLINK) $(FIX_EMPTY_SEC_HDR_FLAGS) |
| endif |
| endif |
| |
| $(ACTUAL_PROGRAM):: $(FILES_o) |
| @$(prep-target) |
| @set -- $?; \ |
| $(ECHO) Rebuilding $@ because of $$1 $$2 $$3 $$4 $$5 $$6 $${7:+...}; |
| @$(MKDIR) -p $(TEMPDIR) |
| $(LINK_PRE_CMD) $(CC) $(CC_OBJECT_OUTPUT_FLAG)$@ $(LDFLAGS) \ |
| $(sort $(FILES_o)) $(THREADLIBS) $(LDLIBS) |
| ifeq ($(findstring privileged, $(INFO_PLIST_FILE)), privileged) |
| -codesign -s openjdk_codesign $@ |
| endif |
| @$(call binary_file_verification,$@) |
| ifneq ($(PLATFORM), macosx) |
| ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1) |
| ifeq ($(PROGRAM_SUPPORTS_FULL_DEBUG_SYMBOLS),1) |
| ifeq ($(PLATFORM), solaris) |
| # gobjcopy crashes on "empty" section headers with the SHF_ALLOC flag set. |
| # Use $(FIX_EMPTY_SEC_HDR_FLAGS) to clear the SHF_ALLOC flag (if set) from |
| # empty section headers until a fixed $(OBJCOPY) is available. |
| # An empty section header has sh_addr == 0 and sh_size == 0. |
| # This problem has only been seen on Solaris X64, but we call this tool |
| # on all Solaris builds just in case. |
| # |
| # $(OBJCOPY) --add-gnu-debuglink=... corrupts SUNW_* sections. |
| # Use $(ADD_GNU_DEBUGLINK) until a fixed $(OBJCOPY) is available. |
| (set -e ; \ |
| $(CD) $(@D) ; \ |
| $(FIX_EMPTY_SEC_HDR_FLAGS) $(@F) ; \ |
| $(OBJCOPY) --only-keep-debug $(@F) $(@F).debuginfo ; \ |
| $(ADD_GNU_DEBUGLINK) $(@F).debuginfo $(@F) ; \ |
| ) |
| else # PLATFORM != solaris |
| (set -e ; \ |
| $(CD) $(@D) ; \ |
| $(OBJCOPY) --only-keep-debug $(@F) $(@F).debuginfo ; \ |
| $(OBJCOPY) --add-gnu-debuglink=$(@F).debuginfo $(@F) ; \ |
| ) |
| endif # PLATFORM == solaris |
| ifeq ($(STRIP_POLICY),all_strip) |
| $(STRIP) $@ |
| else |
| ifeq ($(STRIP_POLICY),min_strip) |
| ifeq ($(PLATFORM), solaris) |
| $(STRIP) -x $@ |
| else |
| # assume Linux |
| $(STRIP) -g $@ |
| endif |
| # implied else here is no stripping at all |
| endif |
| endif |
| ifeq ($(ZIP_DEBUGINFO_FILES),1) |
| (set -e ; \ |
| $(CD) $(@D) ; \ |
| $(ZIPEXE) -q $(@F).diz $(@F).debuginfo ; \ |
| $(RM) $(@F).debuginfo ; \ |
| ) |
| # save ZIP'ed debug info with rest of the program's build artifacts |
| $(MV) $@.diz $(OBJDIR) |
| else |
| # save debug info with rest of the program's build artifacts |
| $(MV) $@.debuginfo $(OBJDIR) |
| endif |
| endif # PROGRAM_SUPPORTS_FULL_DEBUG_SYMBOLS |
| endif # ENABLE_FULL_DEBUG_SYMBOLS |
| endif # PLATFORM-!macosx |
| endif # PLATFORM |
| |
| clean:: |
| ifeq ($(PLATFORM), windows) |
| $(RM) $(OBJDIR)/$(PROGRAM).rc |
| $(RM) $(OBJDIR)/$(PROGRAM).ico |
| $(RM) $(OBJDIR)/$(PROGRAM).lcf |
| $(RM) $(OBJDIR)/$(PROGRAM).map |
| $(RM) $(OBJDIR)/$(PROGRAM).pdb |
| $(RM) $(OBJDIR)/$(PROGRAM).exp |
| $(RM) $(OBJDIR)/$(PROGRAM).lib |
| $(RM) $(OBJDIR)/$(PROGRAM)$(EXE_SUFFIX) |
| $(RM) $(OBJDIR)/$(PROGRAM).ilk |
| $(RM) *.pdb |
| else |
| $(RM) $(OBJDIR)/$(PROGRAM).debuginfo |
| endif |
| $(RM) $(OBJDIR)/$(PROGRAM).diz |
| |
| |
| clobber:: |
| $(RM) $(ACTUAL_PROGRAM) |
| |
| # |
| # Now include make dependencies (created during compilation, see Rules.gmk) |
| # |
| ifeq ($(INCREMENTAL_BUILD),true) |
| # Workaround: gnumake sometimes says files is empty when it shouldn't |
| # was: files := $(foreach file, $(wildcard */$(ARCH)/*.$(DEPEND_SUFFIX)), $(file)) |
| files := $(shell $(LS) $(OBJDIR)/*.$(DEPEND_SUFFIX) 2>/dev/null) |
| ifneq ($(strip $(files)),) |
| include $(files) |
| endif |
| endif |
| |
| ifdef JAVA_ARGS |
| OTHER_CPPFLAGS += -DJAVA_ARGS='$(JAVA_ARGS)' |
| OTHER_CPPFLAGS += -DLAUNCHER_NAME='"$(LAUNCHER_NAME)"' |
| endif |
| |
| ifeq ($(PLATFORM), windows) |
| ifdef RELEASE |
| OTHER_CPPFLAGS += -DVERSION='"$(RELEASE)"' |
| endif |
| endif |
| |
| |
| ifneq ($(PLATFORM), windows) |
| HAVE_GETHRTIME=true |
| endif |
| |
| ifeq ($(HAVE_GETHRTIME),true) |
| OTHER_CPPFLAGS += -DHAVE_GETHRTIME |
| endif |
| |
| OTHER_INCLUDES += -I$(LAUNCHER_SHARE_SRC)/bin -I$(LAUNCHER_PLATFORM_SRC)/bin |
| ifeq ($(PLATFORM), macosx) |
| OTHER_INCLUDES += -I$(LAUNCHER_SOLARIS_PLATFORM_SRC)/bin |
| ifneq ($(SYSTEM_ZLIB), true) |
| OTHER_INCLUDES += -I$(SHARE_SRC)/native/java/util/zip/zlib-1.1.3 |
| endif |
| else |
| OTHER_INCLUDES += -I$(SHARE_SRC)/native/java/util/zip/zlib-1.1.3 |
| endif |
| |
| OTHER_CPPFLAGS += -DPROGNAME='"$(PROGRAM)"' |
| VERSION_DEFINES += -DFULL_VERSION='"$(FULL_VERSION)"' |
| |
| VERSION_DEFINES += -DJDK_MAJOR_VERSION='"$(JDK_MAJOR_VERSION)"' \ |
| -DJDK_MINOR_VERSION='"$(JDK_MINOR_VERSION)"' |
| |
| $(OBJDIR)/main.$(OBJECT_SUFFIX): $(LAUNCHER_SHARE_SRC)/bin/main.c |
| @$(prep-target) |
| $(COMPILE.c) $(CC_OBJECT_OUTPUT_FLAG)$(OBJDIR)/main.$(OBJECT_SUFFIX) \ |
| $(VERSION_DEFINES) $< |
| |
| # |
| # Default dependencies |
| # |
| |
| all: build |
| |
| build: program |
| |
| debug: |
| $(MAKE) VARIANT=DBG build |
| |
| fastdebug: |
| $(MAKE) VARIANT=DBG FASTDEBUG=true build |
| |
| .PHONY: all build program clean clobber debug fastdebug |