e487e25584
6845973: Update JDK7 with deployment changes in 6u13, 6u14 4802695: Support 64-bit Java Plug-in and Java webstart on Windows/Linux on AMD64 6825019: DownloadManager should not be loaded and referenced for full JRE 6738770: REGRESSION:JSException throws when use LiveConnect javascript facility 6772884: plugin2 : java.lang.OutOfMemoryError or crash 6707535: Crossing domain hole affecting multiple sites/domains using plug-in 6728071: Non-verification of Update files may allow unintended updates 6704154: Code loaded from local filesystem should not get access to localhost 6727081: Web Start security restrictions bypass using special extension jnlp 6727079: Java Web Start Socket() restriction bypass 6727071: Cache location/user name information disclosure in SingleInstanceImpl 6716217: AppletClassLoader adds permissions based on codebase regardless of CS 6694892: Java Webstart inclusion via system properties override [CVE-2008-2086] 6704074: localhost socket access due to cache location exposed 6703909: Java webstart arbitrary file creation using nativelib 6665315: browser crashes when deployment.properties has more slashes ( / ) 6660121: Encoding values in JNLP files can cause buffer overflow 6606110: URLConnection.setProxiedHost for resources that are loaded via proxy 6581221: SSV(VISTA): Redirection FAILS to work if user does a downgrade install 6609756: Buffer Overflow in Java ActiveX component 6608712: Bypassing the same origin policy in Java with crafted names 6534630: "gnumake clobber" doesn't 6849953: JDK7 - replacement of bufferoverflowU.lib on amd64 breaks build 6849029: Need some JDK7 merge clean-up after comments on the webrev 6847582: Build problem on JDK7 with isSecureProperty in merge 6827935: JDK 7 deployment merging - problem in Compiler-msvm.gmk 6823215: latest merge fixes from 6u12 -> JDK7 6816153: further mergers for JDK7 deployment integration 6807074: Fix Java Kernel and JQS in initial JDK7 builds Initial changeset for implementing 6uX Deployment Features into JDK7 Reviewed-by: dgu, billyh
301 lines
8.0 KiB
Plaintext
301 lines
8.0 KiB
Plaintext
#
|
|
# Copyright 1995-2007 Sun Microsystems, Inc. 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. Sun designates this
|
|
# particular file as subject to the "Classpath" exception as provided
|
|
# by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
|
# CA 95054 USA or visit www.sun.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
|
|
|
|
ifndef LAUNCHER_PLATFORM_SRC
|
|
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)
|
|
|
|
JVMCFG = $(LIBDIR)/$(LIBARCH)/jvm.cfg
|
|
|
|
# Make sure the default rule is all
|
|
program_default_rule: all
|
|
|
|
program: $(ACTUAL_PROGRAM)
|
|
|
|
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.
|
|
#
|
|
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 += -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
|
|
|
|
#
|
|
# Launcher specific files.
|
|
#
|
|
FILES_o = \
|
|
$(OBJDIR)/main.$(OBJECT_SUFFIX)
|
|
|
|
# We either need to import (copy) binaries in, or build them
|
|
ifneq ($(IMPORT_NATIVE_BINARIES),true)
|
|
COMPILE_IT=true
|
|
else
|
|
COMPILE_IT=false
|
|
endif
|
|
|
|
ifeq ($(COMPILE_IT),true)
|
|
|
|
$(ACTUAL_PROGRAM):: classes $(JVMCFG) $(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) setargv.obj >> $@
|
|
@$(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
|
|
|
|
# In VS2005 or VS2008 the link command creates a .manifest file that we want
|
|
# to insert into the linked artifact so we do not need to track it separately.
|
|
# Use ";#2" for .dll and ";#1" for .exe in the MT command below:
|
|
$(OBJDIR)/$(PROGRAM)$(EXE_SUFFIX):: $(OBJDIR)/$(PROGRAM).lcf $(FILES_o) $(JLI_LCF)
|
|
@$(prep-target)
|
|
@set -- $?; \
|
|
$(ECHO) Rebuilding $@ because of $$1 $$2 $$3 $$4 $$5 $$6 $${7:+...};
|
|
$(LINK) -out:$@ /STACK:$(STACK_SIZE) \
|
|
-map:$(OBJDIR)/$(PROGRAM).map $(LFLAGS) $(LDFLAGS) \
|
|
@$(OBJDIR)/$(PROGRAM).lcf $(LDLIBS)
|
|
ifdef MT
|
|
$(MT) /manifest $(OBJDIR)/$(PROGRAM).exe.manifest /outputresource:$@;#1
|
|
endif
|
|
|
|
else # PLATFORM
|
|
|
|
#
|
|
# 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 # USE_PTHREADS
|
|
THREADLIBS = $(LIBTHREAD)
|
|
endif # USE_PTHREADS
|
|
|
|
#
|
|
# This rule only applies on unix. It supports quantify and its ilk.
|
|
#
|
|
$(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) \
|
|
$(FILES_o) $(THREADLIBS) $(LDLIBS)
|
|
|
|
endif # PLATFORM
|
|
|
|
else # COMPILE_IT
|
|
|
|
$(ACTUAL_PROGRAM):: $(JVMCFG)
|
|
|
|
# Copies in the file from the JDK_IMPORT_PATH area
|
|
$(ACTUAL_PROGRAM_DIR)/%: $(JDK_IMPORT_PATH)/jre/bin/%
|
|
@$(install-import-file)
|
|
$(ACTUAL_PROGRAM_DIR)/%: $(JDK_IMPORT_PATH)/bin/%
|
|
@$(install-import-file)
|
|
|
|
endif # COMPILE_IT
|
|
|
|
|
|
clean::
|
|
ifeq ($(PLATFORM), windows)
|
|
$(RM) $(OBJDIR)/$(PROGRAM).rc
|
|
$(RM) $(OBJDIR)/$(PROGRAM).ico
|
|
$(RM) $(OBJDIR)/$(PROGRAM).lcf
|
|
$(RM) $(OBJDIR)/$(PROGRAM).map
|
|
$(RM) $(OBJDIR)/$(PROGRAM).exp
|
|
$(RM) $(OBJDIR)/$(PROGRAM).lib
|
|
$(RM) $(OBJDIR)/$(PROGRAM)$(EXE_SUFFIX)
|
|
$(RM) $(OBJDIR)/$(PROGRAM).ilk
|
|
$(RM) *.pdb
|
|
endif
|
|
|
|
|
|
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 # files
|
|
endif # INCREMENTAL_BUILD
|
|
|
|
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
|
|
OTHER_INCLUDES += -I$(SHARE_SRC)/native/java/util/zip/zlib-1.1.3
|
|
|
|
# this may not be necessary...
|
|
ifeq ($(PLATFORM), windows)
|
|
OTHER_CPPFLAGS += -DPROGNAME="\"$(PROGRAM)\""
|
|
VERSION_DEFINES += -DFULL_VERSION="\"$(FULL_VERSION)\""
|
|
else
|
|
OTHER_CPPFLAGS += -DPROGNAME='"$(PROGRAM)"'
|
|
VERSION_DEFINES += -DFULL_VERSION='"$(FULL_VERSION)"'
|
|
endif
|
|
|
|
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) $<
|
|
|
|
#
|
|
# How to install jvm.cfg.
|
|
#
|
|
$(JVMCFG): $(LAUNCHER_PLATFORM_SRC)/bin/$(ARCH)/jvm.cfg
|
|
$(install-file)
|
|
|
|
#
|
|
# 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
|