common/autoconf/flags.m4

Mon, 14 Sep 2020 16:42:03 +0100

author
andrew
date
Mon, 14 Sep 2020 16:42:03 +0100
changeset 2554
7f60c2d9823e
parent 2497
343c4ea489d5
permissions
-rw-r--r--

Added tag jdk8u272-b08 for changeset 34c6baf21464

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@2298 111 -d \"JDK_VER=\$(JDK_MINOR_VERSION).\$(JDK_MICRO_VERSION).\$(COOKED_JDK_UPDATE_VERSION).\$(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@2401 114 -d \"JDK_FVER=\$(JDK_MINOR_VERSION),\$(JDK_MICRO_VERSION),\$(if \$(COOKED_JDK_UPDATE_VERSION),\$(COOKED_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@2215 122
kevinw@2215 123 if test "x$SYSROOT" != "x"; then
kevinw@2215 124 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2215 125 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2215 126 # Solaris Studio does not have a concept of sysroot. Instead we must
kevinw@2215 127 # make sure the default include and lib dirs are appended to each
kevinw@2215 128 # compile and link command line.
kevinw@2215 129 SYSROOT_CFLAGS="-I$SYSROOT/usr/include"
kevinw@2215 130 SYSROOT_LDFLAGS="-L$SYSROOT/usr/lib$OPENJDK_TARGET_CPU_ISADIR \
kevinw@2215 131 -L$SYSROOT/lib$OPENJDK_TARGET_CPU_ISADIR \
kevinw@2215 132 -L$SYSROOT/usr/ccs/lib$OPENJDK_TARGET_CPU_ISADIR"
kevinw@2215 133 fi
kevinw@2215 134 elif test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2215 135 SYSROOT_CFLAGS="--sysroot=\"$SYSROOT\""
kevinw@2215 136 SYSROOT_LDFLAGS="--sysroot=\"$SYSROOT\""
kevinw@2215 137 elif test "x$TOOLCHAIN_TYPE" = xclang; then
kevinw@2215 138 SYSROOT_CFLAGS="-isysroot \"$SYSROOT\""
kevinw@2215 139 SYSROOT_LDFLAGS="-isysroot \"$SYSROOT\""
kevinw@2215 140 fi
kevinw@2215 141 # Propagate the sysroot args to hotspot
kevinw@2215 142 LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS $SYSROOT_CFLAGS"
kevinw@2215 143 LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS $SYSROOT_CFLAGS"
kevinw@2215 144 LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS $SYSROOT_LDFLAGS"
kevinw@2215 145 fi
kevinw@2215 146 AC_SUBST(SYSROOT_CFLAGS)
kevinw@2215 147 AC_SUBST(SYSROOT_LDFLAGS)
kevinw@2206 148 ])
kevinw@2206 149
kevinw@2206 150 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_LIBS],
kevinw@2206 151 [
kevinw@2206 152 ###############################################################################
kevinw@2206 153 #
kevinw@2206 154 # How to compile shared libraries.
kevinw@2206 155 #
kevinw@2206 156
kevinw@2206 157 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 158 PICFLAG="-fPIC"
alvdavi@2496 159 PIEFLAG="-fPIE"
kevinw@2206 160 C_FLAG_REORDER=''
kevinw@2206 161 CXX_FLAG_REORDER=''
kevinw@2206 162
kevinw@2206 163 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 164 # Linking is different on MacOSX
kevinw@2206 165 SHARED_LIBRARY_FLAGS="-dynamiclib -compatibility_version 1.0.0 -current_version 1.0.0 $PICFLAG"
kevinw@2206 166 SET_EXECUTABLE_ORIGIN='-Xlinker -rpath -Xlinker @loader_path/.'
kevinw@2206 167 SET_SHARED_LIBRARY_ORIGIN="$SET_EXECUTABLE_ORIGIN"
kevinw@2206 168 SET_SHARED_LIBRARY_NAME='-Xlinker -install_name -Xlinker @rpath/[$]1'
kevinw@2206 169 SET_SHARED_LIBRARY_MAPFILE=''
kevinw@2206 170 else
kevinw@2206 171 # Default works for linux, might work on other platforms as well.
kevinw@2206 172 SHARED_LIBRARY_FLAGS='-shared'
kevinw@2206 173 SET_EXECUTABLE_ORIGIN='-Xlinker -rpath -Xlinker \$$$$ORIGIN[$]1'
kevinw@2206 174 SET_SHARED_LIBRARY_ORIGIN="-Xlinker -z -Xlinker origin $SET_EXECUTABLE_ORIGIN"
kevinw@2206 175 SET_SHARED_LIBRARY_NAME='-Xlinker -soname=[$]1'
kevinw@2206 176 SET_SHARED_LIBRARY_MAPFILE='-Xlinker -version-script=[$]1'
kevinw@2206 177 fi
kevinw@2206 178 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 179 PICFLAG="-KPIC"
alvdavi@2496 180 PIEFLAG=""
kevinw@2206 181 C_FLAG_REORDER='-xF'
kevinw@2206 182 CXX_FLAG_REORDER='-xF'
kevinw@2206 183 SHARED_LIBRARY_FLAGS="-G"
kevinw@2206 184 SET_EXECUTABLE_ORIGIN='-R\$$$$ORIGIN[$]1'
kevinw@2206 185 SET_SHARED_LIBRARY_ORIGIN="$SET_EXECUTABLE_ORIGIN"
kevinw@2206 186 SET_SHARED_LIBRARY_NAME=''
kevinw@2206 187 SET_SHARED_LIBRARY_MAPFILE='-M[$]1'
kevinw@2206 188 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 189 PICFLAG="-qpic=large"
alvdavi@2496 190 PIEFLAG=""
kevinw@2206 191 C_FLAG_REORDER=''
kevinw@2206 192 CXX_FLAG_REORDER=''
kevinw@2206 193 SHARED_LIBRARY_FLAGS="-qmkshrobj"
kevinw@2206 194 SET_EXECUTABLE_ORIGIN=""
kevinw@2206 195 SET_SHARED_LIBRARY_ORIGIN=''
kevinw@2206 196 SET_SHARED_LIBRARY_NAME=''
kevinw@2206 197 SET_SHARED_LIBRARY_MAPFILE=''
kevinw@2206 198 elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 199 PICFLAG=""
alvdavi@2496 200 PIEFLAG=""
kevinw@2206 201 C_FLAG_REORDER=''
kevinw@2206 202 CXX_FLAG_REORDER=''
kevinw@2206 203 SHARED_LIBRARY_FLAGS="-LD"
kevinw@2206 204 SET_EXECUTABLE_ORIGIN=''
kevinw@2206 205 SET_SHARED_LIBRARY_ORIGIN=''
kevinw@2206 206 SET_SHARED_LIBRARY_NAME=''
kevinw@2206 207 SET_SHARED_LIBRARY_MAPFILE=''
kevinw@2206 208 fi
kevinw@2206 209
kevinw@2206 210 AC_SUBST(C_FLAG_REORDER)
kevinw@2206 211 AC_SUBST(CXX_FLAG_REORDER)
kevinw@2206 212 AC_SUBST(SHARED_LIBRARY_FLAGS)
kevinw@2206 213 AC_SUBST(SET_EXECUTABLE_ORIGIN)
kevinw@2206 214 AC_SUBST(SET_SHARED_LIBRARY_ORIGIN)
kevinw@2206 215 AC_SUBST(SET_SHARED_LIBRARY_NAME)
kevinw@2206 216 AC_SUBST(SET_SHARED_LIBRARY_MAPFILE)
kevinw@2206 217
kevinw@2206 218 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 219 CFLAGS_JDK="${CFLAGS_JDK} -D__solaris__"
kevinw@2206 220 CXXFLAGS_JDK="${CXXFLAGS_JDK} -D__solaris__"
kevinw@2206 221 CFLAGS_JDKLIB_EXTRA='-xstrconst'
kevinw@2206 222 fi
kevinw@2206 223 # The (cross) compiler is now configured, we can now test capabilities
kevinw@2206 224 # of the target platform.
kevinw@2206 225 ])
kevinw@2206 226
kevinw@2206 227 # Documentation on common flags used for solstudio in HIGHEST.
kevinw@2206 228 #
kevinw@2206 229 # WARNING: Use of OPTIMIZATION_LEVEL=HIGHEST in your Makefile needs to be
kevinw@2206 230 # done with care, there are some assumptions below that need to
kevinw@2206 231 # be understood about the use of pointers, and IEEE behavior.
kevinw@2206 232 #
kevinw@2206 233 # -fns: Use non-standard floating point mode (not IEEE 754)
kevinw@2206 234 # -fsimple: Do some simplification of floating point arithmetic (not IEEE 754)
kevinw@2206 235 # -fsingle: Use single precision floating point with 'float'
kevinw@2206 236 # -xalias_level=basic: Assume memory references via basic pointer types do not alias
kevinw@2206 237 # (Source with excessing pointer casting and data access with mixed
kevinw@2206 238 # pointer types are not recommended)
kevinw@2206 239 # -xbuiltin=%all: Use intrinsic or inline versions for math/std functions
kevinw@2206 240 # (If you expect perfect errno behavior, do not use this)
kevinw@2206 241 # -xdepend: Loop data dependency optimizations (need -xO3 or higher)
kevinw@2206 242 # -xrestrict: Pointer parameters to functions do not overlap
kevinw@2206 243 # (Similar to -xalias_level=basic usage, but less obvious sometimes.
kevinw@2206 244 # If you pass in multiple pointers to the same data, do not use this)
kevinw@2206 245 # -xlibmil: Inline some library routines
kevinw@2206 246 # (If you expect perfect errno behavior, do not use this)
kevinw@2206 247 # -xlibmopt: Use optimized math routines (CURRENTLY DISABLED)
kevinw@2206 248 # (If you expect perfect errno behavior, do not use this)
kevinw@2206 249 # Can cause undefined external on Solaris 8 X86 on __sincos, removing for now
kevinw@2206 250
kevinw@2206 251 # FIXME: this will never happen since sparc != sparcv9, ie 32 bit, which we don't build anymore.
kevinw@2206 252 # Bug?
kevinw@2206 253 #if test "x$OPENJDK_TARGET_CPU" = xsparc; then
kevinw@2206 254 # CFLAGS_JDK="${CFLAGS_JDK} -xmemalign=4s"
kevinw@2206 255 # CXXFLAGS_JDK="${CXXFLAGS_JDK} -xmemalign=4s"
kevinw@2206 256 #fi
kevinw@2206 257
kevinw@2206 258 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_OPTIMIZATION],
kevinw@2206 259 [
kevinw@2206 260
kevinw@2206 261 ###############################################################################
kevinw@2206 262 #
kevinw@2206 263 # Setup the opt flags for different compilers
kevinw@2206 264 # and different operating systems.
kevinw@2206 265 #
kevinw@2206 266
kevinw@2206 267 # FIXME: this was indirectly the old default, but just inherited.
kevinw@2206 268 # if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 269 # C_FLAG_DEPS="-MMD -MF"
kevinw@2206 270 # fi
kevinw@2206 271
kevinw@2206 272 # Generate make dependency files
kevinw@2206 273 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 274 C_FLAG_DEPS="-MMD -MF"
kevinw@2206 275 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 276 C_FLAG_DEPS="-xMMD -xMF"
kevinw@2206 277 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 278 C_FLAG_DEPS="-qmakedep=gcc -MF"
kevinw@2206 279 fi
kevinw@2206 280 CXX_FLAG_DEPS="$C_FLAG_DEPS"
kevinw@2206 281 AC_SUBST(C_FLAG_DEPS)
kevinw@2206 282 AC_SUBST(CXX_FLAG_DEPS)
kevinw@2206 283
kevinw@2206 284 # Debug symbols
sgehwolf@2322 285 #
sgehwolf@2322 286 # By default don't set any specific assembler debug
sgehwolf@2322 287 # info flags for toolchains unless we know they work.
sgehwolf@2322 288 # See JDK-8207057.
sgehwolf@2322 289 ASFLAGS_DEBUG_SYMBOLS=""
kevinw@2206 290 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 291 if test "x$OPENJDK_TARGET_CPU_BITS" = "x64" && test "x$DEBUG_LEVEL" = "xfastdebug"; then
kevinw@2206 292 CFLAGS_DEBUG_SYMBOLS="-g1"
kevinw@2206 293 CXXFLAGS_DEBUG_SYMBOLS="-g1"
kevinw@2206 294 else
kevinw@2206 295 CFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 296 CXXFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 297 fi
sgehwolf@2322 298 ASFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 299 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 300 CFLAGS_DEBUG_SYMBOLS="-g -xs"
kevinw@2206 301 CXXFLAGS_DEBUG_SYMBOLS="-g0 -xs"
kevinw@2206 302 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 303 CFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 304 CXXFLAGS_DEBUG_SYMBOLS="-g"
kevinw@2206 305 fi
sgehwolf@2322 306 AC_SUBST(ASFLAGS_DEBUG_SYMBOLS)
kevinw@2206 307 AC_SUBST(CFLAGS_DEBUG_SYMBOLS)
kevinw@2206 308 AC_SUBST(CXXFLAGS_DEBUG_SYMBOLS)
kevinw@2206 309
kevinw@2206 310 # Optimization levels
kevinw@2206 311 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 312 CC_HIGHEST="$CC_HIGHEST -fns -fsimple -fsingle -xalias_level=basic -xbuiltin=%all -xdepend -xrestrict -xlibmil"
kevinw@2206 313
kevinw@2206 314 if test "x$OPENJDK_TARGET_CPU_ARCH" = "xx86"; then
kevinw@2206 315 # FIXME: seems we always set -xregs=no%frameptr; put it elsewhere more global?
kevinw@2206 316 C_O_FLAG_HIGHEST="-xO4 -Wu,-O4~yz $CC_HIGHEST -xregs=no%frameptr"
kevinw@2206 317 C_O_FLAG_HI="-xO4 -Wu,-O4~yz -xregs=no%frameptr"
kevinw@2206 318 C_O_FLAG_NORM="-xO2 -Wu,-O2~yz -xregs=no%frameptr"
kevinw@2206 319 C_O_FLAG_NONE="-xregs=no%frameptr"
kevinw@2206 320 CXX_O_FLAG_HIGHEST="-xO4 -Qoption ube -O4~yz $CC_HIGHEST -xregs=no%frameptr"
kevinw@2206 321 CXX_O_FLAG_HI="-xO4 -Qoption ube -O4~yz -xregs=no%frameptr"
kevinw@2206 322 CXX_O_FLAG_NORM="-xO2 -Qoption ube -O2~yz -xregs=no%frameptr"
kevinw@2206 323 CXX_O_FLAG_NONE="-xregs=no%frameptr"
kevinw@2206 324 if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then
kevinw@2206 325 C_O_FLAG_HIGHEST="$C_O_FLAG_HIGHEST -xchip=pentium"
kevinw@2206 326 CXX_O_FLAG_HIGHEST="$CXX_O_FLAG_HIGHEST -xchip=pentium"
kevinw@2206 327 fi
kevinw@2206 328 elif test "x$OPENJDK_TARGET_CPU_ARCH" = "xsparc"; then
kevinw@2206 329 C_O_FLAG_HIGHEST="-xO4 -Wc,-Qrm-s -Wc,-Qiselect-T0 $CC_HIGHEST -xprefetch=auto,explicit -xchip=ultra"
kevinw@2206 330 C_O_FLAG_HI="-xO4 -Wc,-Qrm-s -Wc,-Qiselect-T0"
kevinw@2206 331 C_O_FLAG_NORM="-xO2 -Wc,-Qrm-s -Wc,-Qiselect-T0"
kevinw@2206 332 C_O_FLAG_NONE=""
kevinw@2206 333 CXX_O_FLAG_HIGHEST="-xO4 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0 $CC_HIGHEST -xprefetch=auto,explicit -xchip=ultra"
kevinw@2206 334 CXX_O_FLAG_HI="-xO4 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0"
kevinw@2206 335 CXX_O_FLAG_NORM="-xO2 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0"
kevinw@2206 336 CXX_O_FLAG_NONE=""
kevinw@2206 337 fi
kevinw@2206 338 else
kevinw@2206 339 # The remaining toolchains share opt flags between CC and CXX;
kevinw@2206 340 # setup for C and duplicate afterwards.
kevinw@2206 341 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 342 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 343 # On MacOSX we optimize for size, something
kevinw@2206 344 # we should do for all platforms?
kevinw@2206 345 C_O_FLAG_HIGHEST="-Os"
kevinw@2206 346 C_O_FLAG_HI="-Os"
kevinw@2206 347 C_O_FLAG_NORM="-Os"
kevinw@2206 348 C_O_FLAG_NONE=""
kevinw@2206 349 else
kevinw@2206 350 C_O_FLAG_HIGHEST="-O3"
kevinw@2206 351 C_O_FLAG_HI="-O3"
kevinw@2206 352 C_O_FLAG_NORM="-O2"
kevinw@2206 353 C_O_FLAG_NONE="-O0"
kevinw@2206 354 fi
kevinw@2206 355 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 356 C_O_FLAG_HIGHEST="-O3"
kevinw@2206 357 C_O_FLAG_HI="-O3 -qstrict"
kevinw@2206 358 C_O_FLAG_NORM="-O2"
kevinw@2206 359 C_O_FLAG_NONE=""
kevinw@2206 360 elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 361 C_O_FLAG_HIGHEST="-O2"
kevinw@2206 362 C_O_FLAG_HI="-O1"
kevinw@2206 363 C_O_FLAG_NORM="-O1"
kevinw@2206 364 C_O_FLAG_NONE="-Od"
kevinw@2206 365 fi
kevinw@2206 366 CXX_O_FLAG_HIGHEST="$C_O_FLAG_HIGHEST"
kevinw@2206 367 CXX_O_FLAG_HI="$C_O_FLAG_HI"
kevinw@2206 368 CXX_O_FLAG_NORM="$C_O_FLAG_NORM"
kevinw@2206 369 CXX_O_FLAG_NONE="$C_O_FLAG_NONE"
kevinw@2206 370 fi
kevinw@2206 371
kevinw@2206 372 AC_SUBST(C_O_FLAG_HIGHEST)
kevinw@2206 373 AC_SUBST(C_O_FLAG_HI)
kevinw@2206 374 AC_SUBST(C_O_FLAG_NORM)
kevinw@2206 375 AC_SUBST(C_O_FLAG_NONE)
kevinw@2206 376 AC_SUBST(CXX_O_FLAG_HIGHEST)
kevinw@2206 377 AC_SUBST(CXX_O_FLAG_HI)
kevinw@2206 378 AC_SUBST(CXX_O_FLAG_NORM)
kevinw@2206 379 AC_SUBST(CXX_O_FLAG_NONE)
kevinw@2206 380 ])
kevinw@2206 381
kevinw@2206 382 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
kevinw@2206 383 [
kevinw@2206 384 # Special extras...
kevinw@2206 385 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 386 if test "x$OPENJDK_TARGET_CPU_ARCH" = "xsparc"; then
kevinw@2206 387 CFLAGS_JDKLIB_EXTRA="${CFLAGS_JDKLIB_EXTRA} -xregs=no%appl"
kevinw@2206 388 CXXFLAGS_JDKLIB_EXTRA="${CXXFLAGS_JDKLIB_EXTRA} -xregs=no%appl"
kevinw@2206 389 fi
kevinw@2206 390 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 391 LDFLAGS_JDK="${LDFLAGS_JDK} -q64 -brtl -bnolibpath -liconv -bexpall"
kevinw@2206 392 CFLAGS_JDK="${CFLAGS_JDK} -qchars=signed -q64 -qfullpath -qsaveopt"
kevinw@2206 393 CXXFLAGS_JDK="${CXXFLAGS_JDK} -qchars=signed -q64 -qfullpath -qsaveopt"
kevinw@2206 394 elif test "x$TOOLCHAIN_TYPE" = xgcc; then
andrew@2445 395 LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS -fstack-protector"
andrew@2445 396 LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS -fstack-protector"
kevinw@2373 397 if test "x$OPENJDK_TARGET_OS" != xmacosx; then
kevinw@2373 398 LDFLAGS_JDK="$LDFLAGS_JDK -Wl,-z,relro"
kevinw@2373 399 LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS -Wl,-z,relro"
kevinw@2373 400 fi
kevinw@2206 401 $2CXXSTD_CXXFLAG="-std=gnu++98"
kevinw@2206 402 FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]$2CXXSTD_CXXFLAG -Werror],
kevinw@2206 403 [], [$2CXXSTD_CXXFLAG=""])
kevinw@2206 404 $2CXXFLAGS_JDK="${$2CXXFLAGS_JDK} ${$2CXXSTD_CXXFLAG}"
kevinw@2206 405 $2JVM_CFLAGS="${$2JVM_CFLAGS} ${$2CXXSTD_CXXFLAG}"
kevinw@2206 406 AC_SUBST($2CXXSTD_CXXFLAG)
kevinw@2206 407 fi
kevinw@2206 408
kevinw@2206 409 if test "x$CFLAGS" != "x${ADDED_CFLAGS}"; then
kevinw@2206 410 AC_MSG_WARN([Ignoring CFLAGS($CFLAGS) found in environment. Use --with-extra-cflags])
kevinw@2206 411 fi
kevinw@2206 412
kevinw@2206 413 if test "x$CXXFLAGS" != "x${ADDED_CXXFLAGS}"; then
kevinw@2206 414 AC_MSG_WARN([Ignoring CXXFLAGS($CXXFLAGS) found in environment. Use --with-extra-cxxflags])
kevinw@2206 415 fi
kevinw@2206 416
kevinw@2206 417 if test "x$LDFLAGS" != "x${ADDED_LDFLAGS}"; then
kevinw@2206 418 AC_MSG_WARN([Ignoring LDFLAGS($LDFLAGS) found in environment. Use --with-extra-ldflags])
kevinw@2206 419 fi
kevinw@2206 420
sgehwolf@2482 421
sgehwolf@2482 422 if test "x$ASFLAGS" != "x"; then
sgehwolf@2482 423 AC_MSG_WARN([Ignoring ASFLAGS($ASFLAGS) found in environment. Use --with-extra-asflags])
sgehwolf@2482 424 fi
sgehwolf@2482 425
kevinw@2206 426 AC_ARG_WITH(extra-cflags, [AS_HELP_STRING([--with-extra-cflags],
kevinw@2206 427 [extra flags to be used when compiling jdk c-files])])
kevinw@2206 428
kevinw@2206 429 AC_ARG_WITH(extra-cxxflags, [AS_HELP_STRING([--with-extra-cxxflags],
kevinw@2206 430 [extra flags to be used when compiling jdk c++-files])])
kevinw@2206 431
kevinw@2206 432 AC_ARG_WITH(extra-ldflags, [AS_HELP_STRING([--with-extra-ldflags],
kevinw@2206 433 [extra flags to be used when linking jdk])])
kevinw@2206 434
sgehwolf@2482 435 AC_ARG_WITH(extra-asflags, [AS_HELP_STRING([--with-extra-asflags],
sgehwolf@2482 436 [extra flags to be passed to the assembler])])
sgehwolf@2482 437
kevinw@2206 438 CFLAGS_JDK="${CFLAGS_JDK} $with_extra_cflags"
kevinw@2206 439 CXXFLAGS_JDK="${CXXFLAGS_JDK} $with_extra_cxxflags"
kevinw@2206 440 LDFLAGS_JDK="${LDFLAGS_JDK} $with_extra_ldflags"
kevinw@2206 441
kevinw@2206 442 # Hotspot needs these set in their legacy form
kevinw@2215 443 LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS $with_extra_cflags"
kevinw@2215 444 LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS $with_extra_cxxflags"
kevinw@2215 445 LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS $with_extra_ldflags"
sgehwolf@2482 446 LEGACY_EXTRA_ASFLAGS="$with_extra_asflags"
kevinw@2206 447
kevinw@2206 448 AC_SUBST(LEGACY_EXTRA_CFLAGS)
kevinw@2206 449 AC_SUBST(LEGACY_EXTRA_CXXFLAGS)
kevinw@2206 450 AC_SUBST(LEGACY_EXTRA_LDFLAGS)
sgehwolf@2482 451 AC_SUBST(LEGACY_EXTRA_ASFLAGS)
kevinw@2206 452
kevinw@2206 453 ###############################################################################
kevinw@2206 454 #
kevinw@2206 455 # Now setup the CFLAGS and LDFLAGS for the JDK build.
kevinw@2206 456 # Later we will also have CFLAGS and LDFLAGS for the hotspot subrepo build.
kevinw@2206 457 #
kevinw@2206 458
sgehwolf@2424 459 FDLIBM_CFLAGS=""
kevinw@2206 460 # Setup compiler/platform specific flags to CFLAGS_JDK,
kevinw@2206 461 # CXXFLAGS_JDK and CCXXFLAGS_JDK (common to C and CXX?)
kevinw@2206 462 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 463 # these options are used for both C and C++ compiles
kevinw@2206 464 CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK -Wall -Wno-parentheses -Wextra -Wno-unused -Wno-unused-parameter -Wformat=2 \
andrew@2445 465 -pipe -fstack-protector -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE"
kevinw@2206 466 case $OPENJDK_TARGET_CPU_ARCH in
kevinw@2206 467 arm )
kevinw@2206 468 # on arm we don't prevent gcc to omit frame pointer but do prevent strict aliasing
kevinw@2206 469 CFLAGS_JDK="${CFLAGS_JDK} -fno-strict-aliasing"
kevinw@2206 470 ;;
kevinw@2206 471 ppc )
kevinw@2206 472 # on ppc we don't prevent gcc to omit frame pointer nor strict-aliasing
kevinw@2206 473 ;;
kevinw@2206 474 * )
kevinw@2206 475 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -fno-omit-frame-pointer"
kevinw@2206 476 CFLAGS_JDK="${CFLAGS_JDK} -fno-strict-aliasing"
kevinw@2206 477 ;;
kevinw@2206 478 esac
kevinw@2206 479 TOOLCHAIN_CHECK_COMPILER_VERSION(6, FLAGS_SETUP_GCC6_COMPILER_FLAGS)
sgehwolf@2424 480
sgehwolf@2424 481 # Check that the compiler supports -ffp-contract=off flag
sgehwolf@2424 482 # Set FDLIBM_CFLAGS to -ffp-contract=off if it does.
sgehwolf@2424 483 # For GCC < 4.6, on x86, x86_64 and ppc check for
sgehwolf@2424 484 # -mno-fused-madd and -fno-strict-aliasing. If they exist,
sgehwolf@2424 485 # use them as a substitute for -ffp-contract=off.
sgehwolf@2424 486 #
sgehwolf@2424 487 # These flags are required for GCC-based builds of
sgehwolf@2424 488 # fdlibm with optimization without losing precision.
sgehwolf@2424 489 # Notably, -ffp-contract=off needs to be added for GCC >= 4.6,
sgehwolf@2424 490 # -mno-fused-madd -fno-strict-aliasing for GCC < 4.6
sgehwolf@2424 491 COMPILER_FP_CONTRACT_OFF_FLAG="-ffp-contract=off"
sgehwolf@2424 492 FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]COMPILER_FP_CONTRACT_OFF_FLAG -Werror],
sgehwolf@2424 493 [], [COMPILER_FP_CONTRACT_OFF_FLAG=""])
sgehwolf@2424 494 if test "x$COMPILER_FP_CONTRACT_OFF_FLAG" = x; then
sgehwolf@2424 495 if test "$OPENJDK_TARGET_CPU_ARCH" = "x86" ||
sgehwolf@2424 496 test "$OPENJDK_TARGET_CPU_ARCH" = "x86_64" ||
sgehwolf@2424 497 test "$OPENJDK_TARGET_CPU_ARCH" = "ppc"; then
sgehwolf@2424 498 M_NO_FUSED_ADD_FLAG="-mno-fused-madd"
sgehwolf@2424 499 FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]M_NO_FUSED_ADD_FLAG -Werror],
sgehwolf@2424 500 [], [M_NO_FUSED_ADD_FLAG=""])
sgehwolf@2424 501 NO_STRICT_ALIASING_FLAG="-fno-strict-aliasing"
sgehwolf@2424 502 FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]NO_STRICT_ALIASING_FLAG -Werror],
sgehwolf@2424 503 [], [NO_STRICT_ALIASING_FLAG=""])
sgehwolf@2424 504 if test "x$M_NO_FUSED_ADD_FLAG" != "x" && test "x$NO_STRICT_ALIASING_FLAG" != "x"; then
sgehwolf@2424 505 FDLIBM_CFLAGS="$M_NO_FUSED_ADD_FLAG $NO_STRICT_ALIASING_FLAG"
sgehwolf@2424 506 fi
sgehwolf@2424 507 fi
sgehwolf@2424 508 else
sgehwolf@2424 509 FDLIBM_CFLAGS="$COMPILER_FP_CONTRACT_OFF_FLAG"
sgehwolf@2424 510 fi
kevinw@2206 511 elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 512 CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK -DTRACING -DMACRO_MEMSYS_OPS -DBREAKPTS"
kevinw@2206 513 if test "x$OPENJDK_TARGET_CPU_ARCH" = xx86; then
kevinw@2206 514 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DcpuIntel -Di586 -D$OPENJDK_TARGET_CPU_LEGACY_LIB"
kevinw@2206 515 CFLAGS_JDK="$CFLAGS_JDK -erroff=E_BAD_PRAGMA_PACK_VALUE"
kevinw@2206 516 fi
kevinw@2206 517
kevinw@2206 518 CFLAGS_JDK="$CFLAGS_JDK -xc99=%none -xCC -errshort=tags -Xa -v -mt -W0,-noglobal"
kevinw@2206 519 CXXFLAGS_JDK="$CXXFLAGS_JDK -errtags=yes +w -mt -features=no%except -DCC_NOEX -norunpath -xnolib"
kevinw@2206 520 elif test "x$TOOLCHAIN_TYPE" = xxlc; then
kevinw@2206 521 CFLAGS_JDK="$CFLAGS_JDK -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE -DSTDC"
kevinw@2206 522 CXXFLAGS_JDK="$CXXFLAGS_JDK -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE -DSTDC"
kevinw@2206 523 elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2223 524 CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK \
kevinw@2223 525 -Zi -MD -Zc:wchar_t- -W3 -wd4800 \
kevinw@2223 526 -DWIN32_LEAN_AND_MEAN \
kevinw@2223 527 -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE \
kevinw@2223 528 -DWIN32 -DIAL"
kevinw@2206 529 if test "x$OPENJDK_TARGET_CPU" = xx86_64; then
kevinw@2206 530 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_AMD64_ -Damd64"
kevinw@2206 531 else
kevinw@2206 532 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_X86_ -Dx86"
kevinw@2206 533 fi
kevinw@2223 534 # If building with Visual Studio 2010, we can still use _STATIC_CPPLIB to
kevinw@2223 535 # avoid bundling msvcpNNN.dll. Doesn't work with newer versions of visual
kevinw@2223 536 # studio.
kevinw@2223 537 if test "x$TOOLCHAIN_VERSION" = "x2010"; then
aivanov@2225 538 CCXXFLAGS_JDK="$CCXXFLAGS_JDK \
kevinw@2223 539 -D_STATIC_CPPLIB -D_DISABLE_DEPRECATE_STATIC_CPPLIB"
kevinw@2223 540 fi
kevinw@2206 541 fi
sgehwolf@2424 542 AC_SUBST(FDLIBM_CFLAGS)
kevinw@2206 543
kevinw@2206 544 ###############################################################################
kevinw@2206 545
kevinw@2206 546 # Adjust flags according to debug level.
kevinw@2206 547 case $DEBUG_LEVEL in
kevinw@2206 548 fastdebug )
kevinw@2206 549 CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
kevinw@2206 550 CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
kevinw@2206 551 C_O_FLAG_HI="$C_O_FLAG_NORM"
kevinw@2206 552 C_O_FLAG_NORM="$C_O_FLAG_NORM"
kevinw@2206 553 CXX_O_FLAG_HI="$CXX_O_FLAG_NORM"
kevinw@2206 554 CXX_O_FLAG_NORM="$CXX_O_FLAG_NORM"
kevinw@2206 555 JAVAC_FLAGS="$JAVAC_FLAGS -g"
kevinw@2206 556 ;;
kevinw@2206 557 slowdebug )
kevinw@2206 558 CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
kevinw@2206 559 CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
kevinw@2206 560 C_O_FLAG_HI="$C_O_FLAG_NONE"
kevinw@2206 561 C_O_FLAG_NORM="$C_O_FLAG_NONE"
kevinw@2206 562 CXX_O_FLAG_HI="$CXX_O_FLAG_NONE"
kevinw@2206 563 CXX_O_FLAG_NORM="$CXX_O_FLAG_NONE"
kevinw@2206 564 JAVAC_FLAGS="$JAVAC_FLAGS -g"
kevinw@2206 565 ;;
kevinw@2206 566 esac
kevinw@2206 567
kevinw@2206 568 # Setup LP64
kevinw@2206 569 CCXXFLAGS_JDK="$CCXXFLAGS_JDK $ADD_LP64"
kevinw@2206 570
kevinw@2206 571 # Set some common defines. These works for all compilers, but assume
kevinw@2206 572 # -D is universally accepted.
kevinw@2206 573
kevinw@2206 574 # Setup endianness
kevinw@2206 575 if test "x$OPENJDK_TARGET_CPU_ENDIAN" = xlittle; then
kevinw@2206 576 # The macro _LITTLE_ENDIAN needs to be defined the same to avoid the
kevinw@2206 577 # Sun C compiler warning message: warning: macro redefined: _LITTLE_ENDIAN
kevinw@2206 578 # (The Solaris X86 system defines this in file /usr/include/sys/isa_defs.h).
kevinw@2206 579 # Note: -Dmacro is the same as #define macro 1
kevinw@2206 580 # -Dmacro= is the same as #define macro
kevinw@2206 581 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 582 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN="
kevinw@2206 583 else
kevinw@2206 584 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN"
kevinw@2206 585 fi
kevinw@2206 586 else
kevinw@2215 587 # Same goes for _BIG_ENDIAN. Do we really need to set *ENDIAN on Solaris if they
kevinw@2215 588 # are defined in the system?
kevinw@2215 589 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2215 590 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN="
kevinw@2215 591 else
kevinw@2215 592 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN"
kevinw@2215 593 fi
kevinw@2206 594 fi
sgehwolf@2325 595 if test "x$OPENJDK_TARGET_CPU" = xppc64le; then
sgehwolf@2325 596 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DABI_ELFv2"
sgehwolf@2325 597 fi
kevinw@2206 598
kevinw@2206 599 # Setup target OS define. Use OS target name but in upper case.
kevinw@2206 600 OPENJDK_TARGET_OS_UPPERCASE=`$ECHO $OPENJDK_TARGET_OS | $TR 'abcdefghijklmnopqrstuvwxyz' 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'`
kevinw@2206 601 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D$OPENJDK_TARGET_OS_UPPERCASE"
kevinw@2206 602
kevinw@2206 603 # Setup target CPU
kevinw@2206 604 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DARCH='\"$OPENJDK_TARGET_CPU_LEGACY\"' -D$OPENJDK_TARGET_CPU_LEGACY"
kevinw@2206 605
kevinw@2206 606 # Setup debug/release defines
kevinw@2206 607 if test "x$DEBUG_LEVEL" = xrelease; then
kevinw@2206 608 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DNDEBUG"
kevinw@2206 609 if test "x$OPENJDK_TARGET_OS" = xsolaris; then
kevinw@2206 610 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DTRIMMED"
kevinw@2206 611 fi
kevinw@2206 612 else
kevinw@2206 613 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DDEBUG"
kevinw@2206 614 fi
kevinw@2206 615
kevinw@2206 616 # Setup release name
kevinw@2206 617 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DRELEASE='\"\$(RELEASE)\"'"
kevinw@2206 618
kevinw@2206 619
kevinw@2206 620 # Set some additional per-OS defines.
kevinw@2206 621 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 622 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_ALLBSD_SOURCE -D_DARWIN_UNLIMITED_SELECT"
kevinw@2206 623 elif test "x$OPENJDK_TARGET_OS" = xaix; then
kevinw@2206 624 # FIXME: PPC64 should not be here.
kevinw@2206 625 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DPPC64"
kevinw@2206 626 elif test "x$OPENJDK_TARGET_OS" = xbsd; then
kevinw@2206 627 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_ALLBSD_SOURCE"
kevinw@2206 628 fi
kevinw@2206 629
kevinw@2206 630 # Additional macosx handling
kevinw@2206 631 if test "x$OPENJDK_TARGET_OS" = xmacosx; then
kevinw@2206 632 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 633 # FIXME: This needs to be exported in spec.gmk due to closed legacy code.
kevinw@2206 634 # FIXME: clean this up, and/or move it elsewhere.
kevinw@2206 635
kevinw@2206 636 # Setting these parameters makes it an error to link to macosx APIs that are
kevinw@2206 637 # newer than the given OS version and makes the linked binaries compatible
kevinw@2206 638 # even if built on a newer version of the OS.
kevinw@2206 639 # The expected format is X.Y.Z
kevinw@2206 640 MACOSX_VERSION_MIN=10.7.0
kevinw@2206 641 AC_SUBST(MACOSX_VERSION_MIN)
kevinw@2206 642
kevinw@2206 643 # The macro takes the version with no dots, ex: 1070
kevinw@2206 644 # Let the flags variables get resolved in make for easier override on make
kevinw@2206 645 # command line.
kevinw@2206 646 CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DMAC_OS_X_VERSION_MAX_ALLOWED=\$(subst .,,\$(MACOSX_VERSION_MIN)) -mmacosx-version-min=\$(MACOSX_VERSION_MIN)"
kevinw@2206 647 LDFLAGS_JDK="$LDFLAGS_JDK -mmacosx-version-min=\$(MACOSX_VERSION_MIN)"
kevinw@2206 648 fi
kevinw@2206 649 fi
kevinw@2206 650
kevinw@2206 651 # Setup some hard coded includes
kevinw@2206 652 CCXXFLAGS_JDK="$CCXXFLAGS_JDK \
kevinw@2206 653 -I${JDK_OUTPUTDIR}/include \
kevinw@2206 654 -I${JDK_OUTPUTDIR}/include/$OPENJDK_TARGET_OS \
kevinw@2206 655 -I${JDK_TOPDIR}/src/share/javavm/export \
kevinw@2206 656 -I${JDK_TOPDIR}/src/$OPENJDK_TARGET_OS_EXPORT_DIR/javavm/export \
kevinw@2206 657 -I${JDK_TOPDIR}/src/share/native/common \
kevinw@2206 658 -I${JDK_TOPDIR}/src/$OPENJDK_TARGET_OS_API_DIR/native/common"
kevinw@2206 659
kevinw@2206 660 # The shared libraries are compiled using the picflag.
kevinw@2206 661 CFLAGS_JDKLIB="$CCXXFLAGS_JDK $CFLAGS_JDK $PICFLAG $CFLAGS_JDKLIB_EXTRA"
kevinw@2206 662 CXXFLAGS_JDKLIB="$CCXXFLAGS_JDK $CXXFLAGS_JDK $PICFLAG $CXXFLAGS_JDKLIB_EXTRA "
kevinw@2206 663
kevinw@2206 664 # Executable flags
alvdavi@2496 665 CFLAGS_JDKEXE="$CCXXFLAGS_JDK $CFLAGS_JDK $PIEFLAG"
alvdavi@2496 666 CXXFLAGS_JDKEXE="$CCXXFLAGS_JDK $CXXFLAGS_JDK $PIEFLAG"
kevinw@2206 667
kevinw@2206 668 AC_SUBST(CFLAGS_JDKLIB)
kevinw@2206 669 AC_SUBST(CFLAGS_JDKEXE)
kevinw@2206 670 AC_SUBST(CXXFLAGS_JDKLIB)
kevinw@2206 671 AC_SUBST(CXXFLAGS_JDKEXE)
kevinw@2206 672
kevinw@2206 673 # Setup LDFLAGS et al.
kevinw@2206 674 #
kevinw@2206 675 # Now this is odd. The JDK native libraries have to link against libjvm.so
kevinw@2206 676 # On 32-bit machines there is normally two distinct libjvm.so:s, client and server.
kevinw@2206 677 # Which should we link to? Are we lucky enough that the binary api to the libjvm.so library
kevinw@2206 678 # is identical for client and server? Yes. Which is picked at runtime (client or server)?
kevinw@2206 679 # Neither, since the chosen libjvm.so has already been loaded by the launcher, all the following
kevinw@2206 680 # libraries will link to whatever is in memory. Yuck.
kevinw@2206 681 #
kevinw@2206 682 # Thus we offer the compiler to find libjvm.so first in server then in client. It works. Ugh.
kevinw@2206 683 if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
kevinw@2206 684 LDFLAGS_JDK="$LDFLAGS_JDK -nologo -opt:ref -incremental:no"
kevinw@2206 685 if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then
kevinw@2206 686 LDFLAGS_JDK="$LDFLAGS_JDK -safeseh"
kevinw@2206 687 fi
kevinw@2206 688 # TODO: make -debug optional "--disable-full-debug-symbols"
kevinw@2206 689 LDFLAGS_JDK="$LDFLAGS_JDK -debug"
kevinw@2206 690 LDFLAGS_JDKLIB="${LDFLAGS_JDK} -dll -libpath:${JDK_OUTPUTDIR}/lib"
kevinw@2206 691 LDFLAGS_JDKLIB_SUFFIX=""
kevinw@2206 692 if test "x$OPENJDK_TARGET_CPU_BITS" = "x64"; then
kevinw@2206 693 LDFLAGS_STACK_SIZE=1048576
kevinw@2206 694 else
kevinw@2206 695 LDFLAGS_STACK_SIZE=327680
kevinw@2206 696 fi
kevinw@2206 697 LDFLAGS_JDKEXE="${LDFLAGS_JDK} /STACK:$LDFLAGS_STACK_SIZE"
kevinw@2206 698 else
kevinw@2206 699 if test "x$TOOLCHAIN_TYPE" = xgcc; then
kevinw@2206 700 # If this is a --hash-style=gnu system, use --hash-style=both, why?
kevinw@2206 701 # We have previously set HAS_GNU_HASH if this is the case
kevinw@2206 702 if test -n "$HAS_GNU_HASH"; then
kevinw@2206 703 LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker --hash-style=both "
kevinw@2206 704 fi
kevinw@2206 705 if test "x$OPENJDK_TARGET_OS" = xlinux; then
dbuck@2226 706 # And since we now know that the linker is gnu, then add:
dbuck@2226 707 # -z defs, to forbid undefined symbols in object files
dbuck@2226 708 # -z noexecstack, to mark stack regions as non-executable
dbuck@2226 709 LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker -z -Xlinker defs -Xlinker -z -Xlinker noexecstack"
kevinw@2206 710 if test "x$DEBUG_LEVEL" = "xrelease"; then
kevinw@2206 711 # When building release libraries, tell the linker optimize them.
kevinw@2206 712 # Should this be supplied to the OSS linker as well?
kevinw@2206 713 LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker -O1"
kevinw@2206 714 fi
kevinw@2206 715 fi
kevinw@2206 716 fi
kevinw@2206 717
kevinw@2206 718 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 719 LDFLAGS_JDK="$LDFLAGS_JDK -z defs -xildoff -ztext"
kevinw@2206 720 LDFLAGS_CXX_JDK="$LDFLAGS_CXX_JDK -norunpath -xnolib"
kevinw@2206 721 fi
kevinw@2206 722
kevinw@2206 723 LDFLAGS_JDKLIB="${LDFLAGS_JDK} $SHARED_LIBRARY_FLAGS \
kevinw@2206 724 -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}"
kevinw@2206 725
kevinw@2206 726 # On some platforms (mac) the linker warns about non existing -L dirs.
kevinw@2206 727 # Add server first if available. Linking aginst client does not always produce the same results.
kevinw@2206 728 # Only add client dir if client is being built. Add minimal (note not minimal1) if only building minimal1.
kevinw@2206 729 # Default to server for other variants.
kevinw@2206 730 if test "x$JVM_VARIANT_SERVER" = xtrue; then
kevinw@2206 731 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/server"
kevinw@2206 732 elif test "x$JVM_VARIANT_CLIENT" = xtrue; then
kevinw@2206 733 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/client"
kevinw@2206 734 elif test "x$JVM_VARIANT_MINIMAL1" = xtrue; then
kevinw@2206 735 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/minimal"
kevinw@2206 736 else
kevinw@2206 737 LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/server"
kevinw@2206 738 fi
kevinw@2206 739
kevinw@2206 740 LDFLAGS_JDKLIB_SUFFIX="-ljava -ljvm"
kevinw@2206 741 if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
kevinw@2206 742 LDFLAGS_JDKLIB_SUFFIX="$LDFLAGS_JDKLIB_SUFFIX -lc"
kevinw@2206 743 fi
kevinw@2206 744
kevinw@2206 745 LDFLAGS_JDKEXE="${LDFLAGS_JDK}"
kevinw@2206 746 if test "x$OPENJDK_TARGET_OS" = xlinux; then
kevinw@2206 747 LDFLAGS_JDKEXE="$LDFLAGS_JDKEXE -Xlinker --allow-shlib-undefined"
kevinw@2206 748 fi
alvdavi@2496 749 if test "x$TOOLCHAIN_TYPE" = xgcc; then
alvdavi@2497 750 # Enabling pie on 32 bit builds prevents the JVM from allocating a continuous
alvdavi@2497 751 # java heap.
alvdavi@2497 752 if test "x$OPENJDK_TARGET_CPU_BITS" != "x32"; then
alvdavi@2497 753 LDFLAGS_JDKEXE="$LDFLAGS_JDKEXE -pie"
alvdavi@2497 754 fi
alvdavi@2496 755 fi
kevinw@2206 756 fi
kevinw@2206 757 AC_SUBST(LDFLAGS_JDKLIB)
kevinw@2206 758 AC_SUBST(LDFLAGS_JDKEXE)
kevinw@2206 759 AC_SUBST(LDFLAGS_JDKLIB_SUFFIX)
kevinw@2206 760 AC_SUBST(LDFLAGS_JDKEXE_SUFFIX)
kevinw@2206 761 AC_SUBST(LDFLAGS_CXX_JDK)
kevinw@2206 762 ])
kevinw@2206 763
kevinw@2206 764
kevinw@2206 765 # FLAGS_C_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
kevinw@2206 766 # [RUN-IF-FALSE])
kevinw@2206 767 # ------------------------------------------------------------
kevinw@2206 768 # Check that the C compiler supports an argument
kevinw@2206 769 AC_DEFUN([FLAGS_C_COMPILER_CHECK_ARGUMENTS],
kevinw@2206 770 [
kevinw@2206 771 AC_MSG_CHECKING([if the C compiler supports "$1"])
kevinw@2206 772 supports=yes
kevinw@2206 773
kevinw@2206 774 saved_cflags="$CFLAGS"
kevinw@2206 775 CFLAGS="$CFLAGS $1"
kevinw@2206 776 AC_LANG_PUSH([C])
kevinw@2206 777 AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
kevinw@2206 778 [supports=no])
kevinw@2206 779 AC_LANG_POP([C])
kevinw@2206 780 CFLAGS="$saved_cflags"
kevinw@2206 781
kevinw@2206 782 AC_MSG_RESULT([$supports])
kevinw@2206 783 if test "x$supports" = "xyes" ; then
kevinw@2206 784 m4_ifval([$2], [$2], [:])
kevinw@2206 785 else
kevinw@2206 786 m4_ifval([$3], [$3], [:])
kevinw@2206 787 fi
kevinw@2206 788 ])
kevinw@2206 789
kevinw@2206 790 # FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
kevinw@2206 791 # [RUN-IF-FALSE])
kevinw@2206 792 # ------------------------------------------------------------
kevinw@2206 793 # Check that the C++ compiler supports an argument
kevinw@2206 794 AC_DEFUN([FLAGS_CXX_COMPILER_CHECK_ARGUMENTS],
kevinw@2206 795 [
kevinw@2206 796 AC_MSG_CHECKING([if the C++ compiler supports "$1"])
kevinw@2206 797 supports=yes
kevinw@2206 798
kevinw@2206 799 saved_cxxflags="$CXXFLAGS"
kevinw@2206 800 CXXFLAGS="$CXXFLAG $1"
kevinw@2206 801 AC_LANG_PUSH([C++])
kevinw@2206 802 AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
kevinw@2206 803 [supports=no])
kevinw@2206 804 AC_LANG_POP([C++])
kevinw@2206 805 CXXFLAGS="$saved_cxxflags"
kevinw@2206 806
kevinw@2206 807 AC_MSG_RESULT([$supports])
kevinw@2206 808 if test "x$supports" = "xyes" ; then
kevinw@2206 809 m4_ifval([$2], [$2], [:])
kevinw@2206 810 else
kevinw@2206 811 m4_ifval([$3], [$3], [:])
kevinw@2206 812 fi
kevinw@2206 813 ])
kevinw@2206 814
kevinw@2206 815 # FLAGS_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
kevinw@2206 816 # [RUN-IF-FALSE])
kevinw@2206 817 # ------------------------------------------------------------
kevinw@2206 818 # Check that the C and C++ compilers support an argument
kevinw@2206 819 AC_DEFUN([FLAGS_COMPILER_CHECK_ARGUMENTS],
kevinw@2206 820 [
kevinw@2206 821 FLAGS_C_COMPILER_CHECK_ARGUMENTS([$1],
kevinw@2206 822 [C_COMP_SUPPORTS="yes"],
kevinw@2206 823 [C_COMP_SUPPORTS="no"])
kevinw@2206 824 FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([$1],
kevinw@2206 825 [CXX_COMP_SUPPORTS="yes"],
kevinw@2206 826 [CXX_COMP_SUPPORTS="no"])
kevinw@2206 827
kevinw@2206 828 AC_MSG_CHECKING([if both compilers support "$1"])
kevinw@2206 829 supports=no
kevinw@2206 830 if test "x$C_COMP_SUPPORTS" = "xyes" -a "x$CXX_COMP_SUPPORTS" = "xyes"; then supports=yes; fi
kevinw@2206 831
kevinw@2206 832 AC_MSG_RESULT([$supports])
kevinw@2206 833 if test "x$supports" = "xyes" ; then
kevinw@2206 834 m4_ifval([$2], [$2], [:])
kevinw@2206 835 else
kevinw@2206 836 m4_ifval([$3], [$3], [:])
kevinw@2206 837 fi
kevinw@2206 838 ])
kevinw@2206 839
kevinw@2206 840 AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
kevinw@2206 841 [
kevinw@2206 842 # Some Zero and Shark settings.
kevinw@2206 843 # ZERO_ARCHFLAG tells the compiler which mode to build for
kevinw@2206 844 case "${OPENJDK_TARGET_CPU}" in
kevinw@2206 845 s390)
kevinw@2206 846 ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}31"
kevinw@2206 847 ;;
kevinw@2206 848 *)
kevinw@2206 849 ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}"
kevinw@2206 850 esac
kevinw@2206 851 FLAGS_COMPILER_CHECK_ARGUMENTS([$ZERO_ARCHFLAG], [], [ZERO_ARCHFLAG=""])
kevinw@2206 852 AC_SUBST(ZERO_ARCHFLAG)
kevinw@2206 853
kevinw@2206 854 # Check that the compiler supports -mX (or -qX on AIX) flags
kevinw@2206 855 # Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does
kevinw@2206 856 FLAGS_COMPILER_CHECK_ARGUMENTS([${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}],
kevinw@2206 857 [COMPILER_SUPPORTS_TARGET_BITS_FLAG=true],
kevinw@2206 858 [COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
kevinw@2206 859 AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
kevinw@2206 860 ])
kevinw@2206 861
kevinw@2206 862 AC_DEFUN_ONCE([FLAGS_SETUP_GCC6_COMPILER_FLAGS],
kevinw@2206 863 [
kevinw@2206 864 # These flags are required for GCC 6 builds as undefined behaviour in OpenJDK code
kevinw@2206 865 # runs afoul of the more aggressive versions of these optimisations.
kevinw@2206 866 # Notably, value range propagation now assumes that the this pointer of C++
kevinw@2206 867 # member functions is non-null.
kevinw@2206 868 NO_DELETE_NULL_POINTER_CHECKS_CFLAG="-fno-delete-null-pointer-checks"
kevinw@2206 869 FLAGS_COMPILER_CHECK_ARGUMENTS([$NO_DELETE_NULL_POINTER_CHECKS_CFLAG -Werror],
kevinw@2206 870 [], [NO_DELETE_NULL_POINTER_CHECKS_CFLAG=""])
kevinw@2206 871 AC_SUBST([NO_DELETE_NULL_POINTER_CHECKS_CFLAG])
kevinw@2206 872 NO_LIFETIME_DSE_CFLAG="-fno-lifetime-dse"
kevinw@2206 873 FLAGS_COMPILER_CHECK_ARGUMENTS([$NO_LIFETIME_DSE_CFLAG -Werror],
kevinw@2206 874 [], [NO_LIFETIME_DSE_CFLAG=""])
kevinw@2206 875 CFLAGS_JDK="${CFLAGS_JDK} ${NO_DELETE_NULL_POINTER_CHECKS_CFLAG} ${NO_LIFETIME_DSE_CFLAG}"
kevinw@2206 876 AC_SUBST([NO_LIFETIME_DSE_CFLAG])
kevinw@2206 877 ])
kevinw@2206 878

mercurial