Blame openjdk/common/autoconf/flags.m4

Packit Service 46fadf
#
Packit Service 46fadf
# Copyright (c) 2011, 2018, Oracle and/or its affiliates. All rights reserved.
Packit Service 46fadf
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
Packit Service 46fadf
#
Packit Service 46fadf
# This code is free software; you can redistribute it and/or modify it
Packit Service 46fadf
# under the terms of the GNU General Public License version 2 only, as
Packit Service 46fadf
# published by the Free Software Foundation.  Oracle designates this
Packit Service 46fadf
# particular file as subject to the "Classpath" exception as provided
Packit Service 46fadf
# by Oracle in the LICENSE file that accompanied this code.
Packit Service 46fadf
#
Packit Service 46fadf
# This code is distributed in the hope that it will be useful, but WITHOUT
Packit Service 46fadf
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
Packit Service 46fadf
# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit Service 46fadf
# version 2 for more details (a copy is included in the LICENSE file that
Packit Service 46fadf
# accompanied this code).
Packit Service 46fadf
#
Packit Service 46fadf
# You should have received a copy of the GNU General Public License version
Packit Service 46fadf
# 2 along with this work; if not, write to the Free Software Foundation,
Packit Service 46fadf
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
Packit Service 46fadf
#
Packit Service 46fadf
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
Packit Service 46fadf
# or visit www.oracle.com if you need additional information or have any
Packit Service 46fadf
# questions.
Packit Service 46fadf
#
Packit Service 46fadf
Packit Service 46fadf
AC_DEFUN_ONCE([FLAGS_SETUP_INIT_FLAGS],
Packit Service 46fadf
[
Packit Service 46fadf
  # Option used to tell the compiler whether to create 32- or 64-bit executables
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xxlc; then
Packit Service 46fadf
    COMPILER_TARGET_BITS_FLAG="-q"
Packit Service 46fadf
  else
Packit Service 46fadf
    COMPILER_TARGET_BITS_FLAG="-m"
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(COMPILER_TARGET_BITS_FLAG)
Packit Service 46fadf
Packit Service 46fadf
  # FIXME: figure out if we should select AR flags depending on OS or toolchain.
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_OS" = xmacosx; then
Packit Service 46fadf
    ARFLAGS="-r"
Packit Service 46fadf
  elif test "x$OPENJDK_TARGET_OS" = xaix; then
Packit Service 46fadf
    ARFLAGS="-X64"
Packit Service 46fadf
  elif test "x$OPENJDK_TARGET_OS" = xwindows; then
Packit Service 46fadf
    # lib.exe is used as AR to create static libraries.
Packit Service 46fadf
    ARFLAGS="-nologo -NODEFAULTLIB:MSVCRT"
Packit Service 46fadf
  else
Packit Service 46fadf
    ARFLAGS=""
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(ARFLAGS)
Packit Service 46fadf
Packit Service 46fadf
  ## Setup strip.
Packit Service 46fadf
  # FIXME: should this really be per platform, or should it be per toolchain type?
Packit Service 46fadf
  # strip is not provided by clang or solstudio; so guessing platform makes most sense.
Packit Service 46fadf
  # FIXME: we should really only export STRIPFLAGS from here, not POST_STRIP_CMD.
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_OS" = xlinux; then
Packit Service 46fadf
    STRIPFLAGS="-g"
Packit Service 46fadf
  elif test "x$OPENJDK_TARGET_OS" = xsolaris; then
Packit Service 46fadf
    STRIPFLAGS="-x"
Packit Service 46fadf
  elif test "x$OPENJDK_TARGET_OS" = xmacosx; then
Packit Service 46fadf
    STRIPFLAGS="-S"
Packit Service 46fadf
  elif test "x$OPENJDK_TARGET_OS" = xaix; then
Packit Service 46fadf
    STRIPFLAGS="-X32_64"
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_OS" != xwindows; then
Packit Service 46fadf
    POST_STRIP_CMD="$STRIP $STRIPFLAGS"
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(POST_STRIP_CMD)
Packit Service 46fadf
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_OS" = xsolaris; then
Packit Service 46fadf
    # FIXME: break out into MCSFLAGS
Packit Service 46fadf
    POST_MCS_CMD="$MCS -d -a \"JDK $FULL_VERSION\""
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(POST_MCS_CMD)
Packit Service 46fadf
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
    CC_OUT_OPTION=-Fo
Packit Service 46fadf
    EXE_OUT_OPTION=-out:
Packit Service 46fadf
    LD_OUT_OPTION=-out:
Packit Service 46fadf
    AR_OUT_OPTION=-out:
Packit Service 46fadf
  else
Packit Service 46fadf
    # The option used to specify the target .o,.a or .so file.
Packit Service 46fadf
    # When compiling, how to specify the to be created object file.
Packit Service 46fadf
    CC_OUT_OPTION='-o$(SPACE)'
Packit Service 46fadf
    # When linking, how to specify the to be created executable.
Packit Service 46fadf
    EXE_OUT_OPTION='-o$(SPACE)'
Packit Service 46fadf
    # When linking, how to specify the to be created dynamically linkable library.
Packit Service 46fadf
    LD_OUT_OPTION='-o$(SPACE)'
Packit Service 46fadf
    # When archiving, how to specify the to be create static archive for object files.
Packit Service 46fadf
    AR_OUT_OPTION='rcs$(SPACE)'
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(CC_OUT_OPTION)
Packit Service 46fadf
  AC_SUBST(EXE_OUT_OPTION)
Packit Service 46fadf
  AC_SUBST(LD_OUT_OPTION)
Packit Service 46fadf
  AC_SUBST(AR_OUT_OPTION)
Packit Service 46fadf
Packit Service 46fadf
  # On Windows, we need to set RC flags.
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
    RC_FLAGS="-nologo -l 0x409 -r"
Packit Service 46fadf
    if test "x$VARIANT" = xOPT; then
Packit Service 46fadf
      RC_FLAGS="$RC_FLAGS -d NDEBUG"
Packit Service 46fadf
    fi
Packit Service 46fadf
Packit Service 46fadf
    # The version variables used to create RC_FLAGS may be overridden
Packit Service 46fadf
    # in a custom configure script, or possibly the command line.
Packit Service 46fadf
    # Let those variables be expanded at make time in spec.gmk.
Packit Service 46fadf
    # The \$ are escaped to the shell, and the $(...) variables
Packit Service 46fadf
    # are evaluated by make.
Packit Service 46fadf
    RC_FLAGS="$RC_FLAGS \
Packit Service 46fadf
        -d \"JDK_BUILD_ID=\$(FULL_VERSION)\" \
Packit Service 46fadf
        -d \"JDK_COMPANY=\$(COMPANY_NAME)\" \
Packit Service 46fadf
        -d \"JDK_COMPONENT=\$(PRODUCT_NAME) \$(JDK_RC_PLATFORM_NAME) binary\" \
Packit Service 46fadf
        -d \"JDK_VER=\$(JDK_MINOR_VERSION).\$(JDK_MICRO_VERSION).\$(COOKED_JDK_UPDATE_VERSION).\$(COOKED_BUILD_NUMBER)\" \
Packit Service 46fadf
        -d \"JDK_COPYRIGHT=Copyright \xA9 $COPYRIGHT_YEAR\" \
Packit Service 46fadf
        -d \"JDK_NAME=\$(PRODUCT_NAME) \$(JDK_RC_PLATFORM_NAME) \$(JDK_MINOR_VERSION) \$(JDK_UPDATE_META_TAG)\" \
Packit Service 46fadf
        -d \"JDK_FVER=\$(JDK_MINOR_VERSION),\$(JDK_MICRO_VERSION),\$(if \$(COOKED_JDK_UPDATE_VERSION),\$(COOKED_JDK_UPDATE_VERSION),0),\$(COOKED_BUILD_NUMBER)\""
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(RC_FLAGS)
Packit Service 46fadf
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
    # FIXME: likely bug, should be CCXXFLAGS_JDK? or one for C or CXX.
Packit Service 46fadf
    CCXXFLAGS="$CCXXFLAGS -nologo"
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  if test "x$SYSROOT" != "x"; then
Packit Service 46fadf
    if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
      if test "x$OPENJDK_TARGET_OS" = xsolaris; then
Packit Service 46fadf
        # Solaris Studio does not have a concept of sysroot. Instead we must
Packit Service 46fadf
        # make sure the default include and lib dirs are appended to each 
Packit Service 46fadf
        # compile and link command line.
Packit Service 46fadf
        SYSROOT_CFLAGS="-I$SYSROOT/usr/include"
Packit Service 46fadf
        SYSROOT_LDFLAGS="-L$SYSROOT/usr/lib$OPENJDK_TARGET_CPU_ISADIR \
Packit Service 46fadf
            -L$SYSROOT/lib$OPENJDK_TARGET_CPU_ISADIR \
Packit Service 46fadf
            -L$SYSROOT/usr/ccs/lib$OPENJDK_TARGET_CPU_ISADIR"
Packit Service 46fadf
      fi
Packit Service 46fadf
    elif test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
      SYSROOT_CFLAGS="--sysroot=\"$SYSROOT\""
Packit Service 46fadf
      SYSROOT_LDFLAGS="--sysroot=\"$SYSROOT\""
Packit Service 46fadf
    elif test "x$TOOLCHAIN_TYPE" = xclang; then
Packit Service 46fadf
      SYSROOT_CFLAGS="-isysroot \"$SYSROOT\""
Packit Service 46fadf
      SYSROOT_LDFLAGS="-isysroot \"$SYSROOT\""
Packit Service 46fadf
    fi
Packit Service 46fadf
    # Propagate the sysroot args to hotspot
Packit Service 46fadf
    LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS $SYSROOT_CFLAGS"
Packit Service 46fadf
    LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS $SYSROOT_CFLAGS"
Packit Service 46fadf
    LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS $SYSROOT_LDFLAGS"
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(SYSROOT_CFLAGS)
Packit Service 46fadf
  AC_SUBST(SYSROOT_LDFLAGS)
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_LIBS],
Packit Service 46fadf
[
Packit Service 46fadf
  ###############################################################################
Packit Service 46fadf
  #
Packit Service 46fadf
  # How to compile shared libraries.
Packit Service 46fadf
  #
Packit Service 46fadf
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
    PICFLAG="-fPIC"
Packit Service 46fadf
    PIEFLAG="-fPIE"
Packit Service 46fadf
    C_FLAG_REORDER=''
Packit Service 46fadf
    CXX_FLAG_REORDER=''
Packit Service 46fadf
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_OS" = xmacosx; then
Packit Service 46fadf
      # Linking is different on MacOSX
Packit Service 46fadf
      SHARED_LIBRARY_FLAGS="-dynamiclib -compatibility_version 1.0.0 -current_version 1.0.0 $PICFLAG"
Packit Service 46fadf
      SET_EXECUTABLE_ORIGIN='-Xlinker -rpath -Xlinker @loader_path/.'
Packit Service 46fadf
      SET_SHARED_LIBRARY_ORIGIN="$SET_EXECUTABLE_ORIGIN"
Packit Service 46fadf
      SET_SHARED_LIBRARY_NAME='-Xlinker -install_name -Xlinker @rpath/[$]1'
Packit Service 46fadf
      SET_SHARED_LIBRARY_MAPFILE=''
Packit Service 46fadf
    else
Packit Service 46fadf
      # Default works for linux, might work on other platforms as well.
Packit Service 46fadf
      SHARED_LIBRARY_FLAGS='-shared'
Packit Service 46fadf
      SET_EXECUTABLE_ORIGIN='-Xlinker -rpath -Xlinker \$$$$ORIGIN[$]1'
Packit Service 46fadf
      SET_SHARED_LIBRARY_ORIGIN="-Xlinker -z -Xlinker origin $SET_EXECUTABLE_ORIGIN"
Packit Service 46fadf
      SET_SHARED_LIBRARY_NAME='-Xlinker -soname=[$]1'
Packit Service 46fadf
      SET_SHARED_LIBRARY_MAPFILE='-Xlinker -version-script=[$]1'
Packit Service 46fadf
    fi
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
    PICFLAG="-KPIC"
Packit Service 46fadf
    PIEFLAG=""
Packit Service 46fadf
    C_FLAG_REORDER='-xF'
Packit Service 46fadf
    CXX_FLAG_REORDER='-xF'
Packit Service 46fadf
    SHARED_LIBRARY_FLAGS="-G"
Packit Service 46fadf
    SET_EXECUTABLE_ORIGIN='-R\$$$$ORIGIN[$]1'
Packit Service 46fadf
    SET_SHARED_LIBRARY_ORIGIN="$SET_EXECUTABLE_ORIGIN"
Packit Service 46fadf
    SET_SHARED_LIBRARY_NAME=''
Packit Service 46fadf
    SET_SHARED_LIBRARY_MAPFILE='-M[$]1'
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xxlc; then
Packit Service 46fadf
    PICFLAG="-qpic=large"
Packit Service 46fadf
    PIEFLAG=""
Packit Service 46fadf
    C_FLAG_REORDER=''
Packit Service 46fadf
    CXX_FLAG_REORDER=''
Packit Service 46fadf
    SHARED_LIBRARY_FLAGS="-qmkshrobj"
Packit Service 46fadf
    SET_EXECUTABLE_ORIGIN=""
Packit Service 46fadf
    SET_SHARED_LIBRARY_ORIGIN=''
Packit Service 46fadf
    SET_SHARED_LIBRARY_NAME=''
Packit Service 46fadf
    SET_SHARED_LIBRARY_MAPFILE=''
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
    PICFLAG=""
Packit Service 46fadf
    PIEFLAG=""
Packit Service 46fadf
    C_FLAG_REORDER=''
Packit Service 46fadf
    CXX_FLAG_REORDER=''
Packit Service 46fadf
    SHARED_LIBRARY_FLAGS="-LD"
Packit Service 46fadf
    SET_EXECUTABLE_ORIGIN=''
Packit Service 46fadf
    SET_SHARED_LIBRARY_ORIGIN=''
Packit Service 46fadf
    SET_SHARED_LIBRARY_NAME=''
Packit Service 46fadf
    SET_SHARED_LIBRARY_MAPFILE=''
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  AC_SUBST(C_FLAG_REORDER)
Packit Service 46fadf
  AC_SUBST(CXX_FLAG_REORDER)
Packit Service 46fadf
  AC_SUBST(SHARED_LIBRARY_FLAGS)
Packit Service 46fadf
  AC_SUBST(SET_EXECUTABLE_ORIGIN)
Packit Service 46fadf
  AC_SUBST(SET_SHARED_LIBRARY_ORIGIN)
Packit Service 46fadf
  AC_SUBST(SET_SHARED_LIBRARY_NAME)
Packit Service 46fadf
  AC_SUBST(SET_SHARED_LIBRARY_MAPFILE)
Packit Service 46fadf
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_OS" = xsolaris; then
Packit Service 46fadf
    CFLAGS_JDK="${CFLAGS_JDK} -D__solaris__"
Packit Service 46fadf
    CXXFLAGS_JDK="${CXXFLAGS_JDK} -D__solaris__"
Packit Service 46fadf
    CFLAGS_JDKLIB_EXTRA='-xstrconst'
Packit Service 46fadf
  fi
Packit Service 46fadf
  # The (cross) compiler is now configured, we can now test capabilities
Packit Service 46fadf
  # of the target platform.
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
# Documentation on common flags used for solstudio in HIGHEST.
Packit Service 46fadf
#
Packit Service 46fadf
# WARNING: Use of OPTIMIZATION_LEVEL=HIGHEST in your Makefile needs to be
Packit Service 46fadf
#          done with care, there are some assumptions below that need to
Packit Service 46fadf
#          be understood about the use of pointers, and IEEE behavior.
Packit Service 46fadf
#
Packit Service 46fadf
# -fns: Use non-standard floating point mode (not IEEE 754)
Packit Service 46fadf
# -fsimple: Do some simplification of floating point arithmetic (not IEEE 754)
Packit Service 46fadf
# -fsingle: Use single precision floating point with 'float'
Packit Service 46fadf
# -xalias_level=basic: Assume memory references via basic pointer types do not alias
Packit Service 46fadf
#   (Source with excessing pointer casting and data access with mixed
Packit Service 46fadf
#    pointer types are not recommended)
Packit Service 46fadf
# -xbuiltin=%all: Use intrinsic or inline versions for math/std functions
Packit Service 46fadf
#   (If you expect perfect errno behavior, do not use this)
Packit Service 46fadf
# -xdepend: Loop data dependency optimizations (need -xO3 or higher)
Packit Service 46fadf
# -xrestrict: Pointer parameters to functions do not overlap
Packit Service 46fadf
#   (Similar to -xalias_level=basic usage, but less obvious sometimes.
Packit Service 46fadf
#    If you pass in multiple pointers to the same data, do not use this)
Packit Service 46fadf
# -xlibmil: Inline some library routines
Packit Service 46fadf
#   (If you expect perfect errno behavior, do not use this)
Packit Service 46fadf
# -xlibmopt: Use optimized math routines (CURRENTLY DISABLED)
Packit Service 46fadf
#   (If you expect perfect errno behavior, do not use this)
Packit Service 46fadf
#  Can cause undefined external on Solaris 8 X86 on __sincos, removing for now
Packit Service 46fadf
Packit Service 46fadf
    # FIXME: this will never happen since sparc != sparcv9, ie 32 bit, which we don't build anymore.
Packit Service 46fadf
    # Bug?
Packit Service 46fadf
    #if test "x$OPENJDK_TARGET_CPU" = xsparc; then
Packit Service 46fadf
    #  CFLAGS_JDK="${CFLAGS_JDK} -xmemalign=4s"
Packit Service 46fadf
    #  CXXFLAGS_JDK="${CXXFLAGS_JDK} -xmemalign=4s"
Packit Service 46fadf
    #fi
Packit Service 46fadf
Packit Service 46fadf
AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_OPTIMIZATION],
Packit Service 46fadf
[
Packit Service 46fadf
Packit Service 46fadf
  ###############################################################################
Packit Service 46fadf
  #
Packit Service 46fadf
  # Setup the opt flags for different compilers
Packit Service 46fadf
  # and different operating systems.
Packit Service 46fadf
  #
Packit Service 46fadf
Packit Service 46fadf
  # FIXME: this was indirectly the old default, but just inherited.
Packit Service 46fadf
  # if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
  #   C_FLAG_DEPS="-MMD -MF"
Packit Service 46fadf
  # fi
Packit Service 46fadf
Packit Service 46fadf
  # Generate make dependency files
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
    C_FLAG_DEPS="-MMD -MF"
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
    C_FLAG_DEPS="-xMMD -xMF"
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xxlc; then
Packit Service 46fadf
    C_FLAG_DEPS="-qmakedep=gcc -MF"
Packit Service 46fadf
  fi
Packit Service 46fadf
  CXX_FLAG_DEPS="$C_FLAG_DEPS"
Packit Service 46fadf
  AC_SUBST(C_FLAG_DEPS)
Packit Service 46fadf
  AC_SUBST(CXX_FLAG_DEPS)
Packit Service 46fadf
Packit Service 46fadf
  # Debug symbols
Packit Service 46fadf
  #
Packit Service 46fadf
  # By default don't set any specific assembler debug
Packit Service 46fadf
  # info flags for toolchains unless we know they work.
Packit Service 46fadf
  # See JDK-8207057.
Packit Service 46fadf
  ASFLAGS_DEBUG_SYMBOLS=""
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_CPU_BITS" = "x64" && test "x$DEBUG_LEVEL" = "xfastdebug"; then
Packit Service 46fadf
      CFLAGS_DEBUG_SYMBOLS="-g1"
Packit Service 46fadf
      CXXFLAGS_DEBUG_SYMBOLS="-g1"
Packit Service 46fadf
    else
Packit Service 46fadf
      CFLAGS_DEBUG_SYMBOLS="-g"
Packit Service 46fadf
      CXXFLAGS_DEBUG_SYMBOLS="-g"
Packit Service 46fadf
    fi
Packit Service 46fadf
    ASFLAGS_DEBUG_SYMBOLS="-g"
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
    CFLAGS_DEBUG_SYMBOLS="-g -xs"
Packit Service 46fadf
    CXXFLAGS_DEBUG_SYMBOLS="-g0 -xs"
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xxlc; then
Packit Service 46fadf
    CFLAGS_DEBUG_SYMBOLS="-g"
Packit Service 46fadf
    CXXFLAGS_DEBUG_SYMBOLS="-g"
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(ASFLAGS_DEBUG_SYMBOLS)
Packit Service 46fadf
  AC_SUBST(CFLAGS_DEBUG_SYMBOLS)
Packit Service 46fadf
  AC_SUBST(CXXFLAGS_DEBUG_SYMBOLS)
Packit Service 46fadf
Packit Service 46fadf
  # Optimization levels
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
    CC_HIGHEST="$CC_HIGHEST -fns -fsimple -fsingle -xalias_level=basic -xbuiltin=%all -xdepend -xrestrict -xlibmil"
Packit Service 46fadf
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_CPU_ARCH" = "xx86"; then
Packit Service 46fadf
      # FIXME: seems we always set -xregs=no%frameptr; put it elsewhere more global?
Packit Service 46fadf
      C_O_FLAG_HIGHEST="-xO4 -Wu,-O4~yz $CC_HIGHEST -xregs=no%frameptr"
Packit Service 46fadf
      C_O_FLAG_HI="-xO4 -Wu,-O4~yz -xregs=no%frameptr"
Packit Service 46fadf
      C_O_FLAG_NORM="-xO2 -Wu,-O2~yz -xregs=no%frameptr"
Packit Service 46fadf
      C_O_FLAG_NONE="-xregs=no%frameptr"
Packit Service 46fadf
      CXX_O_FLAG_HIGHEST="-xO4 -Qoption ube -O4~yz $CC_HIGHEST -xregs=no%frameptr"
Packit Service 46fadf
      CXX_O_FLAG_HI="-xO4 -Qoption ube -O4~yz -xregs=no%frameptr"
Packit Service 46fadf
      CXX_O_FLAG_NORM="-xO2 -Qoption ube -O2~yz -xregs=no%frameptr"
Packit Service 46fadf
      CXX_O_FLAG_NONE="-xregs=no%frameptr"
Packit Service 46fadf
      if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then
Packit Service 46fadf
        C_O_FLAG_HIGHEST="$C_O_FLAG_HIGHEST -xchip=pentium"
Packit Service 46fadf
        CXX_O_FLAG_HIGHEST="$CXX_O_FLAG_HIGHEST -xchip=pentium"
Packit Service 46fadf
      fi
Packit Service 46fadf
    elif test "x$OPENJDK_TARGET_CPU_ARCH" = "xsparc"; then
Packit Service 46fadf
      C_O_FLAG_HIGHEST="-xO4 -Wc,-Qrm-s -Wc,-Qiselect-T0 $CC_HIGHEST -xprefetch=auto,explicit -xchip=ultra"
Packit Service 46fadf
      C_O_FLAG_HI="-xO4 -Wc,-Qrm-s -Wc,-Qiselect-T0"
Packit Service 46fadf
      C_O_FLAG_NORM="-xO2 -Wc,-Qrm-s -Wc,-Qiselect-T0"
Packit Service 46fadf
      C_O_FLAG_NONE=""
Packit Service 46fadf
      CXX_O_FLAG_HIGHEST="-xO4 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0 $CC_HIGHEST -xprefetch=auto,explicit -xchip=ultra"
Packit Service 46fadf
      CXX_O_FLAG_HI="-xO4 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0"
Packit Service 46fadf
      CXX_O_FLAG_NORM="-xO2 -Qoption cg -Qrm-s -Qoption cg -Qiselect-T0"
Packit Service 46fadf
      CXX_O_FLAG_NONE=""
Packit Service 46fadf
    fi
Packit Service 46fadf
  else
Packit Service 46fadf
    # The remaining toolchains share opt flags between CC and CXX;
Packit Service 46fadf
    # setup for C and duplicate afterwards.
Packit Service 46fadf
    if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
      if test "x$OPENJDK_TARGET_OS" = xmacosx; then
Packit Service 46fadf
        # On MacOSX we optimize for size, something
Packit Service 46fadf
        # we should do for all platforms?
Packit Service 46fadf
        C_O_FLAG_HIGHEST="-Os"
Packit Service 46fadf
        C_O_FLAG_HI="-Os"
Packit Service 46fadf
        C_O_FLAG_NORM="-Os"
Packit Service 46fadf
        C_O_FLAG_NONE=""
Packit Service 46fadf
      else
Packit Service 46fadf
        C_O_FLAG_HIGHEST="-O3"
Packit Service 46fadf
        C_O_FLAG_HI="-O3"
Packit Service 46fadf
        C_O_FLAG_NORM="-O2"
Packit Service 46fadf
        C_O_FLAG_NONE="-O0"
Packit Service 46fadf
      fi
Packit Service 46fadf
    elif test "x$TOOLCHAIN_TYPE" = xxlc; then
Packit Service 46fadf
      C_O_FLAG_HIGHEST="-O3"
Packit Service 46fadf
      C_O_FLAG_HI="-O3 -qstrict"
Packit Service 46fadf
      C_O_FLAG_NORM="-O2"
Packit Service 46fadf
      C_O_FLAG_NONE=""
Packit Service 46fadf
    elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
      C_O_FLAG_HIGHEST="-O2"
Packit Service 46fadf
      C_O_FLAG_HI="-O1"
Packit Service 46fadf
      C_O_FLAG_NORM="-O1"
Packit Service 46fadf
      C_O_FLAG_NONE="-Od"
Packit Service 46fadf
    fi
Packit Service 46fadf
    CXX_O_FLAG_HIGHEST="$C_O_FLAG_HIGHEST"
Packit Service 46fadf
    CXX_O_FLAG_HI="$C_O_FLAG_HI"
Packit Service 46fadf
    CXX_O_FLAG_NORM="$C_O_FLAG_NORM"
Packit Service 46fadf
    CXX_O_FLAG_NONE="$C_O_FLAG_NONE"
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  AC_SUBST(C_O_FLAG_HIGHEST)
Packit Service 46fadf
  AC_SUBST(C_O_FLAG_HI)
Packit Service 46fadf
  AC_SUBST(C_O_FLAG_NORM)
Packit Service 46fadf
  AC_SUBST(C_O_FLAG_NONE)
Packit Service 46fadf
  AC_SUBST(CXX_O_FLAG_HIGHEST)
Packit Service 46fadf
  AC_SUBST(CXX_O_FLAG_HI)
Packit Service 46fadf
  AC_SUBST(CXX_O_FLAG_NORM)
Packit Service 46fadf
  AC_SUBST(CXX_O_FLAG_NONE)
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
Packit Service 46fadf
[
Packit Service 46fadf
  # Special extras...
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_CPU_ARCH" = "xsparc"; then
Packit Service 46fadf
      CFLAGS_JDKLIB_EXTRA="${CFLAGS_JDKLIB_EXTRA} -xregs=no%appl"
Packit Service 46fadf
      CXXFLAGS_JDKLIB_EXTRA="${CXXFLAGS_JDKLIB_EXTRA} -xregs=no%appl"
Packit Service 46fadf
    fi
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xxlc; then
Packit Service 46fadf
    LDFLAGS_JDK="${LDFLAGS_JDK} -q64 -brtl -bnolibpath -liconv -bexpall"
Packit Service 46fadf
    CFLAGS_JDK="${CFLAGS_JDK} -qchars=signed -q64 -qfullpath -qsaveopt"
Packit Service 46fadf
    CXXFLAGS_JDK="${CXXFLAGS_JDK} -qchars=signed -q64 -qfullpath -qsaveopt"
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
    LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS -fstack-protector"
Packit Service 46fadf
    LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS -fstack-protector"
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_OS" != xmacosx; then
Packit Service 46fadf
      LDFLAGS_JDK="$LDFLAGS_JDK -Wl,-z,relro"
Packit Service 46fadf
      LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS -Wl,-z,relro"
Packit Service 46fadf
    fi
Packit Service 46fadf
    $2CXXSTD_CXXFLAG="-std=gnu++98"
Packit Service 46fadf
    FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]$2CXXSTD_CXXFLAG -Werror],
Packit Service 46fadf
                                       [], [$2CXXSTD_CXXFLAG=""])
