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 |