make/linux/makefiles/rules.make

Fri, 25 Mar 2011 09:35:39 +0100

author
roland
date
Fri, 25 Mar 2011 09:35:39 +0100
changeset 2683
7e88bdae86ec
parent 2515
d8a72fbc4be7
child 3518
719f7007c8e8
permissions
-rw-r--r--

7029017: Additional architecture support for c2 compiler
Summary: Enables cross building of a c2 VM. Support masking of shift counts when the processor architecture mandates it.
Reviewed-by: kvn, never

duke@435 1 #
kamg@2515 2 # Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
duke@435 3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@435 4 #
duke@435 5 # This code is free software; you can redistribute it and/or modify it
duke@435 6 # under the terms of the GNU General Public License version 2 only, as
duke@435 7 # published by the Free Software Foundation.
duke@435 8 #
duke@435 9 # This code is distributed in the hope that it will be useful, but WITHOUT
duke@435 10 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@435 11 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@435 12 # version 2 for more details (a copy is included in the LICENSE file that
duke@435 13 # accompanied this code).
duke@435 14 #
duke@435 15 # You should have received a copy of the GNU General Public License version
duke@435 16 # 2 along with this work; if not, write to the Free Software Foundation,
duke@435 17 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@435 18 #
trims@1907 19 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
trims@1907 20 # or visit www.oracle.com if you need additional information or have any
trims@1907 21 # questions.
duke@435 22 #
duke@435 23 #
duke@435 24
duke@435 25 # Common rules/macros for the vm, adlc.
duke@435 26
duke@435 27 # Tell make that .cpp is important
duke@435 28 .SUFFIXES: .cpp $(SUFFIXES)
duke@435 29
duke@435 30 # For now. Other makefiles use CPP as the c++ compiler, but that should really
duke@435 31 # name the preprocessor.
duke@435 32 ifeq ($(CCC),)
duke@435 33 CCC = $(CPP)
duke@435 34 endif
duke@435 35
duke@435 36 DEMANGLER = c++filt
duke@435 37 DEMANGLE = $(DEMANGLER) < $@ > .$@ && mv -f .$@ $@
duke@435 38
duke@435 39 # $(CC) is the c compiler (cc/gcc), $(CCC) is the c++ compiler (CC/g++).
duke@435 40 C_COMPILE = $(CC) $(CPPFLAGS) $(CFLAGS)
duke@435 41 CC_COMPILE = $(CCC) $(CPPFLAGS) $(CFLAGS)
duke@435 42
duke@435 43 AS.S = $(AS) $(ASFLAGS)
duke@435 44
duke@435 45 COMPILE.c = $(C_COMPILE) -c
duke@435 46 GENASM.c = $(C_COMPILE) -S
duke@435 47 LINK.c = $(CC) $(LFLAGS) $(AOUT_FLAGS) $(PROF_AOUT_FLAGS)
duke@435 48 LINK_LIB.c = $(CC) $(LFLAGS) $(SHARED_FLAG)
duke@435 49 PREPROCESS.c = $(C_COMPILE) -E
duke@435 50
duke@435 51 COMPILE.CC = $(CC_COMPILE) -c
duke@435 52 GENASM.CC = $(CC_COMPILE) -S
duke@435 53 LINK.CC = $(CCC) $(LFLAGS) $(AOUT_FLAGS) $(PROF_AOUT_FLAGS)
duke@435 54 LINK_NOPROF.CC = $(CCC) $(LFLAGS) $(AOUT_FLAGS)
duke@435 55 LINK_LIB.CC = $(CCC) $(LFLAGS) $(SHARED_FLAG)
duke@435 56 PREPROCESS.CC = $(CC_COMPILE) -E
duke@435 57
roland@2683 58 # cross compiling the jvm with c2 requires host compilers to build
roland@2683 59 # adlc tool
roland@2683 60
roland@2683 61 HOST.CC_COMPILE = $(HOSTCPP) $(CPPFLAGS) $(CFLAGS)
roland@2683 62 HOST.COMPILE.CC = $(HOST.CC_COMPILE) -c
roland@2683 63 HOST.LINK_NOPROF.CC = $(HOSTCPP) $(LFLAGS) $(AOUT_FLAGS)
roland@2683 64
roland@2683 65
duke@435 66 # Effect of REMOVE_TARGET is to delete out-of-date files during "gnumake -k".
duke@435 67 REMOVE_TARGET = rm -f $@
duke@435 68
duke@435 69 # Synonyms.
duke@435 70 COMPILE.cpp = $(COMPILE.CC)
duke@435 71 GENASM.cpp = $(GENASM.CC)
duke@435 72 LINK.cpp = $(LINK.CC)
duke@435 73 LINK_LIB.cpp = $(LINK_LIB.CC)
duke@435 74 PREPROCESS.cpp = $(PREPROCESS.CC)
duke@435 75
duke@435 76 # Note use of ALT_BOOTDIR to explicitly specify location of java and
duke@435 77 # javac; this is the same environment variable used in the J2SE build
duke@435 78 # process for overriding the default spec, which is BOOTDIR.
duke@435 79 # Note also that we fall back to using JAVA_HOME if neither of these is
duke@435 80 # specified.
duke@435 81
duke@435 82 ifdef ALT_BOOTDIR
duke@435 83
duke@435 84 RUN.JAVA = $(ALT_BOOTDIR)/bin/java
duke@435 85 RUN.JAVAP = $(ALT_BOOTDIR)/bin/javap
duke@435 86 RUN.JAVAH = $(ALT_BOOTDIR)/bin/javah
duke@435 87 RUN.JAR = $(ALT_BOOTDIR)/bin/jar
duke@435 88 COMPILE.JAVAC = $(ALT_BOOTDIR)/bin/javac
duke@435 89 COMPILE.RMIC = $(ALT_BOOTDIR)/bin/rmic
duke@435 90 BOOT_JAVA_HOME = $(ALT_BOOTDIR)
duke@435 91
duke@435 92 else
duke@435 93
duke@435 94 ifdef BOOTDIR
duke@435 95
duke@435 96 RUN.JAVA = $(BOOTDIR)/bin/java
duke@435 97 RUN.JAVAP = $(BOOTDIR)/bin/javap
duke@435 98 RUN.JAVAH = $(BOOTDIR)/bin/javah
duke@435 99 RUN.JAR = $(BOOTDIR)/bin/jar
duke@435 100 COMPILE.JAVAC = $(BOOTDIR)/bin/javac
duke@435 101 COMPILE.RMIC = $(BOOTDIR)/bin/rmic
duke@435 102 BOOT_JAVA_HOME = $(BOOTDIR)
duke@435 103
duke@435 104 else
duke@435 105
duke@435 106 ifdef JAVA_HOME
duke@435 107
duke@435 108 RUN.JAVA = $(JAVA_HOME)/bin/java
duke@435 109 RUN.JAVAP = $(JAVA_HOME)/bin/javap
duke@435 110 RUN.JAVAH = $(JAVA_HOME)/bin/javah
duke@435 111 RUN.JAR = $(JAVA_HOME)/bin/jar
duke@435 112 COMPILE.JAVAC = $(JAVA_HOME)/bin/javac
duke@435 113 COMPILE.RMIC = $(JAVA_HOME)/bin/rmic
duke@435 114 BOOT_JAVA_HOME = $(JAVA_HOME)
duke@435 115
duke@435 116 else
duke@435 117
duke@435 118 # take from the PATH, if ALT_BOOTDIR, BOOTDIR and JAVA_HOME are not defined
duke@435 119 # note that this is to support hotspot build without SA. To build
duke@435 120 # SA along with hotspot, you need to define ALT_BOOTDIR, BOOTDIR or JAVA_HOME
duke@435 121
duke@435 122 RUN.JAVA = java
duke@435 123 RUN.JAVAP = javap
duke@435 124 RUN.JAVAH = javah
duke@435 125 RUN.JAR = jar
duke@435 126 COMPILE.JAVAC = javac
duke@435 127 COMPILE.RMIC = rmic
duke@435 128
duke@435 129 endif
duke@435 130 endif
duke@435 131 endif
duke@435 132
andrew@1406 133 COMPILE.JAVAC += $(BOOTSTRAP_JAVAC_FLAGS)
andrew@1406 134
duke@435 135 SUM = /usr/bin/sum
duke@435 136
duke@435 137 # 'gmake MAKE_VERBOSE=y' gives all the gory details.
duke@435 138 QUIETLY$(MAKE_VERBOSE) = @
duke@435 139 RUN.JAR$(MAKE_VERBOSE) += >/dev/null
duke@435 140
andrew@1406 141 # Settings for javac
andrew@1406 142 BOOT_SOURCE_LANGUAGE_VERSION = 6
andrew@1406 143 BOOT_TARGET_CLASS_VERSION = 6
andrew@1406 144 JAVAC_FLAGS = -g -encoding ascii
andrew@1406 145 BOOTSTRAP_JAVAC_FLAGS = $(JAVAC_FLAGS) -source $(BOOT_SOURCE_LANGUAGE_VERSION) -target $(BOOT_TARGET_CLASS_VERSION)
andrew@1406 146
duke@435 147 # With parallel makes, print a message at the end of compilation.
duke@435 148 ifeq ($(findstring j,$(MFLAGS)),j)
duke@435 149 COMPILE_DONE = && { echo Done with $<; }
duke@435 150 endif
duke@435 151
xlu@663 152 # Include $(NONPIC_OBJ_FILES) definition
xlu@663 153 ifndef LP64
xlu@663 154 include $(GAMMADIR)/make/pic.make
xlu@663 155 endif
xlu@633 156
kamg@2515 157 include $(GAMMADIR)/make/altsrc.make
bobv@2508 158
xlu@633 159 # The non-PIC object files are only generated for 32 bit platforms.
xlu@633 160 ifdef LP64
duke@435 161 %.o: %.cpp
duke@435 162 @echo Compiling $<
duke@435 163 $(QUIETLY) $(REMOVE_TARGET)
stefank@2314 164 $(QUIETLY) $(COMPILE.CC) $(DEPFLAGS) -o $@ $< $(COMPILE_DONE)
xlu@633 165 else
xlu@633 166 %.o: %.cpp
xlu@633 167 @echo Compiling $<
xlu@633 168 $(QUIETLY) $(REMOVE_TARGET)
xlu@633 169 $(QUIETLY) $(if $(findstring $@, $(NONPIC_OBJ_FILES)), \
stefank@2314 170 $(subst $(VM_PICFLAG), ,$(COMPILE.CC)) $(DEPFLAGS) -o $@ $< $(COMPILE_DONE), \
stefank@2314 171 $(COMPILE.CC) $(DEPFLAGS) -o $@ $< $(COMPILE_DONE))
xlu@633 172 endif
duke@435 173
duke@435 174 %.o: %.s
duke@435 175 @echo Assembling $<
duke@435 176 $(QUIETLY) $(REMOVE_TARGET)
stefank@2314 177 $(QUIETLY) $(AS.S) $(DEPFLAGS) -o $@ $< $(COMPILE_DONE)
duke@435 178
duke@435 179 %.s: %.cpp
duke@435 180 @echo Generating assembly for $<
duke@435 181 $(QUIETLY) $(GENASM.CC) -o $@ $<
duke@435 182 $(QUIETLY) $(DEMANGLE) $(COMPILE_DONE)
duke@435 183
duke@435 184 # Intermediate files (for debugging macros)
duke@435 185 %.i: %.cpp
duke@435 186 @echo Preprocessing $< to $@
duke@435 187 $(QUIETLY) $(PREPROCESS.CC) $< > $@ $(COMPILE_DONE)
duke@435 188
duke@435 189 # Override gnumake built-in rules which do sccs get operations badly.
duke@435 190 # (They put the checked out code in the current directory, not in the
duke@435 191 # directory of the original file.) Since this is a symptom of a teamware
duke@435 192 # failure, and since not all problems can be detected by gnumake due
duke@435 193 # to incomplete dependency checking... just complain and stop.
duke@435 194 %:: s.%
duke@435 195 @echo "========================================================="
duke@435 196 @echo File $@
duke@435 197 @echo is out of date with respect to its SCCS file.
duke@435 198 @echo This file may be from an unresolved Teamware conflict.
duke@435 199 @echo This is also a symptom of a Teamware bringover/putback failure
duke@435 200 @echo in which SCCS files are updated but not checked out.
duke@435 201 @echo Check for other out of date files in your workspace.
duke@435 202 @echo "========================================================="
duke@435 203 @exit 666
duke@435 204
duke@435 205 %:: SCCS/s.%
duke@435 206 @echo "========================================================="
duke@435 207 @echo File $@
duke@435 208 @echo is out of date with respect to its SCCS file.
duke@435 209 @echo This file may be from an unresolved Teamware conflict.
duke@435 210 @echo This is also a symptom of a Teamware bringover/putback failure
duke@435 211 @echo in which SCCS files are updated but not checked out.
duke@435 212 @echo Check for other out of date files in your workspace.
duke@435 213 @echo "========================================================="
duke@435 214 @exit 666
duke@435 215
duke@435 216 .PHONY: default

mercurial