Packit Service 46fadf
    $2CXXFLAGS_JDK="${$2CXXFLAGS_JDK} ${$2CXXSTD_CXXFLAG}"
Packit Service 46fadf
    $2JVM_CFLAGS="${$2JVM_CFLAGS} ${$2CXXSTD_CXXFLAG}"
Packit Service 46fadf
    AC_SUBST($2CXXSTD_CXXFLAG)
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service cb9467
  #
Packit Service cb9467
  # NOTE: check for -mstackrealign needs to be below potential addition of -m32
Packit Service cb9467
  #
Packit Service cb9467
  if test "x$OPENJDK_TARGET_CPU" = xx86 && test "x$OPENJDK_TARGET_OS" = xmacosx -o \
Packit Service cb9467
                                                "x$OPENJDK_TARGET_OS" = xlinux; then
Packit Service cb9467
    # On 32-bit MacOSX the OS requires C-entry points to be 16 byte aligned.
Packit Service cb9467
    # While waiting for a better solution, the current workaround is to use -mstackrealign
Packit Service cb9467
    # This is also required on Linux systems which use libraries compiled with SSE instructions
Packit Service cb9467
    REALIGN_CFLAG="-mstackrealign"
Packit Service cb9467
    FLAGS_COMPILER_CHECK_ARGUMENTS([$REALIGN_CFLAG -Werror], [],
Packit Service cb9467
      AC_MSG_ERROR([The selected compiler $CXX does not support -mstackrealign! Try to put another compiler in the path.])
Packit Service cb9467
    )
