1 #
   2 # Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
   3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4 #
   5 # This code is free software; you can redistribute it and/or modify it
   6 # under the terms of the GNU General Public License version 2 only, as
   7 # published by the Free Software Foundation.  Oracle designates this
   8 # particular file as subject to the "Classpath" exception as provided
   9 # by Oracle in the LICENSE file that accompanied this code.
  10 #
  11 # This code is distributed in the hope that it will be useful, but WITHOUT
  12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  14 # version 2 for more details (a copy is included in the LICENSE file that
  15 # accompanied this code).
  16 #
  17 # You should have received a copy of the GNU General Public License version
  18 # 2 along with this work; if not, write to the Free Software Foundation,
  19 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  20 #
  21 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  22 # or visit www.oracle.com if you need additional information or have any
  23 # questions.
  24 #
  25 
  26 ################################################################################
  27 # Generate classlist
  28 ################################################################################
  29 
  30 default: all
  31 
  32 include $(SPEC)
  33 include MakeBase.gmk
  34 include SetupJavaCompilers.gmk
  35 
  36 ################################################################################
  37 # Create a jar with our generator class. Using a jar is intentional since it
  38 # will load more classes
  39 
  40 $(eval $(call SetupJavaCompilation, CLASSLIST_JAR, \
  41     SETUP := GENERATE_JDKBYTECODE, \
  42     SRC := $(TOPDIR)/make/jdk/src/classes, \
  43     INCLUDES := build/tools/classlist, \
  44     BIN := $(BUILDTOOLS_OUTPUTDIR)/classlist_classes, \
  45     JAR := $(SUPPORT_OUTPUTDIR)/classlist.jar, \
  46 ))
  47 
  48 TARGETS += $(CLASSLIST_JAR)
  49 
  50 ################################################################################
  51 
  52 LINK_OPT_DIR := $(SUPPORT_OUTPUTDIR)/link_opt
  53 CLASSLIST_FILE := $(LINK_OPT_DIR)/classlist
  54 JLI_TRACE_FILE := $(LINK_OPT_DIR)/default_jli_trace.txt
  55 
  56 # If an external buildjdk has been supplied, we don't build a separate interim
  57 # image, so just use the external build jdk instead.
  58 ifeq ($(EXTERNAL_BUILDJDK), true)
  59   INTERIM_IMAGE_DIR := $(BUILD_JDK)
  60 endif
  61 
  62 # Save the stderr output of the command and print it along with stdout in case
  63 # something goes wrong.
  64 $(CLASSLIST_FILE): $(INTERIM_IMAGE_DIR)/bin/java$(EXE_SUFFIX) $(CLASSLIST_JAR)
  65         $(call MakeDir, $(LINK_OPT_DIR))
  66         $(call LogInfo, Generating $(patsubst $(OUTPUTDIR)/%, %, $@))
  67         $(call LogInfo, Generating $(patsubst $(OUTPUTDIR)/%, %, $(JLI_TRACE_FILE)))
  68         $(FIXPATH) $(INTERIM_IMAGE_DIR)/bin/java -XX:DumpLoadedClassList=$@.raw \
  69             -Djava.lang.invoke.MethodHandle.TRACE_RESOLVE=true \
  70             -Duser.language=en -Duser.country=US \
  71             -cp $(SUPPORT_OUTPUTDIR)/classlist.jar \
  72             build.tools.classlist.HelloClasslist \
  73             2> $(LINK_OPT_DIR)/stderr > $(JLI_TRACE_FILE) \
  74             || ( \
  75                 exitcode=$$? ; \
  76                 $(ECHO) "ERROR: Failed to generate link optimization data." \
  77                     "This is likely a problem with the newly built JVM/JDK." ; \
  78                 $(CAT) $(LINK_OPT_DIR)/stderr $(JLI_TRACE_FILE) ; \
  79                 exit $$exitcode \
  80             )
  81         $(GREP) -v HelloClasslist $@.raw > $@
  82 
  83 # The jli trace is created by the same recipe as classlist. By declaring these
  84 # dependencies, make will correctly rebuild both jli trace and classlist
  85 # incrementally using the single recipe above.
  86 $(CLASSLIST_FILE): $(JLI_TRACE_FILE)
  87 $(JLI_TRACE_FILE): $(INTERIM_IMAGE_DIR)/bin/java$(EXE_SUFFIX) $(CLASSLIST_JAR)
  88 
  89 TARGETS += $(CLASSLIST_FILE) $(JLI_TRACE_FILE)
  90 
  91 # Copy the classlist file into java.base libs
  92 $(eval $(call SetupCopyFiles, COPY_CLASSLIST, \
  93     FILES := $(CLASSLIST_FILE), \
  94     DEST := $(SUPPORT_OUTPUTDIR)/modules_libs/java.base, \
  95 ))
  96 
  97 TARGETS += $(COPY_CLASSLIST)
  98 
  99 # Copy the default_jli_trace.txt file into jdk.jlink
 100 $(eval $(call SetupCopyFiles, COPY_JLI_TRACE, \
 101     FILES := $(JLI_TRACE_FILE), \
 102     DEST := $(JDK_OUTPUTDIR)/modules/jdk.jlink/jdk/tools/jlink/internal/plugins, \
 103 ))
 104 
 105 # Because of the single recipe for jli trace and classlist above, the
 106 # COPY_JLI_TRACE rule needs to explicitly add the classlist file as a
 107 # prerequisite.
 108 $(COPY_JLI_TRACE): $(CLASSLIST_FILE)
 109 
 110 TARGETS += $(COPY_JLI_TRACE)
 111 
 112 ################################################################################
 113 
 114 all: $(TARGETS)