make/bsd/makefiles/sa.make

Print this page




   8 #
   9 # This code is distributed in the hope that it will be useful, but WITHOUT
  10 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12 # version 2 for more details (a copy is included in the LICENSE file that
  13 # accompanied this code).
  14 #
  15 # You should have received a copy of the GNU General Public License version
  16 # 2 along with this work; if not, write to the Free Software Foundation,
  17 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18 #
  19 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20 # or visit www.oracle.com if you need additional information or have any
  21 # questions.
  22 #
  23 #
  24 
  25 # This makefile (sa.make) is included from the sa.make in the
  26 # build directories.
  27 






  28 # This makefile is used to build Serviceability Agent java code
  29 # and generate JNI header file for native methods.
  30 
  31 include $(GAMMADIR)/make/bsd/makefiles/rules.make
  32 
  33 AGENT_DIR = $(GAMMADIR)/agent
  34 
  35 include $(GAMMADIR)/make/sa.files
  36 
  37 TOPDIR    = $(shell echo `pwd`)
  38 GENERATED = $(TOPDIR)/../generated
  39 
  40 # SA-JDI depends on the standard JDI classes.
  41 # Default SA_CLASSPATH location:
  42 DEF_SA_CLASSPATH=$(BOOT_JAVA_HOME)/lib/tools.jar
  43 ifeq ($(ALT_SA_CLASSPATH),)
  44   # no alternate specified; see if default exists
  45   SA_CLASSPATH=$(shell test -f $(DEF_SA_CLASSPATH) && echo $(DEF_SA_CLASSPATH))
  46   ifeq ($(SA_CLASSPATH),)
  47     # the default doesn't exist
  48     ifeq ($(OS_VENDOR), Darwin)
  49       # A JDK from Apple doesn't have tools.jar; the JDI classes are
  50       # are in the regular classes.jar file.
  51       APPLE_JAR=$(BOOT_JAVA_HOME)/bundle/Classes/classes.jar
  52       SA_CLASSPATH=$(shell test -f $(APPLE_JAR) && echo $(APPLE_JAR))
  53     endif
  54   endif
  55 else
  56   _JUNK_ := $(shell echo >&2 "INFO: ALT_SA_CLASSPATH=$(ALT_SA_CLASSPATH)")
  57   SA_CLASSPATH=$(shell test -f $(ALT_SA_CLASSPATH) && echo $(ALT_SA_CLASSPATH))
  58 endif
  59 
  60 # TODO: if it's a modules image, check if SA module is installed.
  61 MODULELIB_PATH= $(BOOT_JAVA_HOME)/lib/modules
  62 
  63 AGENT_FILES_LIST := $(GENERATED)/agent.classes.list
  64 
  65 SA_CLASSDIR = $(GENERATED)/saclasses
  66 
  67 SA_BUILD_VERSION_PROP = "sun.jvm.hotspot.runtime.VM.saBuildVersion=$(SA_BUILD_VERSION)"
  68 
  69 SA_PROPERTIES = $(SA_CLASSDIR)/sa.properties
  70 
  71 # if $(AGENT_DIR) does not exist, we don't build SA
  72 # also, we don't build SA on Itanium, PowerPC, ARM or zero.
  73 
  74 all:
  75         if [ -d $(AGENT_DIR) -a "$(SRCARCH)" != "ia64" \
  76              -a "$(SRCARCH)" != "arm" \
  77              -a "$(SRCARCH)" != "ppc" \
  78              -a "$(SRCARCH)" != "zero" ] ; then \
  79            $(MAKE) -f sa.make $(GENERATED)/sa-jdi.jar; \
  80         fi
  81 
  82 $(GENERATED)/sa-jdi.jar: $(AGENT_FILES)
  83         $(QUIETLY) echo "Making $@"
  84         $(QUIETLY) if [ "$(BOOT_JAVA_HOME)" = "" ]; then \
  85           echo "ALT_BOOTDIR, BOOTDIR or JAVA_HOME needs to be defined to build SA"; \
  86           exit 1; \
  87         fi
  88         $(QUIETLY) if [ ! -f "$(SA_CLASSPATH)" -a ! -d $(MODULELIB_PATH) ] ; then \
  89           echo "Cannot find JDI classes. Use 1.6.0 or later version of JDK."; \
  90           echo ""; \
  91           exit 1; \
  92         fi
  93         $(QUIETLY) if [ ! -d $(SA_CLASSDIR) ] ; then \
  94           mkdir -p $(SA_CLASSDIR);        \
  95         fi
  96 # Note: When indented, make tries to execute the '$(shell' comment.
  97 # In some environments, cmd processors have limited line length.
  98 # To prevent the javac invocation in the next block from using
  99 # a very long cmd line, we use javac's @file-list option. We
 100 # generate the file lists using make's built-in 'foreach' control
 101 # flow which also avoids cmd processor line length issues. Since
 102 # the 'foreach' is done as part of make's macro expansion phase,
 103 # the initialization of the lists is also done in the same phase




   8 #
   9 # This code is distributed in the hope that it will be useful, but WITHOUT
  10 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12 # version 2 for more details (a copy is included in the LICENSE file that
  13 # accompanied this code).
  14 #
  15 # You should have received a copy of the GNU General Public License version
  16 # 2 along with this work; if not, write to the Free Software Foundation,
  17 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18 #
  19 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20 # or visit www.oracle.com if you need additional information or have any
  21 # questions.
  22 #
  23 #
  24 
  25 # This makefile (sa.make) is included from the sa.make in the
  26 # build directories.
  27 
  28 define print_info
  29   ifneq ($$(LOG_LEVEL), warn)
  30     $$(shell echo >&2 "INFO: $1")
  31   endif
  32 endef
  33 
  34 # This makefile is used to build Serviceability Agent java code
  35 # and generate JNI header file for native methods.
  36 
  37 include $(GAMMADIR)/make/bsd/makefiles/rules.make
  38 
  39 AGENT_DIR = $(GAMMADIR)/agent
  40 
  41 include $(GAMMADIR)/make/sa.files
  42 
  43 TOPDIR    = $(shell echo `pwd`)
  44 GENERATED = $(TOPDIR)/../generated
  45 
  46 # SA-JDI depends on the standard JDI classes.
  47 # Default SA_CLASSPATH location:
  48 DEF_SA_CLASSPATH=$(BOOT_JAVA_HOME)/lib/tools.jar
  49 ifeq ($(ALT_SA_CLASSPATH),)
  50   # no alternate specified; see if default exists
  51   SA_CLASSPATH=$(shell test -f $(DEF_SA_CLASSPATH) && echo $(DEF_SA_CLASSPATH))
  52   ifeq ($(SA_CLASSPATH),)
  53     # the default doesn't exist
  54     ifeq ($(OS_VENDOR), Darwin)
  55       # A JDK from Apple doesn't have tools.jar; the JDI classes are
  56       # are in the regular classes.jar file.
  57       APPLE_JAR=$(BOOT_JAVA_HOME)/bundle/Classes/classes.jar
  58       SA_CLASSPATH=$(shell test -f $(APPLE_JAR) && echo $(APPLE_JAR))
  59     endif
  60   endif
  61 else
  62   $(eval $(call print_info, "ALT_SA_CLASSPATH=$(ALT_SA_CLASSPATH)"))
  63   SA_CLASSPATH=$(shell test -f $(ALT_SA_CLASSPATH) && echo $(ALT_SA_CLASSPATH))
  64 endif
  65 
  66 # TODO: if it's a modules image, check if SA module is installed.
  67 MODULELIB_PATH= $(BOOT_JAVA_HOME)/lib/modules
  68 
  69 AGENT_FILES_LIST := $(GENERATED)/agent.classes.list
  70 
  71 SA_CLASSDIR = $(GENERATED)/saclasses
  72 
  73 SA_BUILD_VERSION_PROP = "sun.jvm.hotspot.runtime.VM.saBuildVersion=$(SA_BUILD_VERSION)"
  74 
  75 SA_PROPERTIES = $(SA_CLASSDIR)/sa.properties
  76 
  77 # if $(AGENT_DIR) does not exist, we don't build SA
  78 # also, we don't build SA on Itanium, PowerPC, ARM or zero.
  79 
  80 all:
  81         if [ -d $(AGENT_DIR) -a "$(SRCARCH)" != "ia64" \
  82              -a "$(SRCARCH)" != "arm" \
  83              -a "$(SRCARCH)" != "ppc" \
  84              -a "$(SRCARCH)" != "zero" ] ; then \
  85            $(MAKE) -f sa.make $(GENERATED)/sa-jdi.jar; \
  86         fi
  87 
  88 $(GENERATED)/sa-jdi.jar: $(AGENT_FILES)
  89         $(QUIETLY) echo $(LOG_INFO) "Making $@"
  90         $(QUIETLY) if [ "$(BOOT_JAVA_HOME)" = "" ]; then \
  91           echo "ALT_BOOTDIR, BOOTDIR or JAVA_HOME needs to be defined to build SA"; \
  92           exit 1; \
  93         fi
  94         $(QUIETLY) if [ ! -f "$(SA_CLASSPATH)" -a ! -d $(MODULELIB_PATH) ] ; then \
  95           echo "Cannot find JDI classes. Use 1.6.0 or later version of JDK."; \
  96           echo ""; \
  97           exit 1; \
  98         fi
  99         $(QUIETLY) if [ ! -d $(SA_CLASSDIR) ] ; then \
 100           mkdir -p $(SA_CLASSDIR);        \
 101         fi
 102 # Note: When indented, make tries to execute the '$(shell' comment.
 103 # In some environments, cmd processors have limited line length.
 104 # To prevent the javac invocation in the next block from using
 105 # a very long cmd line, we use javac's @file-list option. We
 106 # generate the file lists using make's built-in 'foreach' control
 107 # flow which also avoids cmd processor line length issues. Since
 108 # the 'foreach' is done as part of make's macro expansion phase,
 109 # the initialization of the lists is also done in the same phase