Packit Service 0cd700
    CFLAGS_JDK="${CFLAGS_JDK} ${REALIGN_CFLAG}"
Packit Service 0cd700
    CXXFLAGS_JDK="${CXXFLAGS_JDK} ${REALIGN_CFLAG}"
Packit Service cb9467
    AC_SUBST([REALIGN_CFLAG])
Packit Service cb9467
  fi
Packit Service cb9467
Packit Service 46fadf
  if test "x$CFLAGS" != "x${ADDED_CFLAGS}"; then
Packit Service 46fadf
    AC_MSG_WARN([Ignoring CFLAGS($CFLAGS) found in environment. Use --with-extra-cflags])
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  if test "x$CXXFLAGS" != "x${ADDED_CXXFLAGS}"; then
Packit Service 46fadf
    AC_MSG_WARN([Ignoring CXXFLAGS($CXXFLAGS) found in environment. Use --with-extra-cxxflags])
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  if test "x$LDFLAGS" != "x${ADDED_LDFLAGS}"; then
Packit Service 46fadf
    AC_MSG_WARN([Ignoring LDFLAGS($LDFLAGS) found in environment. Use --with-extra-ldflags])
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
Packit Service 46fadf
  if test "x$ASFLAGS" != "x"; then
Packit Service 46fadf
    AC_MSG_WARN([Ignoring ASFLAGS($ASFLAGS) found in environment. Use --with-extra-asflags])
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  AC_ARG_WITH(extra-cflags, [AS_HELP_STRING([--with-extra-cflags],
Packit Service 46fadf
      [extra flags to be used when compiling jdk c-files])])
