make/linux/makefiles/gcc.make

Wed, 10 Jul 2013 09:14:25 -0700

author
simonis
date
Wed, 10 Jul 2013 09:14:25 -0700
changeset 6452
faf0c78e906b
parent 5315
cc63bcb47cce
child 6462
e2722a66aba7
permissions
-rw-r--r--

8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
Summary: HotSpot make changes to build the HotSpot on Linux/PPC64
Reviewed-by: dholmes, kvn

     1 #
     2 # Copyright (c) 1999, 2013, 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.
     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 #
    25 #------------------------------------------------------------------------
    26 # CC, CXX & AS
    28 # If a SPEC is not set already, then use these defaults.
    29 ifeq ($(SPEC),)
    30   # When cross-compiling the ALT_COMPILER_PATH points
    31   # to the cross-compilation toolset
    32   ifdef CROSS_COMPILE_ARCH
    33     CXX = $(ALT_COMPILER_PATH)/g++
    34     CC  = $(ALT_COMPILER_PATH)/gcc
    35     HOSTCXX = g++
    36     HOSTCC  = gcc
    37     STRIP = $(ALT_COMPILER_PATH)/strip
    38   else
    39     ifeq ($(USE_CLANG), true)
    40       CXX = clang++
    41       CC  = clang
    42     else
    43       CXX = g++
    44       CC  = gcc
    45     endif
    47     HOSTCXX = $(CXX)
    48     HOSTCC  = $(CC)
    49     STRIP = strip
    50   endif
    51   AS  = $(CC) -c
    52 endif
    55 ifeq ($(USE_CLANG), true)
    56   CC_VER_MAJOR := $(shell $(CC) -v 2>&1 | grep version | sed "s/.*version \([0-9]*\.[0-9]*\).*/\1/" | cut -d'.' -f1)
    57   CC_VER_MINOR := $(shell $(CC) -v 2>&1 | grep version | sed "s/.*version \([0-9]*\.[0-9]*\).*/\1/" | cut -d'.' -f2)
    58 else
    59   # -dumpversion in gcc-2.91 shows "egcs-2.91.66". In later version, it only
    60   # prints the numbers (e.g. "2.95", "3.2.1")
    61   CC_VER_MAJOR := $(shell $(CC) -dumpversion | sed 's/egcs-//' | cut -d'.' -f1)
    62   CC_VER_MINOR := $(shell $(CC) -dumpversion | sed 's/egcs-//' | cut -d'.' -f2)
    63 endif
    66 ifeq ($(USE_CLANG), true)
    67   # Clang has precompiled headers support by default, but the user can switch
    68   # it off by using 'USE_PRECOMPILED_HEADER=0'.
    69   ifdef LP64
    70     ifeq ($(USE_PRECOMPILED_HEADER),)
    71       USE_PRECOMPILED_HEADER=1
    72     endif
    73   else
    74     # We don't support precompiled headers on 32-bit builds because there some files are
    75     # compiled with -fPIC while others are compiled without (see 'NONPIC_OBJ_FILES' rules.make)
    76     # Clang produces an error if the PCH file was compiled with other options than the actual compilation unit.
    77     USE_PRECOMPILED_HEADER=0
    78   endif
    80   ifeq ($(USE_PRECOMPILED_HEADER),1)
    82     ifndef LP64
    83       $(error " Precompiled Headers only supported on 64-bit platforms!")
    84     endif
    86     PRECOMPILED_HEADER_DIR=.
    87     PRECOMPILED_HEADER_SRC=$(GAMMADIR)/src/share/vm/precompiled/precompiled.hpp
    88     PRECOMPILED_HEADER=$(PRECOMPILED_HEADER_DIR)/precompiled.hpp.pch
    90     PCH_FLAG = -include precompiled.hpp
    91     PCH_FLAG/DEFAULT = $(PCH_FLAG)
    92     PCH_FLAG/NO_PCH = -DNO_PCH
    93     PCH_FLAG/BY_FILE = $(PCH_FLAG/$@)$(PCH_FLAG/DEFAULT$(PCH_FLAG/$@))
    95     VM_PCH_FLAG/LIBJVM = $(PCH_FLAG/BY_FILE)
    96     VM_PCH_FLAG/AOUT =
    97     VM_PCH_FLAG = $(VM_PCH_FLAG/$(LINK_INTO))
    99     # We only use precompiled headers for the JVM build
   100     CFLAGS += $(VM_PCH_FLAG)
   102     # There are some files which don't like precompiled headers
   103     # The following files are build with 'OPT_CFLAGS/NOOPT' (-O0) in the opt build.
   104     # But Clang doesn't support a precompiled header which was compiled with -O3
   105     # to be used in a compilation unit which uses '-O0'. We could also prepare an
   106     # extra '-O0' PCH file for the opt build and use it here, but it's probably
   107     # not worth the effoert as long as only two files need this special handling.
   108     PCH_FLAG/loopTransform.o = $(PCH_FLAG/NO_PCH)
   109     PCH_FLAG/sharedRuntimeTrig.o = $(PCH_FLAG/NO_PCH)
   110     PCH_FLAG/sharedRuntimeTrans.o = $(PCH_FLAG/NO_PCH)
   112   endif
   113 else # ($(USE_CLANG), true)
   114   # check for precompiled headers support
   115   ifneq "$(shell expr \( $(CC_VER_MAJOR) \> 3 \) \| \( \( $(CC_VER_MAJOR) = 3 \) \& \( $(CC_VER_MINOR) \>= 4 \) \))" "0"
   116     # Allow the user to turn off precompiled headers from the command line.
   117     ifneq ($(USE_PRECOMPILED_HEADER),0)
   118       PRECOMPILED_HEADER_DIR=.
   119       PRECOMPILED_HEADER_SRC=$(GAMMADIR)/src/share/vm/precompiled/precompiled.hpp
   120       PRECOMPILED_HEADER=$(PRECOMPILED_HEADER_DIR)/precompiled.hpp.gch
   121     endif
   122   endif
   123 endif
   125 # -DDONT_USE_PRECOMPILED_HEADER will exclude all includes in precompiled.hpp.
   126 ifeq ($(USE_PRECOMPILED_HEADER),0)
   127   CFLAGS += -DDONT_USE_PRECOMPILED_HEADER
   128 endif
   131 #------------------------------------------------------------------------
   132 # Compiler flags
   134 # position-independent code
   135 PICFLAG = -fPIC
   137 VM_PICFLAG/LIBJVM = $(PICFLAG)
   138 VM_PICFLAG/AOUT   =
   139 VM_PICFLAG        = $(VM_PICFLAG/$(LINK_INTO))
   141 ifeq ($(JVM_VARIANT_ZERO), true)
   142 CFLAGS += $(LIBFFI_CFLAGS)
   143 endif
   144 ifeq ($(JVM_VARIANT_ZEROSHARK), true)
   145 CFLAGS += $(LIBFFI_CFLAGS)
   146 CFLAGS += $(LLVM_CFLAGS)
   147 endif
   148 CFLAGS += $(VM_PICFLAG)
   149 CFLAGS += -fno-rtti
   150 CFLAGS += -fno-exceptions
   151 CFLAGS += -D_REENTRANT
   152 ifeq ($(USE_CLANG),)
   153   CFLAGS += -fcheck-new
   154   # version 4 and above support fvisibility=hidden (matches jni_x86.h file)
   155   # except 4.1.2 gives pointless warnings that can't be disabled (afaik)
   156   ifneq "$(shell expr \( $(CC_VER_MAJOR) \> 4 \) \| \( \( $(CC_VER_MAJOR) = 4 \) \& \( $(CC_VER_MINOR) \>= 3 \) \))" "0"
   157     CFLAGS += -fvisibility=hidden
   158   endif
   159 else
   160   CFLAGS += -fvisibility=hidden
   161 endif
   163 ifeq ($(USE_CLANG), true)
   164   # Before Clang 3.1, we had to pass the stack alignment specification directly to llvm with the help of '-mllvm'
   165   # Starting with version 3.1, Clang understands the '-mstack-alignment' (and rejects '-mllvm -stack-alignment')
   166   ifneq "$(shell expr \( $(CC_VER_MAJOR) \> 3 \) \| \( \( $(CC_VER_MAJOR) = 3 \) \& \( $(CC_VER_MINOR) \>= 1 \) \))" "0"
   167     STACK_ALIGNMENT_OPT = -mno-omit-leaf-frame-pointer -mstack-alignment=16
   168   else
   169     STACK_ALIGNMENT_OPT = -mno-omit-leaf-frame-pointer -mllvm -stack-alignment=16
   170   endif
   171 endif
   173 ARCHFLAG = $(ARCHFLAG/$(BUILDARCH))
   174 ARCHFLAG/i486    = -m32 -march=i586
   175 ARCHFLAG/amd64   = -m64 $(STACK_ALIGNMENT_OPT)
   176 ARCHFLAG/ia64    =
   177 ARCHFLAG/sparc   = -m32 -mcpu=v9
   178 ARCHFLAG/sparcv9 = -m64 -mcpu=v9
   179 ARCHFLAG/arm     =  -fsigned-char
   180 ARCHFLAG/zero    = $(ZERO_ARCHFLAG)
   181 ifndef E500V2
   182 ARCHFLAG/ppc     =  -mcpu=powerpc
   183 endif
   184 ARCHFLAG/ppc64   =  -m64
   186 CFLAGS     += $(ARCHFLAG)
   187 AOUT_FLAGS += $(ARCHFLAG)
   188 LFLAGS     += $(ARCHFLAG)
   189 ASFLAGS    += $(ARCHFLAG)
   191 ifdef E500V2
   192 CFLAGS += -DE500V2
   193 endif
   195 # Use C++ Interpreter
   196 ifdef CC_INTERP
   197   CFLAGS += -DCC_INTERP
   198 endif
   200 # Keep temporary files (.ii, .s)
   201 ifdef NEED_ASM
   202   CFLAGS += -save-temps
   203 else
   204   CFLAGS += -pipe
   205 endif
   207 # Compiler warnings are treated as errors
   208 WARNINGS_ARE_ERRORS = -Werror
   210 ifeq ($(USE_CLANG), true)
   211   # However we need to clean the code up before we can unrestrictedly enable this option with Clang
   212   WARNINGS_ARE_ERRORS += -Wno-unused-value -Wno-logical-op-parentheses -Wno-parentheses-equality -Wno-parentheses
   213   WARNINGS_ARE_ERRORS += -Wno-switch -Wno-tautological-constant-out-of-range-compare -Wno-tautological-compare
   214   WARNINGS_ARE_ERRORS += -Wno-delete-non-virtual-dtor -Wno-deprecated -Wno-format -Wno-dynamic-class-memaccess
   215   WARNINGS_ARE_ERRORS += -Wno-return-type -Wno-empty-body
   216 endif
   218 WARNING_FLAGS = -Wpointer-arith -Wsign-compare -Wundef -Wunused-function -Wunused-value
   220 ifeq ($(USE_CLANG),)
   221   # Since GCC 4.3, -Wconversion has changed its meanings to warn these implicit
   222   # conversions which might affect the values. Only enable it in earlier versions.
   223   ifeq "$(shell expr \( $(CC_VER_MAJOR) \> 4 \) \| \( \( $(CC_VER_MAJOR) = 4 \) \& \( $(CC_VER_MINOR) \>= 3 \) \))" "0"
   224     WARNING_FLAGS += -Wconversion
   225   endif
   226 endif
   228 CFLAGS_WARN/DEFAULT = $(WARNINGS_ARE_ERRORS) $(WARNING_FLAGS)
   229 # Special cases
   230 CFLAGS_WARN/BYFILE = $(CFLAGS_WARN/$@)$(CFLAGS_WARN/DEFAULT$(CFLAGS_WARN/$@)) 
   232 # The flags to use for an Optimized g++ build
   233 OPT_CFLAGS/SIZE=-Os
   234 OPT_CFLAGS/SPEED=-O3
   236 # Hotspot uses very unstrict aliasing turn this optimization off
   237 # This option is added to CFLAGS rather than OPT_CFLAGS
   238 # so that OPT_CFLAGS overrides get this option too.
   239 CFLAGS += -fno-strict-aliasing 
   241 OPT_CFLAGS_DEFAULT ?= SPEED
   243 ifdef OPT_CFLAGS
   244   ifneq ("$(origin OPT_CFLAGS)", "command line")
   245     $(error " Use OPT_EXTRAS instead of OPT_CFLAGS to add extra flags to OPT_CFLAGS.")
   246   endif
   247 endif
   249 OPT_CFLAGS = $(OPT_CFLAGS/$(OPT_CFLAGS_DEFAULT)) $(OPT_EXTRAS)
   251 # The gcc compiler segv's on ia64 when compiling bytecodeInterpreter.cpp 
   252 # if we use expensive-optimizations
   253 ifeq ($(BUILDARCH), ia64)
   254 OPT_CFLAGS += -fno-expensive-optimizations
   255 endif
   257 OPT_CFLAGS/NOOPT=-O0
   259 # Work around some compiler bugs.
   260 ifeq ($(USE_CLANG), true)
   261   ifeq ($(shell expr $(CC_VER_MAJOR) = 4 \& $(CC_VER_MINOR) = 2), 1)
   262     OPT_CFLAGS/loopTransform.o += $(OPT_CFLAGS/NOOPT)
   263   endif
   264 else
   265   # 6835796. Problem in GCC 4.3.0 with mulnode.o optimized compilation.
   266   ifeq ($(shell expr $(CC_VER_MAJOR) = 4 \& $(CC_VER_MINOR) = 3), 1)
   267     OPT_CFLAGS/mulnode.o += $(OPT_CFLAGS/NOOPT)
   268   endif
   269 endif
   271 # Flags for generating make dependency flags.
   272 DEPFLAGS = -MMD -MP -MF $(DEP_DIR)/$(@:%=%.d)
   273 ifeq ($(USE_CLANG),)
   274   ifneq ("${CC_VER_MAJOR}", "2")
   275     DEPFLAGS += -fpch-deps
   276   endif
   277 endif
   279 #------------------------------------------------------------------------
   280 # Linker flags
   282 # statically link libstdc++.so, work with gcc but ignored by g++
   283 STATIC_STDCXX = -Wl,-Bstatic -lstdc++ -Wl,-Bdynamic
   285 ifeq ($(USE_CLANG),)
   286   # statically link libgcc and/or libgcc_s, libgcc does not exist before gcc-3.x.
   287   ifneq ("${CC_VER_MAJOR}", "2")
   288     STATIC_LIBGCC += -static-libgcc
   289   endif
   291   ifeq ($(BUILDARCH), ia64)
   292     LFLAGS += -Wl,-relax
   293   endif
   294 endif
   296 # Enable linker optimization
   297 LFLAGS += -Xlinker -O1
   299 ifeq ($(USE_CLANG),)
   300   # If this is a --hash-style=gnu system, use --hash-style=both
   301   #   The gnu .hash section won't work on some Linux systems like SuSE 10.
   302   _HAS_HASH_STYLE_GNU:=$(shell $(CC) -dumpspecs | grep -- '--hash-style=gnu')
   303   ifneq ($(_HAS_HASH_STYLE_GNU),)
   304     LDFLAGS_HASH_STYLE = -Wl,--hash-style=both
   305   endif
   306 else
   307   # Don't know how to find out the 'hash style' of a system as '-dumpspecs'
   308   # doesn't work for Clang. So for now we'll alwys use --hash-style=both
   309   LDFLAGS_HASH_STYLE = -Wl,--hash-style=both
   310 endif
   312 LFLAGS += $(LDFLAGS_HASH_STYLE)
   314 # Use $(MAPFLAG:FILENAME=real_file_name) to specify a map file.
   315 MAPFLAG = -Xlinker --version-script=FILENAME
   317 # Use $(SONAMEFLAG:SONAME=soname) to specify the intrinsic name of a shared obj
   318 SONAMEFLAG = -Xlinker -soname=SONAME
   320 # Build shared library
   321 SHARED_FLAG = -shared
   323 # Keep symbols even they are not used
   324 AOUT_FLAGS += -Xlinker -export-dynamic
   326 #------------------------------------------------------------------------
   327 # Debug flags
   329 ifeq ($(USE_CLANG), true)
   330   # Restrict the debug information created by Clang to avoid
   331   # too big object files and speed the build up a little bit
   332   # (see http://llvm.org/bugs/show_bug.cgi?id=7554)
   333   CFLAGS += -flimit-debug-info
   334 endif
   336 # DEBUG_BINARIES uses full -g debug information for all configs
   337 ifeq ($(DEBUG_BINARIES), true)
   338   CFLAGS += -g
   339 else
   340   # Use the stabs format for debugging information (this is the default
   341   # on gcc-2.91). It's good enough, has all the information about line
   342   # numbers and local variables, and libjvm.so is only about 16M.
   343   # Change this back to "-g" if you want the most expressive format.
   344   # (warning: that could easily inflate libjvm.so to 150M!)
   345   # Note: The Itanium gcc compiler crashes when using -gstabs.
   346   DEBUG_CFLAGS/ia64  = -g
   347   DEBUG_CFLAGS/amd64 = -g
   348   DEBUG_CFLAGS/arm   = -g
   349   DEBUG_CFLAGS/ppc   = -g
   350   DEBUG_CFLAGS/ppc64 = -g
   351   DEBUG_CFLAGS += $(DEBUG_CFLAGS/$(BUILDARCH))
   352   ifeq ($(DEBUG_CFLAGS/$(BUILDARCH)),)
   353       ifeq ($(USE_CLANG), true)
   354         # Clang doesn't understand -gstabs
   355         DEBUG_CFLAGS += -g
   356       else
   357         DEBUG_CFLAGS += -gstabs
   358       endif
   359   endif
   361   ifeq ($(ENABLE_FULL_DEBUG_SYMBOLS),1)
   362     FASTDEBUG_CFLAGS/ia64  = -g
   363     FASTDEBUG_CFLAGS/amd64 = -g
   364     FASTDEBUG_CFLAGS/arm   = -g
   365     FASTDEBUG_CFLAGS/ppc   = -g
   366     FASTDEBUG_CFLAGS/ppc64 = -g
   367     FASTDEBUG_CFLAGS += $(DEBUG_CFLAGS/$(BUILDARCH))
   368     ifeq ($(FASTDEBUG_CFLAGS/$(BUILDARCH)),)
   369       ifeq ($(USE_CLANG), true)
   370         # Clang doesn't understand -gstabs
   371         FASTDEBUG_CFLAGS += -g
   372       else
   373         FASTDEBUG_CFLAGS += -gstabs
   374       endif
   375     endif
   377     OPT_CFLAGS/ia64  = -g
   378     OPT_CFLAGS/amd64 = -g
   379     OPT_CFLAGS/arm   = -g
   380     OPT_CFLAGS/ppc   = -g
   381     OPT_CFLAGS/ppc64 = -g
   382     OPT_CFLAGS += $(OPT_CFLAGS/$(BUILDARCH))
   383     ifeq ($(OPT_CFLAGS/$(BUILDARCH)),)
   384       ifeq ($(USE_CLANG), true)
   385         # Clang doesn't understand -gstabs
   386         OPT_CFLAGS += -g
   387       else
   388         OPT_CFLAGS += -gstabs
   389       endif
   390     endif
   391   endif
   392 endif
   394 # If we are building HEADLESS, pass on to VM
   395 # so it can set the java.awt.headless property
   396 ifdef HEADLESS
   397 CFLAGS += -DHEADLESS
   398 endif
   400 # We are building Embedded for a small device
   401 # favor code space over speed
   402 ifdef MINIMIZE_RAM_USAGE
   403 CFLAGS += -DMINIMIZE_RAM_USAGE
   404 endif

mercurial