common/autoconf/flags.m4

Thu, 05 Apr 2018 07:59:52 -0700

author
kevinw
date
Thu, 05 Apr 2018 07:59:52 -0700
changeset 2206
7ba4e17574e0
child 2215
7a73b8b4ac8a
permissions
-rw-r--r--

8034788: Rewrite toolchain.m4 to support multiple toolchains per platform.
Reviewed-by: ihse, henryjen, erikj

kevinw@2206 1 #
kevinw@2206 2 # Copyright (c) 2011, 2018, Oracle and/or its affiliates. All rights reserved.
kevinw@2206 3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
kevinw@2206 4 #
kevinw@2206 5 # This code is free software; you can redistribute it and/or modify it
kevinw@2206 6 # under the terms of the GNU General Public License version 2 only, as
kevinw@2206 7 # published by the Free Software Foundation. Oracle designates this
kevinw@2206 8 # particular file as subject to the "Classpath" exception as provided
kevinw@2206 9 # by Oracle in the LICENSE file that accompanied this code.
kevinw@2206 10 #
kevinw@2206 11 # This code is distributed in the hope that it will be useful, but WITHOUT
kevinw@2206 12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
kevinw@2206 13 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kevinw@2206 14 # version 2 for more details (a copy is included in the LICENSE file that
kevinw@2206 15 # accompanied this code).
kevinw@2206 16 #
kevinw@2206 17 # You should have received a copy of the GNU General Public License version
kevinw@2206 18 # 2 along with this work; if not, write to the Free Software Foundation,
kevinw@2206 19 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
kevinw@2206 20 #
kevinw@2206 21 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
kevinw@2206 22 # or visit www.oracle.com if you need additional information or have any
kevinw@2206 23 # questions.
kevinw@2206 24 #
kevinw@2206 25
kevinw@2206 26 AC_DEFUN_ONCE([FLAGS_SETUP_INIT_FLAGS],
kevinw@2206 27 [
kevinw@2206 28 # Option used to tell the compiler whether to create 32- or 64-bit executables
kevinw@2206 29 if test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 30 COMPILER_TARGET_BITS_FLAG="-q"
kevinw@2206 31 else
kevinw@2206 32 COMPILER_TARGET_BITS_FLAG="-m"
kevinw@2206 33 fi
kevinw@2206 34 AC_SUBST(COMPILER_TARGET_BITS_FLAG)
kevinw@2206 35
kevinw@2206 36 # FIXME: figure out if we should select AR flags depending on OS or toolchain.
kevinw@2206 37 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 38 ARFLAGS="-r"
kevinw@2206 39 elif test "x$OPENJDK_TARGET_OS" = xaix; then
kevinw@2206 40 ARFLAGS="-X64"
kevinw@2206 41 elif test "x$OPENJDK_TARGET_OS" = xwindows; then
kevinw@2206 42 # lib.exe is used as AR to create static libraries.
kevinw@2206 43 ARFLAGS="-nologo -NODEFAULTLIB:MSVCRT"
kevinw@2206 44 else
kevinw@2206 45 ARFLAGS=""
kevinw@2206 46 fi
kevinw@2206 47 AC_SUBST(ARFLAGS)
kevinw@2206 48
kevinw@2206 49 ## Setup strip.
kevinw@2206 50 # FIXME: should this really be per platform, or should it be per toolchain type?
kevinw@2206 51 # strip is not provided by clang or solstudio; so guessing platform makes most sense.
kevinw@2206 52 # FIXME: we should really only export STRIPFLAGS from here, not POST_STRIP_CMD.
kevinw@2206 53 if test "x$OPENJDK_TARGET_OS" = xlinux; then
kevinw@2206 54 STRIPFLAGS="-g"
kevinw@2206 55 elif test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 56 STRIPFLAGS="-x"
kevinw@2206 57 elif test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 58 STRIPFLAGS="-S"
kevinw@2206 59 elif test "x$OPENJDK_TARGET_OS" = xaix; then
kevinw@2206 60 STRIPFLAGS="-X32_64"
kevinw@2206 61 fi
kevinw@2206 62
kevinw@2206 63 if test "x$OPENJDK_TARGET_OS" != xwindows; then
kevinw@2206 64 POST_STRIP_CMD="$STRIP $STRIPFLAGS"
kevinw@2206 65 fi
kevinw@2206 66 AC_SUBST(POST_STRIP_CMD)
kevinw@2206 67
kevinw@2206 68 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 69 # FIXME: break out into MCSFLAGS
kevinw@2206 70 POST_MCS_CMD="$MCS -d -a \"JDK $FULL_VERSION\""
kevinw@2206 71 fi
kevinw@2206 72 AC_SUBST(POST_MCS_CMD)
kevinw@2206 73
kevinw@2206 74 if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 75 CC_OUT_OPTION=-Fo
kevinw@2206 76 EXE_OUT_OPTION=-out:
kevinw@2206 77 LD_OUT_OPTION=-out:
kevinw@2206 78 AR_OUT_OPTION=-out:
kevinw@2206 79 else
kevinw@2206 80 # The option used to specify the target .o,.a or .so file.
kevinw@2206 81 # When compiling, how to specify the to be created object file.
kevinw@2206 82 CC_OUT_OPTION='-o$(SPACE)'
kevinw@2206 83 # When linking, how to specify the to be created executable.
kevinw@2206 84 EXE_OUT_OPTION='-o$(SPACE)'
kevinw@2206 85 # When linking, how to specify the to be created dynamically linkable library.
kevinw@2206 86 LD_OUT_OPTION='-o$(SPACE)'
kevinw@2206 87 # When archiving, how to specify the to be create static archive for object files.
kevinw@2206 88 AR_OUT_OPTION='rcs$(SPACE)'
kevinw@2206 89 fi
kevinw@2206 90 AC_SUBST(CC_OUT_OPTION)
kevinw@2206 91 AC_SUBST(EXE_OUT_OPTION)
kevinw@2206 92 AC_SUBST(LD_OUT_OPTION)
kevinw@2206 93 AC_SUBST(AR_OUT_OPTION)
kevinw@2206 94
kevinw@2206 95 # On Windows, we need to set RC flags.
kevinw@2206 96 if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 97 RC_FLAGS="-nologo -l 0x409 -r"
kevinw@2206 98 if test "x$VARIANT" = xOPT; then
kevinw@2206 99 RC_FLAGS="$RC_FLAGS -d NDEBUG"
kevinw@2206 100 fi
kevinw@2206 101
kevinw@2206 102 # The version variables used to create RC_FLAGS may be overridden
kevinw@2206 103 # in a custom configure script, or possibly the command line.
kevinw@2206 104 # Let those variables be expanded at make time in spec.gmk.
kevinw@2206 105 # The \$ are escaped to the shell, and the $(...) variables
kevinw@2206 106 # are evaluated by make.
kevinw@2206 107 RC_FLAGS="$RC_FLAGS \
kevinw@2206 108 -d \"JDK_BUILD_ID=\$(FULL_VERSION)\" \
kevinw@2206 109 -d \"JDK_COMPANY=\$(COMPANY_NAME)\" \
kevinw@2206 110 -d \"JDK_COMPONENT=\$(PRODUCT_NAME) \$(JDK_RC_PLATFORM_NAME) binary\" \
kevinw@2206 111 -d \"JDK_VER=\$(JDK_MINOR_VERSION).\$(JDK_MICRO_VERSION).\$(if \$(JDK_UPDATE_VERSION),\$(JDK_UPDATE_VERSION),0).\$(COOKED_BUILD_NUMBER)\" \
kevinw@2206 112 -d \"JDK_COPYRIGHT=Copyright \xA9 $COPYRIGHT_YEAR\" \
kevinw@2206 113 -d \"JDK_NAME=\$(PRODUCT_NAME) \$(JDK_RC_PLATFORM_NAME) \$(JDK_MINOR_VERSION) \$(JDK_UPDATE_META_TAG)\" \
kevinw@2206 114 -d \"JDK_FVER=\$(JDK_MINOR_VERSION),\$(JDK_MICRO_VERSION),\$(if \$(JDK_UPDATE_VERSION),\$(JDK_UPDATE_VERSION),0),\$(COOKED_BUILD_NUMBER)\""
kevinw@2206 115 fi
kevinw@2206 116 AC_SUBST(RC_FLAGS)
kevinw@2206 117
kevinw@2206 118 if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 119 # FIXME: likely bug, should be CCXXFLAGS_JDK? or one for C or CXX.
kevinw@2206 120 CCXXFLAGS="$CCXXFLAGS -nologo"
kevinw@2206 121 fi
kevinw@2206 122 ])
kevinw@2206 123
kevinw@2206 124 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_LIBS],
kevinw@2206 125 [
kevinw@2206 126 ###############################################################################
kevinw@2206 127 #
kevinw@2206 128 # How to compile shared libraries.
kevinw@2206 129 #
kevinw@2206 130
kevinw@2206 131 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 132 PICFLAG="-fPIC"
kevinw@2206 133 C_FLAG_REORDER=''
kevinw@2206 134 CXX_FLAG_REORDER=''
kevinw@2206 135
kevinw@2206 136 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 137 # Linking is different on MacOSX
kevinw@2206 138 SHARED_LIBRARY_FLAGS="-dynamiclib -compatibility_version 1.0.0 -current_version 1.0.0 $PICFLAG"
kevinw@2206 139 SET_EXECUTABLE_ORIGIN='-Xlinker -rpath -Xlinker @loader_path/.'
kevinw@2206 140 SET_SHARED_LIBRARY_ORIGIN="$SET_EXECUTABLE_ORIGIN"
kevinw@2206 141 SET_SHARED_LIBRARY_NAME='-Xlinker -install_name -Xlinker @rpath/[$]1'
kevinw@2206 142 SET_SHARED_LIBRARY_MAPFILE=''
kevinw@2206 143 else
kevinw@2206 144 # Default works for linux, might work on other platforms as well.
kevinw@2206 145 SHARED_LIBRARY_FLAGS='-shared'
kevinw@2206 146 SET_EXECUTABLE_ORIGIN='-Xlinker -rpath -Xlinker \$$$$ORIGIN[$]1'
kevinw@2206 147 SET_SHARED_LIBRARY_ORIGIN="-Xlinker -z -Xlinker origin $SET_EXECUTABLE_ORIGIN"
kevinw@2206 148 SET_SHARED_LIBRARY_NAME='-Xlinker -soname=[$]1'
kevinw@2206 149 SET_SHARED_LIBRARY_MAPFILE='-Xlinker -version-script=[$]1'
kevinw@2206 150 fi
kevinw@2206 151 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 152 PICFLAG="-KPIC"
kevinw@2206 153 C_FLAG_REORDER='-xF'
kevinw@2206 154 CXX_FLAG_REORDER='-xF'
kevinw@2206 155 SHARED_LIBRARY_FLAGS="-G"
kevinw@2206 156 SET_EXECUTABLE_ORIGIN='-R\$$$$ORIGIN[$]1'
kevinw@2206 157 SET_SHARED_LIBRARY_ORIGIN="$SET_EXECUTABLE_ORIGIN"
kevinw@2206 158 SET_SHARED_LIBRARY_NAME=''
kevinw@2206 159 SET_SHARED_LIBRARY_MAPFILE='-M[$]1'
kevinw@2206 160 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 161 PICFLAG="-qpic=large"
kevinw@2206 162 C_FLAG_REORDER=''
kevinw@2206 163 CXX_FLAG_REORDER=''
kevinw@2206 164 SHARED_LIBRARY_FLAGS="-qmkshrobj"
kevinw@2206 165 SET_EXECUTABLE_ORIGIN=""
kevinw@2206 166 SET_SHARED_LIBRARY_ORIGIN=''
kevinw@2206 167 SET_SHARED_LIBRARY_NAME=''
kevinw@2206 168 SET_SHARED_LIBRARY_MAPFILE=''
kevinw@2206 169 elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 170 PICFLAG=""
kevinw@2206 171 C_FLAG_REORDER=''
kevinw@2206 172 CXX_FLAG_REORDER=''
kevinw@2206 173 SHARED_LIBRARY_FLAGS="-LD"
kevinw@2206 174 SET_EXECUTABLE_ORIGIN=''
kevinw@2206 175 SET_SHARED_LIBRARY_ORIGIN=''
kevinw@2206 176 SET_SHARED_LIBRARY_NAME=''
kevinw@2206 177 SET_SHARED_LIBRARY_MAPFILE=''
kevinw@2206 178 fi
kevinw@2206 179
kevinw@2206 180 AC_SUBST(C_FLAG_REORDER)
kevinw@2206 181 AC_SUBST(CXX_FLAG_REORDER)
kevinw@2206 182 AC_SUBST(SHARED_LIBRARY_FLAGS)
kevinw@2206 183 AC_SUBST(SET_EXECUTABLE_ORIGIN)
kevinw@2206 184 AC_SUBST(SET_SHARED_LIBRARY_ORIGIN)
kevinw@2206 185 AC_SUBST(SET_SHARED_LIBRARY_NAME)
kevinw@2206 186 AC_SUBST(SET_SHARED_LIBRARY_MAPFILE)
kevinw@2206 187
kevinw@2206 188 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 189 CFLAGS_JDK="${CFLAGS_JDK} -D__solaris__"
kevinw@2206 190 CXXFLAGS_JDK="${CXXFLAGS_JDK} -D__solaris__"
kevinw@2206 191 CFLAGS_JDKLIB_EXTRA='-xstrconst'
kevinw@2206 192 fi
kevinw@2206 193 # The (cross) compiler is now configured, we can now test capabilities
kevinw@2206 194 # of the target platform.
kevinw@2206 195 ])
kevinw@2206 196
kevinw@2206 197 # Documentation on common flags used for solstudio in HIGHEST.
kevinw@2206 198 #
kevinw@2206 199 # WARNING: Use of OPTIMIZATION_LEVEL=HIGHEST in your Makefile needs to be
kevinw@2206 200 # done with care, there are some assumptions below that need to
kevinw@2206 201 # be understood about the use of pointers, and IEEE behavior.
kevinw@2206 202 #
kevinw@2206 203 # -fns: Use non-standard floating point mode (not IEEE 754)
kevinw@2206 204 # -fsimple: Do some simplification of floating point arithmetic (not IEEE 754)
kevinw@2206 205 # -fsingle: Use single precision floating point with 'float'
kevinw@2206 206 # -xalias_level=basic: Assume memory references via basic pointer types do not alias
kevinw@2206 207 # (Source with excessing pointer casting and data access with mixed
kevinw@2206 208 # pointer types are not recommended)
kevinw@2206 209 # -xbuiltin=%all: Use intrinsic or inline versions for math/std functions
kevinw@2206 210 # (If you expect perfect errno behavior, do not use this)
kevinw@2206 211 # -xdepend: Loop data dependency optimizations (need -xO3 or higher)
kevinw@2206 212 # -xrestrict: Pointer parameters to functions do not overlap
kevinw@2206 213 # (Similar to -xalias_level=basic usage, but less obvious sometimes.
kevinw@2206 214 # If you pass in multiple pointers to the same data, do not use this)
kevinw@2206 215 # -xlibmil: Inline some library routines
kevinw@2206 216 # (If you expect perfect errno behavior, do not use this)
kevinw@2206 217 # -xlibmopt: Use optimized math routines (CURRENTLY DISABLED)
kevinw@2206 218 # (If you expect perfect errno behavior, do not use this)
kevinw@2206 219 # Can cause undefined external on Solaris 8 X86 on __sincos, removing for now
kevinw@2206 220
kevinw@2206 221 # FIXME: this will never happen since sparc != sparcv9, ie 32 bit, which we don't build anymore.
kevinw@2206 222 # Bug?
kevinw@2206 223 #if test "x$OPENJDK_TARGET_CPU" = xsparc; then
kevinw@2206 224 # CFLAGS_JDK="${CFLAGS_JDK} -xmemalign=4s"
kevinw@2206 225 # CXXFLAGS_JDK="${CXXFLAGS_JDK} -xmemalign=4s"
kevinw@2206 226 #fi
kevinw@2206 227
kevinw@2206 228 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_OPTIMIZATION],
kevinw@2206 229 [
kevinw@2206 230
kevinw@2206 231 ###############################################################################
kevinw@2206 232 #
kevinw@2206 233 # Setup the opt flags for different compilers
kevinw@2206 234 # and different operating systems.
kevinw@2206 235 #
kevinw@2206 236
kevinw@2206 237 # FIXME: this was indirectly the old default, but just inherited.
kevinw@2206 238 # if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 239 # C_FLAG_DEPS="-MMD -MF"
kevinw@2206 240 # fi
kevinw@2206 241
kevinw@2206 242 # Generate make dependency files
kevinw@2206 243 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 244 C_FLAG_DEPS="-MMD -MF"
kevinw@2206 245 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 246 C_FLAG_DEPS="-xMMD -xMF"
kevinw@2206 247 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 248 C_FLAG_DEPS="-qmakedep=gcc -MF"
kevinw@2206 249 fi
kevinw@2206 250 CXX_FLAG_DEPS="$C_FLAG_DEPS"
kevinw@2206 251 AC_SUBST(C_FLAG_DEPS)
kevinw@2206 252 AC_SUBST(CXX_FLAG_DEPS)
kevinw@2206 253
kevinw@2206 254 # Debug symbols
kevinw@2206 255 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 256 if test "x$OPENJDK_TARGET_CPU_BITS" = "x64" && test "x$DEBUG_LEVEL" = "xfastdebug"; then
kevinw@2206 257 CFLAGS_DEBUG_SYMBOLS="-g1"
kevinw@2206 258 CXXFLAGS_DEBUG_SYMBOLS="-g1"
kevinw@2206 259 else
kevinw@2206 260 CFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 261 CXXFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 262 fi
kevinw@2206 263 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 264 CFLAGS_DEBUG_SYMBOLS="-g -xs"
kevinw@2206 265 CXXFLAGS_DEBUG_SYMBOLS="-g0 -xs"
kevinw@2206 266 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 267 CFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 268 CXXFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 269 fi
kevinw@2206 270 AC_SUBST(CFLAGS_DEBUG_SYMBOLS)
kevinw@2206 271 AC_SUBST(CXXFLAGS_DEBUG_SYMBOLS)
kevinw@2206 272
kevinw@2206 273 # Optimization levels
kevinw@2206 274 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 275 CC_HIGHEST="$CC_HIGHEST -fns -fsimple -fsingle -xalias_level=basic -xbuiltin=%all -xdepend -xrestrict -xlibmil"
kevinw@2206 276
kevinw@2206 277 if test "x$OPENJDK_TARGET_CPU_ARCH" = "xx86"; then
kevinw@2206 278 # FIXME: seems we always set -xregs=no%frameptr; put it elsewhere more global?
kevinw@2206 279 C_O_FLAG_HIGHEST="-xO4 -Wu,-O4~yz $CC_HIGHEST -xregs=no%frameptr"
kevinw@2206 280 C_O_FLAG_HI="-xO4 -Wu,-O4~yz -xregs=no%frameptr"
kevinw@2206 281 C_O_FLAG_NORM="-xO2 -Wu,-O2~yz -xregs=no%frameptr"
kevinw@2206 282 C_O_FLAG_NONE="-xregs=no%frameptr"
kevinw@2206 283 CXX_O_FLAG_HIGHEST="-xO4 -Qoption ube -O4~yz $CC_HIGHEST -xregs=no%frameptr"
kevinw@2206 284 CXX_O_FLAG_HI="-xO4 -Qoption ube -O4~yz -xregs=no%frameptr"
kevinw@2206 285 CXX_O_FLAG_NORM="-xO2 -Qoption ube -O2~yz -xregs=no%frameptr"
kevinw@2206 286 CXX_O_FLAG_NONE="-xregs=no%frameptr"
kevinw@2206 287 if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then
kevinw@2206 288 C_O_FLAG_HIGHEST="$C_O_FLAG_HIGHEST -xchip=pentium"
kevinw@2206 289 CXX_O_FLAG_HIGHEST="$CXX_O_FLAG_HIGHEST -xchip=pentium"
kevinw@2206 290 fi
kevinw@2206 291 elif test "x$OPENJDK_TARGET_CPU_ARCH" = "xsparc"; then
kevinw@2206 292 C_O_FLAG_HIGHEST="-xO4 -Wc,-Qrm-s -Wc,-Qiselect-T0 $CC_HIGHEST -xprefetch=auto,explicit -xchip=ultra"
kevinw@2206 293 C_O_FLAG_HI="-xO4 -Wc,-Qrm-s -Wc,-Qiselect-T0"
kevinw@2206 294 C_O_FLAG_NORM="-xO2 -Wc,-Qrm-s -Wc,-Qiselect-T0"
kevinw@2206 295 C_O_FLAG_NONE=""
kevinw@2206 296 CXX_O_FLAG_HIGHEST="-xO4 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0 $CC_HIGHEST -xprefetch=auto,explicit -xchip=ultra"
kevinw@2206 297 CXX_O_FLAG_HI="-xO4 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0"
kevinw@2206 298 CXX_O_FLAG_NORM="-xO2 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0"
kevinw@2206 299 CXX_O_FLAG_NONE=""
kevinw@2206 300 fi
kevinw@2206 301 else
kevinw@2206 302 # The remaining toolchains share opt flags between CC and CXX;
kevinw@2206 303 # setup for C and duplicate afterwards.
kevinw@2206 304 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 305 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 306 # On MacOSX we optimize for size, something
kevinw@2206 307 # we should do for all platforms?
kevinw@2206 308 C_O_FLAG_HIGHEST="-Os"
kevinw@2206 309 C_O_FLAG_HI="-Os"
kevinw@2206 310 C_O_FLAG_NORM="-Os"
kevinw@2206 311 C_O_FLAG_NONE=""
kevinw@2206 312 else
kevinw@2206 313 C_O_FLAG_HIGHEST="-O3"
kevinw@2206 314 C_O_FLAG_HI="-O3"
kevinw@2206 315 C_O_FLAG_NORM="-O2"
kevinw@2206 316 C_O_FLAG_NONE="-O0"
kevinw@2206 317 fi
kevinw@2206 318 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 319 C_O_FLAG_HIGHEST="-O3"
kevinw@2206 320 C_O_FLAG_HI="-O3 -qstrict"
kevinw@2206 321 C_O_FLAG_NORM="-O2"
kevinw@2206 322 C_O_FLAG_NONE=""
kevinw@2206 323 elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 324 C_O_FLAG_HIGHEST="-O2"
kevinw@2206 325 C_O_FLAG_HI="-O1"
kevinw@2206 326 C_O_FLAG_NORM="-O1"
kevinw@2206 327 C_O_FLAG_NONE="-Od"
kevinw@2206 328 fi
kevinw@2206 329 CXX_O_FLAG_HIGHEST="$C_O_FLAG_HIGHEST"
kevinw@2206 330 CXX_O_FLAG_HI="$C_O_FLAG_HI"
kevinw@2206 331 CXX_O_FLAG_NORM="$C_O_FLAG_NORM"
kevinw@2206 332 CXX_O_FLAG_NONE="$C_O_FLAG_NONE"
kevinw@2206 333 fi
kevinw@2206 334
kevinw@2206 335 AC_SUBST(C_O_FLAG_HIGHEST)
kevinw@2206 336 AC_SUBST(C_O_FLAG_HI)
kevinw@2206 337 AC_SUBST(C_O_FLAG_NORM)
kevinw@2206 338 AC_SUBST(C_O_FLAG_NONE)
kevinw@2206 339 AC_SUBST(CXX_O_FLAG_HIGHEST)
kevinw@2206 340 AC_SUBST(CXX_O_FLAG_HI)
kevinw@2206 341 AC_SUBST(CXX_O_FLAG_NORM)
kevinw@2206 342 AC_SUBST(CXX_O_FLAG_NONE)
kevinw@2206 343 ])
kevinw@2206 344
kevinw@2206 345 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
kevinw@2206 346 [
kevinw@2206 347 # Special extras...
kevinw@2206 348 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 349 if test "x$OPENJDK_TARGET_CPU_ARCH" = "xsparc"; then
kevinw@2206 350 CFLAGS_JDKLIB_EXTRA="${CFLAGS_JDKLIB_EXTRA} -xregs=no%appl"
kevinw@2206 351 CXXFLAGS_JDKLIB_EXTRA="${CXXFLAGS_JDKLIB_EXTRA} -xregs=no%appl"
kevinw@2206 352 fi
kevinw@2206 353 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 354 LDFLAGS_JDK="${LDFLAGS_JDK} -q64 -brtl -bnolibpath -liconv -bexpall"
kevinw@2206 355 CFLAGS_JDK="${CFLAGS_JDK} -qchars=signed -q64 -qfullpath -qsaveopt"
kevinw@2206 356 CXXFLAGS_JDK="${CXXFLAGS_JDK} -qchars=signed -q64 -qfullpath -qsaveopt"
kevinw@2206 357 elif test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 358 $2CXXSTD_CXXFLAG="-std=gnu++98"
kevinw@2206 359 FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]$2CXXSTD_CXXFLAG -Werror],
kevinw@2206 360 [], [$2CXXSTD_CXXFLAG=""])
kevinw@2206 361 $2CXXFLAGS_JDK="${$2CXXFLAGS_JDK} ${$2CXXSTD_CXXFLAG}"
kevinw@2206 362 $2JVM_CFLAGS="${$2JVM_CFLAGS} ${$2CXXSTD_CXXFLAG}"
kevinw@2206 363 AC_SUBST($2CXXSTD_CXXFLAG)
kevinw@2206 364 fi
kevinw@2206 365
kevinw@2206 366 if test "x$CFLAGS" != "x${ADDED_CFLAGS}"; then
kevinw@2206 367 AC_MSG_WARN([Ignoring CFLAGS($CFLAGS) found in environment. Use --with-extra-cflags])
kevinw@2206 368 fi
kevinw@2206 369
kevinw@2206 370 if test "x$CXXFLAGS" != "x${ADDED_CXXFLAGS}"; then
kevinw@2206 371 AC_MSG_WARN([Ignoring CXXFLAGS($CXXFLAGS) found in environment. Use --with-extra-cxxflags])
kevinw@2206 372 fi
kevinw@2206 373
kevinw@2206 374 if test "x$LDFLAGS" != "x${ADDED_LDFLAGS}"; then
kevinw@2206 375 AC_MSG_WARN([Ignoring LDFLAGS($LDFLAGS) found in environment. Use --with-extra-ldflags])
kevinw@2206 376 fi
kevinw@2206 377
kevinw@2206 378 AC_ARG_WITH(extra-cflags, [AS_HELP_STRING([--with-extra-cflags],
kevinw@2206 379 [extra flags to be used when compiling jdk c-files])])
kevinw@2206 380
kevinw@2206 381 AC_ARG_WITH(extra-cxxflags, [AS_HELP_STRING([--with-extra-cxxflags],
kevinw@2206 382 [extra flags to be used when compiling jdk c++-files])])
kevinw@2206 383
kevinw@2206 384 AC_ARG_WITH(extra-ldflags, [AS_HELP_STRING([--with-extra-ldflags],
kevinw@2206 385 [extra flags to be used when linking jdk])])
kevinw@2206 386
kevinw@2206 387 CFLAGS_JDK="${CFLAGS_JDK} $with_extra_cflags"
kevinw@2206 388 CXXFLAGS_JDK="${CXXFLAGS_JDK} $with_extra_cxxflags"
kevinw@2206 389 LDFLAGS_JDK="${LDFLAGS_JDK} $with_extra_ldflags"
kevinw@2206 390
kevinw@2206 391 # Hotspot needs these set in their legacy form
kevinw@2206 392 LEGACY_EXTRA_CFLAGS=$with_extra_cflags
kevinw@2206 393 LEGACY_EXTRA_CXXFLAGS=$with_extra_cxxflags
kevinw@2206 394 LEGACY_EXTRA_LDFLAGS=$with_extra_ldflags
kevinw@2206 395
kevinw@2206 396 AC_SUBST(LEGACY_EXTRA_CFLAGS)
kevinw@2206 397 AC_SUBST(LEGACY_EXTRA_CXXFLAGS)
kevinw@2206 398 AC_SUBST(LEGACY_EXTRA_LDFLAGS)
kevinw@2206 399
kevinw@2206 400 ###############################################################################
kevinw@2206 401 #
kevinw@2206 402 # Now setup the CFLAGS and LDFLAGS for the JDK build.
kevinw@2206 403 # Later we will also have CFLAGS and LDFLAGS for the hotspot subrepo build.
kevinw@2206 404 #
kevinw@2206 405
kevinw@2206 406 # Setup compiler/platform specific flags to CFLAGS_JDK,
kevinw@2206 407 # CXXFLAGS_JDK and CCXXFLAGS_JDK (common to C and CXX?)
kevinw@2206 408 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 409 # these options are used for both C and C++ compiles
kevinw@2206 410 CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK -Wall -Wno-parentheses -Wextra -Wno-unused -Wno-unused-parameter -Wformat=2 \
kevinw@2206 411 -pipe -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE"
kevinw@2206 412 case $OPENJDK_TARGET_CPU_ARCH in
kevinw@2206 413 arm )
kevinw@2206 414 # on arm we don't prevent gcc to omit frame pointer but do prevent strict aliasing
kevinw@2206 415 CFLAGS_JDK="${CFLAGS_JDK} -fno-strict-aliasing"
kevinw@2206 416 ;;
kevinw@2206 417 ppc )
kevinw@2206 418 # on ppc we don't prevent gcc to omit frame pointer nor strict-aliasing
kevinw@2206 419 ;;
kevinw@2206 420 * )
kevinw@2206 421 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -fno-omit-frame-pointer"
kevinw@2206 422 CFLAGS_JDK="${CFLAGS_JDK} -fno-strict-aliasing"
kevinw@2206 423 ;;
kevinw@2206 424 esac
kevinw@2206 425 TOOLCHAIN_CHECK_COMPILER_VERSION(6, FLAGS_SETUP_GCC6_COMPILER_FLAGS)
kevinw@2206 426 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 427 CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK -DTRACING -DMACRO_MEMSYS_OPS -DBREAKPTS"
kevinw@2206 428 if test "x$OPENJDK_TARGET_CPU_ARCH" = xx86; then
kevinw@2206 429 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DcpuIntel -Di586 -D$OPENJDK_TARGET_CPU_LEGACY_LIB"
kevinw@2206 430 CFLAGS_JDK="$CFLAGS_JDK -erroff=E_BAD_PRAGMA_PACK_VALUE"
kevinw@2206 431 fi
kevinw@2206 432
kevinw@2206 433 CFLAGS_JDK="$CFLAGS_JDK -xc99=%none -xCC -errshort=tags -Xa -v -mt -W0,-noglobal"
kevinw@2206 434 CXXFLAGS_JDK="$CXXFLAGS_JDK -errtags=yes +w -mt -features=no%except -DCC_NOEX -norunpath -xnolib"
kevinw@2206 435 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 436 CFLAGS_JDK="$CFLAGS_JDK -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE -DSTDC"
kevinw@2206 437 CXXFLAGS_JDK="$CXXFLAGS_JDK -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE -DSTDC"
kevinw@2206 438 elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 439 CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK -Zi -MD -Zc:wchar_t- -W3 -wd4800 \
kevinw@2206 440 -D_STATIC_CPPLIB -D_DISABLE_DEPRECATE_STATIC_CPPLIB -DWIN32_LEAN_AND_MEAN \
kevinw@2206 441 -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE \
kevinw@2206 442 -DWIN32 -DIAL"
kevinw@2206 443 if test "x$OPENJDK_TARGET_CPU" = xx86_64; then
kevinw@2206 444 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_AMD64_ -Damd64"
kevinw@2206 445 else
kevinw@2206 446 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_X86_ -Dx86"
kevinw@2206 447 fi
kevinw@2206 448 fi
kevinw@2206 449
kevinw@2206 450 ###############################################################################
kevinw@2206 451
kevinw@2206 452 # Adjust flags according to debug level.
kevinw@2206 453 case $DEBUG_LEVEL in
kevinw@2206 454 fastdebug )
kevinw@2206 455 CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
kevinw@2206 456 CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
kevinw@2206 457 C_O_FLAG_HI="$C_O_FLAG_NORM"
kevinw@2206 458 C_O_FLAG_NORM="$C_O_FLAG_NORM"
kevinw@2206 459 CXX_O_FLAG_HI="$CXX_O_FLAG_NORM"
kevinw@2206 460 CXX_O_FLAG_NORM="$CXX_O_FLAG_NORM"
kevinw@2206 461 JAVAC_FLAGS="$JAVAC_FLAGS -g"
kevinw@2206 462 ;;
kevinw@2206 463 slowdebug )
kevinw@2206 464 CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
kevinw@2206 465 CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
kevinw@2206 466 C_O_FLAG_HI="$C_O_FLAG_NONE"
kevinw@2206 467 C_O_FLAG_NORM="$C_O_FLAG_NONE"
kevinw@2206 468 CXX_O_FLAG_HI="$CXX_O_FLAG_NONE"
kevinw@2206 469 CXX_O_FLAG_NORM="$CXX_O_FLAG_NONE"
kevinw@2206 470 JAVAC_FLAGS="$JAVAC_FLAGS -g"
kevinw@2206 471 ;;
kevinw@2206 472 esac
kevinw@2206 473
kevinw@2206 474 # Setup LP64
kevinw@2206 475 CCXXFLAGS_JDK="$CCXXFLAGS_JDK $ADD_LP64"
kevinw@2206 476
kevinw@2206 477 # Set some common defines. These works for all compilers, but assume
kevinw@2206 478 # -D is universally accepted.
kevinw@2206 479
kevinw@2206 480 # Setup endianness
kevinw@2206 481 if test "x$OPENJDK_TARGET_CPU_ENDIAN" = xlittle; then
kevinw@2206 482 # The macro _LITTLE_ENDIAN needs to be defined the same to avoid the
kevinw@2206 483 # Sun C compiler warning message: warning: macro redefined: _LITTLE_ENDIAN
kevinw@2206 484 # (The Solaris X86 system defines this in file /usr/include/sys/isa_defs.h).
kevinw@2206 485 # Note: -Dmacro is the same as #define macro 1
kevinw@2206 486 # -Dmacro= is the same as #define macro
kevinw@2206 487 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 488 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN="
kevinw@2206 489 else
kevinw@2206 490 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN"
kevinw@2206 491 fi
kevinw@2206 492 else
kevinw@2206 493 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN"
kevinw@2206 494 fi
kevinw@2206 495
kevinw@2206 496 # Setup target OS define. Use OS target name but in upper case.
kevinw@2206 497 OPENJDK_TARGET_OS_UPPERCASE=`$ECHO $OPENJDK_TARGET_OS | $TR 'abcdefghijklmnopqrstuvwxyz' 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'`
kevinw@2206 498 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D$OPENJDK_TARGET_OS_UPPERCASE"
kevinw@2206 499
kevinw@2206 500 # Setup target CPU
kevinw@2206 501 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DARCH='\"$OPENJDK_TARGET_CPU_LEGACY\"' -D$OPENJDK_TARGET_CPU_LEGACY"
kevinw@2206 502
kevinw@2206 503 # Setup debug/release defines
kevinw@2206 504 if test "x$DEBUG_LEVEL" = xrelease; then
kevinw@2206 505 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DNDEBUG"
kevinw@2206 506 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 507 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DTRIMMED"
kevinw@2206 508 fi
kevinw@2206 509 else
kevinw@2206 510 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DDEBUG"
kevinw@2206 511 fi
kevinw@2206 512
kevinw@2206 513 # Setup release name
kevinw@2206 514 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DRELEASE='\"\$(RELEASE)\"'"
kevinw@2206 515
kevinw@2206 516
kevinw@2206 517 # Set some additional per-OS defines.
kevinw@2206 518 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 519 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_ALLBSD_SOURCE -D_DARWIN_UNLIMITED_SELECT"
kevinw@2206 520 elif test "x$OPENJDK_TARGET_OS" = xaix; then
kevinw@2206 521 # FIXME: PPC64 should not be here.
kevinw@2206 522 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DPPC64"
kevinw@2206 523 elif test "x$OPENJDK_TARGET_OS" = xbsd; then
kevinw@2206 524 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_ALLBSD_SOURCE"
kevinw@2206 525 fi
kevinw@2206 526
kevinw@2206 527 # Additional macosx handling
kevinw@2206 528 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 529 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 530 # FIXME: This needs to be exported in spec.gmk due to closed legacy code.
kevinw@2206 531 # FIXME: clean this up, and/or move it elsewhere.
kevinw@2206 532
kevinw@2206 533 # Setting these parameters makes it an error to link to macosx APIs that are
kevinw@2206 534 # newer than the given OS version and makes the linked binaries compatible
kevinw@2206 535 # even if built on a newer version of the OS.
kevinw@2206 536 # The expected format is X.Y.Z
kevinw@2206 537 MACOSX_VERSION_MIN=10.7.0
kevinw@2206 538 AC_SUBST(MACOSX_VERSION_MIN)
kevinw@2206 539
kevinw@2206 540 # The macro takes the version with no dots, ex: 1070
kevinw@2206 541 # Let the flags variables get resolved in make for easier override on make
kevinw@2206 542 # command line.
kevinw@2206 543 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DMAC_OS_X_VERSION_MAX_ALLOWED=\$(subst .,,\$(MACOSX_VERSION_MIN)) -mmacosx-version-min=\$(MACOSX_VERSION_MIN)"
kevinw@2206 544 LDFLAGS_JDK="$LDFLAGS_JDK -mmacosx-version-min=\$(MACOSX_VERSION_MIN)"
kevinw@2206 545 fi
kevinw@2206 546 fi
kevinw@2206 547
kevinw@2206 548 # Setup some hard coded includes
kevinw@2206 549 CCXXFLAGS_JDK="$CCXXFLAGS_JDK \
kevinw@2206 550 -I${JDK_OUTPUTDIR}/include \
kevinw@2206 551 -I${JDK_OUTPUTDIR}/include/$OPENJDK_TARGET_OS \
kevinw@2206 552 -I${JDK_TOPDIR}/src/share/javavm/export \
kevinw@2206 553 -I${JDK_TOPDIR}/src/$OPENJDK_TARGET_OS_EXPORT_DIR/javavm/export \
kevinw@2206 554 -I${JDK_TOPDIR}/src/share/native/common \
kevinw@2206 555 -I${JDK_TOPDIR}/src/$OPENJDK_TARGET_OS_API_DIR/native/common"
kevinw@2206 556
kevinw@2206 557 # The shared libraries are compiled using the picflag.
kevinw@2206 558 CFLAGS_JDKLIB="$CCXXFLAGS_JDK $CFLAGS_JDK $PICFLAG $CFLAGS_JDKLIB_EXTRA"
kevinw@2206 559 CXXFLAGS_JDKLIB="$CCXXFLAGS_JDK $CXXFLAGS_JDK $PICFLAG $CXXFLAGS_JDKLIB_EXTRA "
kevinw@2206 560
kevinw@2206 561 # Executable flags
kevinw@2206 562 CFLAGS_JDKEXE="$CCXXFLAGS_JDK $CFLAGS_JDK"
kevinw@2206 563 CXXFLAGS_JDKEXE="$CCXXFLAGS_JDK $CXXFLAGS_JDK"
kevinw@2206 564
kevinw@2206 565 AC_SUBST(CFLAGS_JDKLIB)
kevinw@2206 566 AC_SUBST(CFLAGS_JDKEXE)
kevinw@2206 567 AC_SUBST(CXXFLAGS_JDKLIB)
kevinw@2206 568 AC_SUBST(CXXFLAGS_JDKEXE)
kevinw@2206 569
kevinw@2206 570 # Setup LDFLAGS et al.
kevinw@2206 571 #
kevinw@2206 572 # Now this is odd. The JDK native libraries have to link against libjvm.so
kevinw@2206 573 # On 32-bit machines there is normally two distinct libjvm.so:s, client and server.
kevinw@2206 574 # Which should we link to? Are we lucky enough that the binary api to the libjvm.so library
kevinw@2206 575 # is identical for client and server? Yes. Which is picked at runtime (client or server)?
kevinw@2206 576 # Neither, since the chosen libjvm.so has already been loaded by the launcher, all the following
kevinw@2206 577 # libraries will link to whatever is in memory. Yuck.
kevinw@2206 578 #
kevinw@2206 579 # Thus we offer the compiler to find libjvm.so first in server then in client. It works. Ugh.
kevinw@2206 580 if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 581 LDFLAGS_JDK="$LDFLAGS_JDK -nologo -opt:ref -incremental:no"
kevinw@2206 582 if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then
kevinw@2206 583 LDFLAGS_JDK="$LDFLAGS_JDK -safeseh"
kevinw@2206 584 fi
kevinw@2206 585 # TODO: make -debug optional "--disable-full-debug-symbols"
kevinw@2206 586 LDFLAGS_JDK="$LDFLAGS_JDK -debug"
kevinw@2206 587 LDFLAGS_JDKLIB="${LDFLAGS_JDK} -dll -libpath:${JDK_OUTPUTDIR}/lib"
kevinw@2206 588 LDFLAGS_JDKLIB_SUFFIX=""
kevinw@2206 589 if test "x$OPENJDK_TARGET_CPU_BITS" = "x64"; then
kevinw@2206 590 LDFLAGS_STACK_SIZE=1048576
kevinw@2206 591 else
kevinw@2206 592 LDFLAGS_STACK_SIZE=327680
kevinw@2206 593 fi
kevinw@2206 594 LDFLAGS_JDKEXE="${LDFLAGS_JDK} /STACK:$LDFLAGS_STACK_SIZE"
kevinw@2206 595 else
kevinw@2206 596 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 597 # If this is a --hash-style=gnu system, use --hash-style=both, why?
kevinw@2206 598 # We have previously set HAS_GNU_HASH if this is the case
kevinw@2206 599 if test -n "$HAS_GNU_HASH"; then
kevinw@2206 600 LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker --hash-style=both "
kevinw@2206 601 fi
kevinw@2206 602 if test "x$OPENJDK_TARGET_OS" = xlinux; then
kevinw@2206 603 # And since we now know that the linker is gnu, then add -z defs, to forbid
kevinw@2206 604 # undefined symbols in object files.
kevinw@2206 605 LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker -z -Xlinker defs"
kevinw@2206 606 if test "x$DEBUG_LEVEL" = "xrelease"; then
kevinw@2206 607 # When building release libraries, tell the linker optimize them.
kevinw@2206 608 # Should this be supplied to the OSS linker as well?
kevinw@2206 609 LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker -O1"
kevinw@2206 610 fi
kevinw@2206 611 fi
kevinw@2206 612 fi
kevinw@2206 613
kevinw@2206 614 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 615 LDFLAGS_JDK="$LDFLAGS_JDK -z defs -xildoff -ztext"
kevinw@2206 616 LDFLAGS_CXX_JDK="$LDFLAGS_CXX_JDK -norunpath -xnolib"
kevinw@2206 617 fi
kevinw@2206 618
kevinw@2206 619 LDFLAGS_JDKLIB="${LDFLAGS_JDK} $SHARED_LIBRARY_FLAGS \
kevinw@2206 620 -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}"
kevinw@2206 621
kevinw@2206 622 # On some platforms (mac) the linker warns about non existing -L dirs.
kevinw@2206 623 # Add server first if available. Linking aginst client does not always produce the same results.
kevinw@2206 624 # Only add client dir if client is being built. Add minimal (note not minimal1) if only building minimal1.
kevinw@2206 625 # Default to server for other variants.
kevinw@2206 626 if test "x$JVM_VARIANT_SERVER" = xtrue; then
kevinw@2206 627 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/server"
kevinw@2206 628 elif test "x$JVM_VARIANT_CLIENT" = xtrue; then
kevinw@2206 629 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/client"
kevinw@2206 630 elif test "x$JVM_VARIANT_MINIMAL1" = xtrue; then
kevinw@2206 631 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/minimal"
kevinw@2206 632 else
kevinw@2206 633 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/server"
kevinw@2206 634 fi
kevinw@2206 635
kevinw@2206 636 LDFLAGS_JDKLIB_SUFFIX="-ljava -ljvm"
kevinw@2206 637 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 638 LDFLAGS_JDKLIB_SUFFIX="$LDFLAGS_JDKLIB_SUFFIX -lc"
kevinw@2206 639 fi
kevinw@2206 640
kevinw@2206 641 LDFLAGS_JDKEXE="${LDFLAGS_JDK}"
kevinw@2206 642 if test "x$OPENJDK_TARGET_OS" = xlinux; then
kevinw@2206 643 LDFLAGS_JDKEXE="$LDFLAGS_JDKEXE -Xlinker --allow-shlib-undefined"
kevinw@2206 644 fi
kevinw@2206 645 fi
kevinw@2206 646 AC_SUBST(LDFLAGS_JDKLIB)
kevinw@2206 647 AC_SUBST(LDFLAGS_JDKEXE)
kevinw@2206 648 AC_SUBST(LDFLAGS_JDKLIB_SUFFIX)
kevinw@2206 649 AC_SUBST(LDFLAGS_JDKEXE_SUFFIX)
kevinw@2206 650 AC_SUBST(LDFLAGS_CXX_JDK)
kevinw@2206 651 ])
kevinw@2206 652
kevinw@2206 653
kevinw@2206 654 # FLAGS_C_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
kevinw@2206 655 # [RUN-IF-FALSE])
kevinw@2206 656 # ------------------------------------------------------------
kevinw@2206 657 # Check that the C compiler supports an argument
kevinw@2206 658 AC_DEFUN([FLAGS_C_COMPILER_CHECK_ARGUMENTS],
kevinw@2206 659 [
kevinw@2206 660 AC_MSG_CHECKING([if the C compiler supports "$1"])
kevinw@2206 661 supports=yes
kevinw@2206 662
kevinw@2206 663 saved_cflags="$CFLAGS"
kevinw@2206 664 CFLAGS="$CFLAGS $1"
kevinw@2206 665 AC_LANG_PUSH([C])
kevinw@2206 666 AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
kevinw@2206 667 [supports=no])
kevinw@2206 668 AC_LANG_POP([C])
kevinw@2206 669 CFLAGS="$saved_cflags"
kevinw@2206 670
kevinw@2206 671 AC_MSG_RESULT([$supports])
kevinw@2206 672 if test "x$supports" = "xyes" ; then
kevinw@2206 673 m4_ifval([$2], [$2], [:])
kevinw@2206 674 else
kevinw@2206 675 m4_ifval([$3], [$3], [:])
kevinw@2206 676 fi
kevinw@2206 677 ])
kevinw@2206 678
kevinw@2206 679 # FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
kevinw@2206 680 # [RUN-IF-FALSE])
kevinw@2206 681 # ------------------------------------------------------------
kevinw@2206 682 # Check that the C++ compiler supports an argument
kevinw@2206 683 AC_DEFUN([FLAGS_CXX_COMPILER_CHECK_ARGUMENTS],
kevinw@2206 684 [
kevinw@2206 685 AC_MSG_CHECKING([if the C++ compiler supports "$1"])
kevinw@2206 686 supports=yes
kevinw@2206 687
kevinw@2206 688 saved_cxxflags="$CXXFLAGS"
kevinw@2206 689 CXXFLAGS="$CXXFLAG $1"
kevinw@2206 690 AC_LANG_PUSH([C++])
kevinw@2206 691 AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
kevinw@2206 692 [supports=no])
kevinw@2206 693 AC_LANG_POP([C++])
kevinw@2206 694 CXXFLAGS="$saved_cxxflags"
kevinw@2206 695
kevinw@2206 696 AC_MSG_RESULT([$supports])
kevinw@2206 697 if test "x$supports" = "xyes" ; then
kevinw@2206 698 m4_ifval([$2], [$2], [:])
kevinw@2206 699 else
kevinw@2206 700 m4_ifval([$3], [$3], [:])
kevinw@2206 701 fi
kevinw@2206 702 ])
kevinw@2206 703
kevinw@2206 704 # FLAGS_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
kevinw@2206 705 # [RUN-IF-FALSE])
kevinw@2206 706 # ------------------------------------------------------------
kevinw@2206 707 # Check that the C and C++ compilers support an argument
kevinw@2206 708 AC_DEFUN([FLAGS_COMPILER_CHECK_ARGUMENTS],
kevinw@2206 709 [
kevinw@2206 710 FLAGS_C_COMPILER_CHECK_ARGUMENTS([$1],
kevinw@2206 711 [C_COMP_SUPPORTS="yes"],
kevinw@2206 712 [C_COMP_SUPPORTS="no"])
kevinw@2206 713 FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([$1],
kevinw@2206 714 [CXX_COMP_SUPPORTS="yes"],
kevinw@2206 715 [CXX_COMP_SUPPORTS="no"])
kevinw@2206 716
kevinw@2206 717 AC_MSG_CHECKING([if both compilers support "$1"])
kevinw@2206 718 supports=no
kevinw@2206 719 if test "x$C_COMP_SUPPORTS" = "xyes" -a "x$CXX_COMP_SUPPORTS" = "xyes"; then supports=yes; fi
kevinw@2206 720
kevinw@2206 721 AC_MSG_RESULT([$supports])
kevinw@2206 722 if test "x$supports" = "xyes" ; then
kevinw@2206 723 m4_ifval([$2], [$2], [:])
kevinw@2206 724 else
kevinw@2206 725 m4_ifval([$3], [$3], [:])
kevinw@2206 726 fi
kevinw@2206 727 ])
kevinw@2206 728
kevinw@2206 729 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
kevinw@2206 730 [
kevinw@2206 731 # Some Zero and Shark settings.
kevinw@2206 732 # ZERO_ARCHFLAG tells the compiler which mode to build for
kevinw@2206 733 case "${OPENJDK_TARGET_CPU}" in
kevinw@2206 734 s390)
kevinw@2206 735 ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}31"
kevinw@2206 736 ;;
kevinw@2206 737 *)
kevinw@2206 738 ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}"
kevinw@2206 739 esac
kevinw@2206 740 FLAGS_COMPILER_CHECK_ARGUMENTS([$ZERO_ARCHFLAG], [], [ZERO_ARCHFLAG=""])
kevinw@2206 741 AC_SUBST(ZERO_ARCHFLAG)
kevinw@2206 742
kevinw@2206 743 # Check that the compiler supports -mX (or -qX on AIX) flags
kevinw@2206 744 # Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does
kevinw@2206 745 FLAGS_COMPILER_CHECK_ARGUMENTS([${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}],
kevinw@2206 746 [COMPILER_SUPPORTS_TARGET_BITS_FLAG=true],
kevinw@2206 747 [COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
kevinw@2206 748 AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
kevinw@2206 749 ])
kevinw@2206 750
kevinw@2206 751 AC_DEFUN_ONCE([FLAGS_SETUP_GCC6_COMPILER_FLAGS],
kevinw@2206 752 [
kevinw@2206 753 # These flags are required for GCC 6 builds as undefined behaviour in OpenJDK code
kevinw@2206 754 # runs afoul of the more aggressive versions of these optimisations.
kevinw@2206 755 # Notably, value range propagation now assumes that the this pointer of C++
kevinw@2206 756 # member functions is non-null.
kevinw@2206 757 NO_DELETE_NULL_POINTER_CHECKS_CFLAG="-fno-delete-null-pointer-checks"
kevinw@2206 758 FLAGS_COMPILER_CHECK_ARGUMENTS([$NO_DELETE_NULL_POINTER_CHECKS_CFLAG -Werror],
kevinw@2206 759 [], [NO_DELETE_NULL_POINTER_CHECKS_CFLAG=""])
kevinw@2206 760 AC_SUBST([NO_DELETE_NULL_POINTER_CHECKS_CFLAG])
kevinw@2206 761 NO_LIFETIME_DSE_CFLAG="-fno-lifetime-dse"
kevinw@2206 762 FLAGS_COMPILER_CHECK_ARGUMENTS([$NO_LIFETIME_DSE_CFLAG -Werror],
kevinw@2206 763 [], [NO_LIFETIME_DSE_CFLAG=""])
kevinw@2206 764 CFLAGS_JDK="${CFLAGS_JDK} ${NO_DELETE_NULL_POINTER_CHECKS_CFLAG} ${NO_LIFETIME_DSE_CFLAG}"
kevinw@2206 765 AC_SUBST([NO_LIFETIME_DSE_CFLAG])
kevinw@2206 766 ])
kevinw@2206 767

mercurial