Packit Service 46fadf
Packit Service 46fadf
  AC_ARG_WITH(extra-cxxflags, [AS_HELP_STRING([--with-extra-cxxflags],
Packit Service 46fadf
      [extra flags to be used when compiling jdk c++-files])])
Packit Service 46fadf
Packit Service 46fadf
  AC_ARG_WITH(extra-ldflags, [AS_HELP_STRING([--with-extra-ldflags],
Packit Service 46fadf
      [extra flags to be used when linking jdk])])
Packit Service 46fadf
Packit Service 46fadf
  AC_ARG_WITH(extra-asflags, [AS_HELP_STRING([--with-extra-asflags],
Packit Service 46fadf
      [extra flags to be passed to the assembler])])
Packit Service 46fadf
Packit Service 46fadf
  CFLAGS_JDK="${CFLAGS_JDK} $with_extra_cflags"
Packit Service 46fadf
  CXXFLAGS_JDK="${CXXFLAGS_JDK} $with_extra_cxxflags"
Packit Service 46fadf
  LDFLAGS_JDK="${LDFLAGS_JDK} $with_extra_ldflags"
Packit Service 46fadf
Packit Service 46fadf
  # Hotspot needs these set in their legacy form
Packit Service 46fadf
  LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS $with_extra_cflags"
