jdk/make/common/Program.gmk
author amurillo
Fri, 26 Apr 2013 00:29:12 -0700
changeset 17040 e6d52b5fe8d1
parent 14091 e5c8662f325d
permissions -rw-r--r--
Added tag hs25-b30 for changeset 18be17ecfd6c

#
# 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