Packit Service 46fadf
  LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS $with_extra_cxxflags"
Packit Service 46fadf
  LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS $with_extra_ldflags"
Packit Service 46fadf
  LEGACY_EXTRA_ASFLAGS="$with_extra_asflags"
Packit Service 46fadf
Packit Service 46fadf
  AC_SUBST(LEGACY_EXTRA_CFLAGS)
Packit Service 46fadf
  AC_SUBST(LEGACY_EXTRA_CXXFLAGS)
Packit Service 46fadf
  AC_SUBST(LEGACY_EXTRA_LDFLAGS)
Packit Service 46fadf
  AC_SUBST(LEGACY_EXTRA_ASFLAGS)
Packit Service 46fadf
Packit Service 46fadf
  ###############################################################################
Packit Service 46fadf
  #
Packit Service 46fadf
  # Now setup the CFLAGS and LDFLAGS for the JDK build.
Packit Service 46fadf
  # Later we will also have CFLAGS and LDFLAGS for the hotspot subrepo build.
Packit Service 46fadf
  #
Packit Service 46fadf
Packit Service 46fadf
  FDLIBM_CFLAGS=""
Packit Service 46fadf
  # Setup compiler/platform specific flags to CFLAGS_JDK,
Packit Service 46fadf
  # CXXFLAGS_JDK and CCXXFLAGS_JDK (common to C and CXX?)
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
    # these options are used for both C and C++ compiles
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK -Wall -Wno-parentheses -Wextra -Wno-unused -Wno-unused-parameter -Wformat=2 \
Packit Service 46fadf
        -pipe -fstack-protector -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE"
Packit Service 46fadf
    case $OPENJDK_TARGET_CPU_ARCH in
Packit Service 46fadf
      arm )
Packit Service 46fadf
        # on arm we don't prevent gcc to omit frame pointer but do prevent strict aliasing
Packit Service 46fadf
        CFLAGS_JDK="${CFLAGS_JDK} -fno-strict-aliasing"
Packit Service 46fadf
        ;;
Packit Service 46fadf
      ppc )
Packit Service 46fadf
        # on ppc we don't prevent gcc to omit frame pointer nor strict-aliasing
Packit Service 46fadf
        ;;
Packit Service 46fadf
      * )
Packit Service 46fadf
        CCXXFLAGS_JDK="$CCXXFLAGS_JDK -fno-omit-frame-pointer"
Packit Service 46fadf
        CFLAGS_JDK="${CFLAGS_JDK} -fno-strict-aliasing"
Packit Service 46fadf
        ;;
Packit Service 46fadf
    esac
Packit Service 46fadf
    TOOLCHAIN_CHECK_COMPILER_VERSION(6, FLAGS_SETUP_GCC6_COMPILER_FLAGS)
Packit Service 46fadf
Packit Service 46fadf
    # Check that the compiler supports -ffp-contract=off flag
Packit Service 46fadf
    # Set FDLIBM_CFLAGS to -ffp-contract=off if it does.
Packit Service 46fadf
    # For GCC < 4.6, on x86, x86_64 and ppc check for
Packit Service 46fadf
    # -mno-fused-madd and -fno-strict-aliasing. If they exist,
Packit Service 46fadf
    # use them as a substitute for -ffp-contract=off.
Packit Service 46fadf
    #
Packit Service 46fadf
    # These flags are required for GCC-based builds of
Packit Service 46fadf
    # fdlibm with optimization without losing precision.
Packit Service 46fadf
    # Notably, -ffp-contract=off needs to be added for GCC >= 4.6,
Packit Service 46fadf
    #          -mno-fused-madd -fno-strict-aliasing for GCC < 4.6
Packit Service 46fadf
    COMPILER_FP_CONTRACT_OFF_FLAG="-ffp-contract=off"
Packit Service 46fadf
    FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]COMPILER_FP_CONTRACT_OFF_FLAG -Werror],
Packit Service 46fadf
                                       [], [COMPILER_FP_CONTRACT_OFF_FLAG=""])
Packit Service 46fadf
    if test "x$COMPILER_FP_CONTRACT_OFF_FLAG" = x; then
Packit Service 46fadf
      if test "$OPENJDK_TARGET_CPU_ARCH" = "x86" ||
Packit Service 46fadf
         test "$OPENJDK_TARGET_CPU_ARCH" = "x86_64" ||
Packit Service 46fadf
         test "$OPENJDK_TARGET_CPU_ARCH" = "ppc"; then
Packit Service 46fadf
        M_NO_FUSED_ADD_FLAG="-mno-fused-madd"
Packit Service 46fadf
        FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]M_NO_FUSED_ADD_FLAG -Werror],
Packit Service 46fadf
                                           [], [M_NO_FUSED_ADD_FLAG=""])
Packit Service 46fadf
        NO_STRICT_ALIASING_FLAG="-fno-strict-aliasing"
Packit Service 46fadf
        FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([[$]NO_STRICT_ALIASING_FLAG -Werror],
Packit Service 46fadf
                                           [], [NO_STRICT_ALIASING_FLAG=""])
Packit Service 46fadf
        if test "x$M_NO_FUSED_ADD_FLAG" != "x" && test "x$NO_STRICT_ALIASING_FLAG" != "x"; then
Packit Service 46fadf
          FDLIBM_CFLAGS="$M_NO_FUSED_ADD_FLAG $NO_STRICT_ALIASING_FLAG"
Packit Service 46fadf
        fi
Packit Service 46fadf
      fi
Packit Service 46fadf
    else
Packit Service 46fadf
      FDLIBM_CFLAGS="$COMPILER_FP_CONTRACT_OFF_FLAG"
Packit Service 46fadf
    fi
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK -DTRACING -DMACRO_MEMSYS_OPS -DBREAKPTS"
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_CPU_ARCH" = xx86; then
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DcpuIntel -Di586 -D$OPENJDK_TARGET_CPU_LEGACY_LIB"
Packit Service 46fadf
      CFLAGS_JDK="$CFLAGS_JDK -erroff=E_BAD_PRAGMA_PACK_VALUE"
Packit Service 46fadf
    fi
Packit Service 46fadf
  
Packit Service 46fadf
    CFLAGS_JDK="$CFLAGS_JDK -xc99=%none -xCC -errshort=tags -Xa -v -mt -W0,-noglobal"
Packit Service 46fadf
    CXXFLAGS_JDK="$CXXFLAGS_JDK -errtags=yes +w -mt -features=no%except -DCC_NOEX -norunpath -xnolib"
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xxlc; then
Packit Service 46fadf
    CFLAGS_JDK="$CFLAGS_JDK -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE -DSTDC"
Packit Service 46fadf
    CXXFLAGS_JDK="$CXXFLAGS_JDK -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE -DSTDC"
Packit Service 46fadf
  elif test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS $CCXXFLAGS_JDK \
Packit Service 46fadf
        -Zi -MD -Zc:wchar_t- -W3 -wd4800 \
Packit Service 46fadf
        -DWIN32_LEAN_AND_MEAN \
Packit Service 46fadf
        -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE \
Packit Service 46fadf
        -DWIN32 -DIAL"
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_CPU" = xx86_64; then
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_AMD64_ -Damd64"
Packit Service 46fadf
    else
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_X86_ -Dx86"
Packit Service 46fadf
    fi
Packit Service 46fadf
    # If building with Visual Studio 2010, we can still use _STATIC_CPPLIB to
Packit Service 46fadf
    # avoid bundling msvcpNNN.dll. Doesn't work with newer versions of visual
Packit Service 46fadf
    # studio.
Packit Service 46fadf
    if test "x$TOOLCHAIN_VERSION" = "x2010"; then
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK \
Packit Service 46fadf
          -D_STATIC_CPPLIB -D_DISABLE_DEPRECATE_STATIC_CPPLIB"
Packit Service 46fadf
    fi
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(FDLIBM_CFLAGS)
Packit Service 46fadf
Packit Service 46fadf
  ###############################################################################
Packit Service 46fadf
Packit Service 46fadf
  # Adjust flags according to debug level.
Packit Service 46fadf
  case $DEBUG_LEVEL in
Packit Service 46fadf
    fastdebug )
Packit Service 46fadf
      CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
Packit Service 46fadf
      CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
Packit Service 46fadf
      C_O_FLAG_HI="$C_O_FLAG_NORM"
Packit Service 46fadf
      C_O_FLAG_NORM="$C_O_FLAG_NORM"
Packit Service 46fadf
      CXX_O_FLAG_HI="$CXX_O_FLAG_NORM"
Packit Service 46fadf
      CXX_O_FLAG_NORM="$CXX_O_FLAG_NORM"
Packit Service 46fadf
      JAVAC_FLAGS="$JAVAC_FLAGS -g"
Packit Service 46fadf
      ;;
Packit Service 46fadf
    slowdebug )
Packit Service 46fadf
      CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
Packit Service 46fadf
      CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
Packit Service 46fadf
      C_O_FLAG_HI="$C_O_FLAG_NONE"
Packit Service 46fadf
      C_O_FLAG_NORM="$C_O_FLAG_NONE"
Packit Service 46fadf
      CXX_O_FLAG_HI="$CXX_O_FLAG_NONE"
Packit Service 46fadf
      CXX_O_FLAG_NORM="$CXX_O_FLAG_NONE"
Packit Service 46fadf
      JAVAC_FLAGS="$JAVAC_FLAGS -g"
Packit Service 46fadf
      ;;
Packit Service 46fadf
  esac
Packit Service 46fadf
Packit Service 46fadf
  # Setup LP64
Packit Service 46fadf
  CCXXFLAGS_JDK="$CCXXFLAGS_JDK $ADD_LP64"
Packit Service 46fadf
Packit Service 46fadf
  # Set some common defines. These works for all compilers, but assume
Packit Service 46fadf
  # -D is universally accepted.
Packit Service 46fadf
Packit Service 46fadf
  # Setup endianness
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_CPU_ENDIAN" = xlittle; then
Packit Service 46fadf
    # The macro _LITTLE_ENDIAN needs to be defined the same to avoid the
Packit Service 46fadf
    #   Sun C compiler warning message: warning: macro redefined: _LITTLE_ENDIAN
Packit Service 46fadf
    #   (The Solaris X86 system defines this in file /usr/include/sys/isa_defs.h).
Packit Service 46fadf
    #   Note: -Dmacro         is the same as    #define macro 1
Packit Service 46fadf
    #         -Dmacro=        is the same as    #define macro
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_OS" = xsolaris; then
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN="
Packit Service 46fadf
    else
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN"
Packit Service 46fadf
    fi
Packit Service 46fadf
  else
Packit Service 46fadf
    # Same goes for _BIG_ENDIAN. Do we really need to set *ENDIAN on Solaris if they
Packit Service 46fadf
    # are defined in the system?
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_OS" = xsolaris; then
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN="
Packit Service 46fadf
    else
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN"
Packit Service 46fadf
    fi
Packit Service 46fadf
  fi
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_CPU" = xppc64le; then
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DABI_ELFv2"
Packit Service 46fadf
  fi
Packit Service 46fadf
  
Packit Service 46fadf
  # Setup target OS define. Use OS target name but in upper case.
Packit Service 46fadf
  OPENJDK_TARGET_OS_UPPERCASE=`$ECHO $OPENJDK_TARGET_OS | $TR 'abcdefghijklmnopqrstuvwxyz' 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'`
Packit Service 46fadf
  CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D$OPENJDK_TARGET_OS_UPPERCASE"
Packit Service 46fadf
Packit Service 46fadf
  # Setup target CPU
Packit Service 46fadf
  CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DARCH='\"$OPENJDK_TARGET_CPU_LEGACY\"' -D$OPENJDK_TARGET_CPU_LEGACY"
Packit Service 46fadf
  
Packit Service 46fadf
  # Setup debug/release defines
Packit Service 46fadf
  if test "x$DEBUG_LEVEL" = xrelease; then
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DNDEBUG"
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_OS" = xsolaris; then
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DTRIMMED"
Packit Service 46fadf
    fi
Packit Service 46fadf
  else
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DDEBUG"
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  # Setup release name
Packit Service 46fadf
  CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DRELEASE='\"\$(RELEASE)\"'"
Packit Service 46fadf
Packit Service 46fadf
Packit Service 46fadf
  # Set some additional per-OS defines.
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_OS" = xmacosx; then
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_ALLBSD_SOURCE -D_DARWIN_UNLIMITED_SELECT"
Packit Service 46fadf
  elif test "x$OPENJDK_TARGET_OS" = xaix; then
Packit Service 46fadf
    # FIXME: PPC64 should not be here.
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DPPC64"
Packit Service 46fadf
  elif test "x$OPENJDK_TARGET_OS" = xbsd; then
Packit Service 46fadf
    CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_ALLBSD_SOURCE"
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  # Additional macosx handling
Packit Service 46fadf
  if test "x$OPENJDK_TARGET_OS" = xmacosx; then
Packit Service 46fadf
    if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
      # FIXME: This needs to be exported in spec.gmk due to closed legacy code.
Packit Service 46fadf
      # FIXME: clean this up, and/or move it elsewhere.
Packit Service 46fadf
Packit Service 46fadf
      # Setting these parameters makes it an error to link to macosx APIs that are
Packit Service 46fadf
      # newer than the given OS version and makes the linked binaries compatible 
Packit Service 46fadf
      # even if built on a newer version of the OS.
Packit Service 46fadf
      # The expected format is X.Y.Z
Packit Service 46fadf
      MACOSX_VERSION_MIN=10.7.0
Packit Service 46fadf
      AC_SUBST(MACOSX_VERSION_MIN)
Packit Service 46fadf
    
Packit Service 46fadf
      # The macro takes the version with no dots, ex: 1070
Packit Service 46fadf
      # Let the flags variables get resolved in make for easier override on make
Packit Service 46fadf
      # command line.
Packit Service 46fadf
      CCXXFLAGS_JDK="$CCXXFLAGS_JDK -DMAC_OS_X_VERSION_MAX_ALLOWED=\$(subst .,,\$(MACOSX_VERSION_MIN)) -mmacosx-version-min=\$(MACOSX_VERSION_MIN)"
Packit Service 46fadf
      LDFLAGS_JDK="$LDFLAGS_JDK -mmacosx-version-min=\$(MACOSX_VERSION_MIN)"
Packit Service 46fadf
    fi
Packit Service 46fadf
  fi
Packit Service 46fadf
Packit Service 46fadf
  # Setup some hard coded includes
Packit Service 46fadf
  CCXXFLAGS_JDK="$CCXXFLAGS_JDK \
Packit Service 46fadf
      -I${JDK_OUTPUTDIR}/include \
Packit Service 46fadf
      -I${JDK_OUTPUTDIR}/include/$OPENJDK_TARGET_OS \
Packit Service 46fadf
      -I${JDK_TOPDIR}/src/share/javavm/export \
Packit Service 46fadf
      -I${JDK_TOPDIR}/src/$OPENJDK_TARGET_OS_EXPORT_DIR/javavm/export \
Packit Service 46fadf
      -I${JDK_TOPDIR}/src/share/native/common \
Packit Service 46fadf
      -I${JDK_TOPDIR}/src/$OPENJDK_TARGET_OS_API_DIR/native/common"
Packit Service 46fadf
Packit Service 46fadf
  # The shared libraries are compiled using the picflag.
Packit Service 46fadf
  CFLAGS_JDKLIB="$CCXXFLAGS_JDK $CFLAGS_JDK $PICFLAG $CFLAGS_JDKLIB_EXTRA"
Packit Service 46fadf
  CXXFLAGS_JDKLIB="$CCXXFLAGS_JDK $CXXFLAGS_JDK $PICFLAG $CXXFLAGS_JDKLIB_EXTRA "
Packit Service 46fadf
Packit Service 46fadf
  # Executable flags
Packit Service 46fadf
  CFLAGS_JDKEXE="$CCXXFLAGS_JDK $CFLAGS_JDK $PIEFLAG"
Packit Service 46fadf
  CXXFLAGS_JDKEXE="$CCXXFLAGS_JDK $CXXFLAGS_JDK $PIEFLAG"
Packit Service 46fadf
Packit Service 46fadf
  AC_SUBST(CFLAGS_JDKLIB)
Packit Service 46fadf
  AC_SUBST(CFLAGS_JDKEXE)
Packit Service 46fadf
  AC_SUBST(CXXFLAGS_JDKLIB)
Packit Service 46fadf
  AC_SUBST(CXXFLAGS_JDKEXE)
Packit Service 46fadf
Packit Service 46fadf
  # Setup LDFLAGS et al.
Packit Service 46fadf
  #
Packit Service 46fadf
  # Now this is odd. The JDK native libraries have to link against libjvm.so
Packit Service 46fadf
  # On 32-bit machines there is normally two distinct libjvm.so:s, client and server.
Packit Service 46fadf
  # Which should we link to? Are we lucky enough that the binary api to the libjvm.so library
Packit Service 46fadf
  # is identical for client and server? Yes. Which is picked at runtime (client or server)?
Packit Service 46fadf
  # Neither, since the chosen libjvm.so has already been loaded by the launcher, all the following
Packit Service 46fadf
  # libraries will link to whatever is in memory. Yuck.
Packit Service 46fadf
  #
Packit Service 46fadf
  # Thus we offer the compiler to find libjvm.so first in server then in client. It works. Ugh.
Packit Service 46fadf
  if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then
Packit Service 46fadf
    LDFLAGS_JDK="$LDFLAGS_JDK -nologo -opt:ref -incremental:no"
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_CPU_BITS" = "x32"; then
Packit Service 46fadf
      LDFLAGS_JDK="$LDFLAGS_JDK -safeseh"
Packit Service 46fadf
    fi
Packit Service 46fadf
    # TODO: make -debug optional "--disable-full-debug-symbols"
Packit Service 46fadf
    LDFLAGS_JDK="$LDFLAGS_JDK -debug"
Packit Service 46fadf
    LDFLAGS_JDKLIB="${LDFLAGS_JDK} -dll -libpath:${JDK_OUTPUTDIR}/lib"
Packit Service 46fadf
    LDFLAGS_JDKLIB_SUFFIX=""
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_CPU_BITS" = "x64"; then
Packit Service 46fadf
      LDFLAGS_STACK_SIZE=1048576
Packit Service 46fadf
    else
Packit Service 46fadf
      LDFLAGS_STACK_SIZE=327680
Packit Service 46fadf
    fi
Packit Service 46fadf
    LDFLAGS_JDKEXE="${LDFLAGS_JDK} /STACK:$LDFLAGS_STACK_SIZE"
Packit Service 46fadf
  else
Packit Service 46fadf
    if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
      # If this is a --hash-style=gnu system, use --hash-style=both, why?
Packit Service 46fadf
      # We have previously set HAS_GNU_HASH if this is the case
Packit Service 46fadf
      if test -n "$HAS_GNU_HASH"; then
Packit Service 46fadf
        LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker --hash-style=both "
Packit Service 46fadf
      fi
Packit Service 46fadf
      if test "x$OPENJDK_TARGET_OS" = xlinux; then
Packit Service 46fadf
        # And since we now know that the linker is gnu, then add:
Packit Service 46fadf
        #   -z defs, to forbid undefined symbols in object files
Packit Service 46fadf
        #   -z noexecstack, to mark stack regions as non-executable
Packit Service 46fadf
        LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker -z -Xlinker defs -Xlinker -z -Xlinker noexecstack"
Packit Service 46fadf
        if test "x$DEBUG_LEVEL" = "xrelease"; then
Packit Service 46fadf
          # When building release libraries, tell the linker optimize them.
Packit Service 46fadf
          # Should this be supplied to the OSS linker as well?
Packit Service 46fadf
          LDFLAGS_JDK="${LDFLAGS_JDK} -Xlinker -O1"
Packit Service 46fadf
        fi
Packit Service 46fadf
      fi
Packit Service 46fadf
    fi
Packit Service 46fadf
Packit Service 46fadf
    if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
      LDFLAGS_JDK="$LDFLAGS_JDK -z defs -xildoff -ztext"
Packit Service 46fadf
      LDFLAGS_CXX_JDK="$LDFLAGS_CXX_JDK -norunpath -xnolib"
Packit Service 46fadf
    fi
Packit Service 46fadf
Packit Service 46fadf
    LDFLAGS_JDKLIB="${LDFLAGS_JDK} $SHARED_LIBRARY_FLAGS \
Packit Service 46fadf
        -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}"
Packit Service 46fadf
Packit Service 46fadf
    # On some platforms (mac) the linker warns about non existing -L dirs.
Packit Service 46fadf
    # Add server first if available. Linking aginst client does not always produce the same results.
Packit Service 46fadf
    # Only add client dir if client is being built. Add minimal (note not minimal1) if only building minimal1.
Packit Service 46fadf
    # Default to server for other variants.
Packit Service 46fadf
    if test "x$JVM_VARIANT_SERVER" = xtrue; then
Packit Service 46fadf
      LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/server"
Packit Service 46fadf
    elif test "x$JVM_VARIANT_CLIENT" = xtrue; then
Packit Service 46fadf
      LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/client"
Packit Service 46fadf
    elif test "x$JVM_VARIANT_MINIMAL1" = xtrue; then
Packit Service 46fadf
      LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/minimal"
Packit Service 46fadf
    else
Packit Service 46fadf
      LDFLAGS_JDKLIB="${LDFLAGS_JDKLIB} -L${JDK_OUTPUTDIR}/lib${OPENJDK_TARGET_CPU_LIBDIR}/server"
Packit Service 46fadf
    fi
Packit Service 46fadf
Packit Service 46fadf
    LDFLAGS_JDKLIB_SUFFIX="-ljava -ljvm"
Packit Service 46fadf
    if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
Packit Service 46fadf
      LDFLAGS_JDKLIB_SUFFIX="$LDFLAGS_JDKLIB_SUFFIX -lc"
Packit Service 46fadf
    fi
Packit Service 46fadf
Packit Service 46fadf
    LDFLAGS_JDKEXE="${LDFLAGS_JDK}"
Packit Service 46fadf
    if test "x$OPENJDK_TARGET_OS" = xlinux; then
Packit Service 46fadf
      LDFLAGS_JDKEXE="$LDFLAGS_JDKEXE -Xlinker --allow-shlib-undefined"
Packit Service 46fadf
    fi
Packit Service 46fadf
    if test "x$TOOLCHAIN_TYPE" = xgcc; then
Packit Service 46fadf
      # Enabling pie on 32 bit builds prevents the JVM from allocating a continuous
Packit Service 46fadf
      # java heap.
Packit Service 46fadf
      if test "x$OPENJDK_TARGET_CPU_BITS" != "x32"; then
Packit Service 46fadf
        LDFLAGS_JDKEXE="$LDFLAGS_JDKEXE -pie"
Packit Service 46fadf
      fi
Packit Service 46fadf
    fi
Packit Service 46fadf
  fi
Packit Service 46fadf
  AC_SUBST(LDFLAGS_JDKLIB)
Packit Service 46fadf
  AC_SUBST(LDFLAGS_JDKEXE)
Packit Service 46fadf
  AC_SUBST(LDFLAGS_JDKLIB_SUFFIX)
Packit Service 46fadf
  AC_SUBST(LDFLAGS_JDKEXE_SUFFIX)
Packit Service 46fadf
  AC_SUBST(LDFLAGS_CXX_JDK)
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
Packit Service 46fadf
# FLAGS_C_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
Packit Service 46fadf
#                                  [RUN-IF-FALSE])
Packit Service 46fadf
# ------------------------------------------------------------
Packit Service 46fadf
# Check that the C compiler supports an argument
Packit Service 46fadf
AC_DEFUN([FLAGS_C_COMPILER_CHECK_ARGUMENTS],
Packit Service 46fadf
[
Packit Service 46fadf
  AC_MSG_CHECKING([if the C compiler supports "$1"])
Packit Service 46fadf
  supports=yes
Packit Service 46fadf
Packit Service 46fadf
  saved_cflags="$CFLAGS"
Packit Service 46fadf
  CFLAGS="$CFLAGS $1"
Packit Service 46fadf
  AC_LANG_PUSH([C])
Packit Service 46fadf
  AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [], 
Packit Service 46fadf
      [supports=no])
Packit Service 46fadf
  AC_LANG_POP([C])
Packit Service 46fadf
  CFLAGS="$saved_cflags"
Packit Service 46fadf
Packit Service 46fadf
  AC_MSG_RESULT([$supports])
Packit Service 46fadf
  if test "x$supports" = "xyes" ; then
Packit Service 46fadf
    m4_ifval([$2], [$2], [:])
Packit Service 46fadf
  else
Packit Service 46fadf
    m4_ifval([$3], [$3], [:])
Packit Service 46fadf
  fi
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
# FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
Packit Service 46fadf
#                                    [RUN-IF-FALSE])
Packit Service 46fadf
# ------------------------------------------------------------
Packit Service 46fadf
# Check that the C++ compiler supports an argument
Packit Service 46fadf
AC_DEFUN([FLAGS_CXX_COMPILER_CHECK_ARGUMENTS],
Packit Service 46fadf
[
Packit Service 46fadf
  AC_MSG_CHECKING([if the C++ compiler supports "$1"])
Packit Service 46fadf
  supports=yes
Packit Service 46fadf
Packit Service 46fadf
  saved_cxxflags="$CXXFLAGS"
Packit Service 46fadf
  CXXFLAGS="$CXXFLAG $1"
Packit Service 46fadf
  AC_LANG_PUSH([C++])
Packit Service 46fadf
  AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [], 
Packit Service 46fadf
      [supports=no])
Packit Service 46fadf
  AC_LANG_POP([C++])
Packit Service 46fadf
  CXXFLAGS="$saved_cxxflags"
Packit Service 46fadf
  
Packit Service 46fadf
  AC_MSG_RESULT([$supports])
Packit Service 46fadf
  if test "x$supports" = "xyes" ; then
Packit Service 46fadf
    m4_ifval([$2], [$2], [:])
Packit Service 46fadf
  else
Packit Service 46fadf
    m4_ifval([$3], [$3], [:])
Packit Service 46fadf
  fi
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
# FLAGS_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
Packit Service 46fadf
#                                [RUN-IF-FALSE])
Packit Service 46fadf
# ------------------------------------------------------------
Packit Service 46fadf
# Check that the C and C++ compilers support an argument
Packit Service 46fadf
AC_DEFUN([FLAGS_COMPILER_CHECK_ARGUMENTS],
Packit Service 46fadf
[
Packit Service 46fadf
  FLAGS_C_COMPILER_CHECK_ARGUMENTS([$1],
Packit Service 46fadf
                       [C_COMP_SUPPORTS="yes"],
Packit Service 46fadf
                       [C_COMP_SUPPORTS="no"])
Packit Service 46fadf
  FLAGS_CXX_COMPILER_CHECK_ARGUMENTS([$1],
Packit Service 46fadf
                     [CXX_COMP_SUPPORTS="yes"],
Packit Service 46fadf
                     [CXX_COMP_SUPPORTS="no"])
Packit Service 46fadf
Packit Service 46fadf
  AC_MSG_CHECKING([if both compilers support "$1"])
Packit Service 46fadf
  supports=no
Packit Service 46fadf
  if test "x$C_COMP_SUPPORTS" = "xyes" -a "x$CXX_COMP_SUPPORTS" = "xyes"; then supports=yes; fi
Packit Service 46fadf
  
Packit Service 46fadf
  AC_MSG_RESULT([$supports])
Packit Service 46fadf
  if test "x$supports" = "xyes" ; then
Packit Service 46fadf
    m4_ifval([$2], [$2], [:])
Packit Service 46fadf
  else
Packit Service 46fadf
    m4_ifval([$3], [$3], [:])
Packit Service 46fadf
  fi
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
Packit Service 46fadf
[
Packit Service 46fadf
  # Some Zero and Shark settings.
Packit Service 46fadf
  # ZERO_ARCHFLAG tells the compiler which mode to build for
Packit Service 46fadf
  case "${OPENJDK_TARGET_CPU}" in
Packit Service 46fadf
    s390)
Packit Service 46fadf
      ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}31"
Packit Service 46fadf
      ;;
Packit Service 46fadf
    *)
Packit Service 46fadf
      ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}"
Packit Service 46fadf
  esac
Packit Service 46fadf
  FLAGS_COMPILER_CHECK_ARGUMENTS([$ZERO_ARCHFLAG], [], [ZERO_ARCHFLAG=""])
Packit Service 46fadf
  AC_SUBST(ZERO_ARCHFLAG)
Packit Service 46fadf
Packit Service 46fadf
  # Check that the compiler supports -mX (or -qX on AIX) flags
Packit Service 46fadf
  # Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does
Packit Service 46fadf
  FLAGS_COMPILER_CHECK_ARGUMENTS([${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}],
Packit Service 46fadf
      [COMPILER_SUPPORTS_TARGET_BITS_FLAG=true],
Packit Service 46fadf
      [COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
Packit Service 46fadf
  AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
Packit Service 46fadf
])
Packit Service 46fadf
Packit Service 46fadf
AC_DEFUN_ONCE([FLAGS_SETUP_GCC6_COMPILER_FLAGS],
Packit Service 46fadf
[
Packit Service 46fadf
  # These flags are required for GCC 6 builds as undefined behaviour in OpenJDK code
Packit Service 46fadf
  # runs afoul of the more aggressive versions of these optimisations.
Packit Service 46fadf
  # Notably, value range propagation now assumes that the this pointer of C++
Packit Service 46fadf
  # member functions is non-null.
Packit Service 46fadf
  NO_DELETE_NULL_POINTER_CHECKS_CFLAG="-fno-delete-null-pointer-checks"
Packit Service 46fadf
  FLAGS_COMPILER_CHECK_ARGUMENTS([$NO_DELETE_NULL_POINTER_CHECKS_CFLAG -Werror],
Packit Service 46fadf
                                     [], [NO_DELETE_NULL_POINTER_CHECKS_CFLAG=""])
Packit Service 46fadf
  AC_SUBST([NO_DELETE_NULL_POINTER_CHECKS_CFLAG])
Packit Service 46fadf
  NO_LIFETIME_DSE_CFLAG="-fno-lifetime-dse"
Packit Service 46fadf
  FLAGS_COMPILER_CHECK_ARGUMENTS([$NO_LIFETIME_DSE_CFLAG -Werror],
Packit Service 46fadf
                                     [], [NO_LIFETIME_DSE_CFLAG=""])
Packit Service 46fadf
  CFLAGS_JDK="${CFLAGS_JDK} ${NO_DELETE_NULL_POINTER_CHECKS_CFLAG} ${NO_LIFETIME_DSE_CFLAG}"
Packit Service 46fadf
  AC_SUBST([NO_LIFETIME_DSE_CFLAG])
Packit Service 46fadf
])
Packit Service 46fadf