common/autoconf/jdk-options.m4

Tue, 20 Jan 2015 13:29:10 -0800

author
ddehaven
date
Tue, 20 Jan 2015 13:29:10 -0800
changeset 1304
c27cb0ab944f
parent 1202
c3bb27bf9f60
child 1305
ff4a622a5cc4
permissions
-rw-r--r--

8043340: [macosx] Fix hard-wired paths to JavaVM.framework
Summary: Build system tweaks to allow building on OS X 10.9 and later
Reviewed-by: erikj

erikj@459 1 #
erikj@562 2 # Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
erikj@459 3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
erikj@459 4 #
erikj@459 5 # This code is free software; you can redistribute it and/or modify it
erikj@459 6 # under the terms of the GNU General Public License version 2 only, as
erikj@459 7 # published by the Free Software Foundation. Oracle designates this
erikj@459 8 # particular file as subject to the "Classpath" exception as provided
erikj@459 9 # by Oracle in the LICENSE file that accompanied this code.
erikj@459 10 #
erikj@459 11 # This code is distributed in the hope that it will be useful, but WITHOUT
erikj@459 12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
erikj@459 13 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
erikj@459 14 # version 2 for more details (a copy is included in the LICENSE file that
erikj@459 15 # accompanied this code).
erikj@459 16 #
erikj@459 17 # You should have received a copy of the GNU General Public License version
erikj@459 18 # 2 along with this work; if not, write to the Free Software Foundation,
erikj@459 19 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
erikj@459 20 #
erikj@459 21 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
erikj@459 22 # or visit www.oracle.com if you need additional information or have any
erikj@459 23 # questions.
erikj@459 24 #
erikj@459 25
erikj@459 26 AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_VARIANT],
erikj@459 27 [
ihse@839 28 ###############################################################################
ihse@839 29 #
ihse@839 30 # Check which variant of the JDK that we want to build.
ihse@839 31 # Currently we have:
ihse@839 32 # normal: standard edition
ihse@839 33 # but the custom make system may add other variants
ihse@839 34 #
ihse@839 35 # Effectively the JDK variant gives a name to a specific set of
ihse@839 36 # modules to compile into the JDK. In the future, these modules
ihse@839 37 # might even be Jigsaw modules.
ihse@839 38 #
ihse@839 39 AC_MSG_CHECKING([which variant of the JDK to build])
ihse@839 40 AC_ARG_WITH([jdk-variant], [AS_HELP_STRING([--with-jdk-variant],
ihse@839 41 [JDK variant to build (normal) @<:@normal@:>@])])
erikj@459 42
ihse@839 43 if test "x$with_jdk_variant" = xnormal || test "x$with_jdk_variant" = x; then
erikj@459 44 JDK_VARIANT="normal"
ihse@839 45 else
ohair@478 46 AC_MSG_ERROR([The available JDK variants are: normal])
ihse@839 47 fi
ohair@478 48
ihse@839 49 AC_SUBST(JDK_VARIANT)
erikj@459 50
ihse@839 51 AC_MSG_RESULT([$JDK_VARIANT])
erikj@459 52 ])
erikj@459 53
simonis@965 54 AC_DEFUN_ONCE([JDKOPT_SETUP_JVM_INTERPRETER],
simonis@965 55 [
simonis@965 56 ###############################################################################
simonis@965 57 #
simonis@965 58 # Check which interpreter of the JVM we want to build.
simonis@965 59 # Currently we have:
simonis@965 60 # template: Template interpreter (the default)
simonis@965 61 # cpp : C++ interpreter
simonis@965 62 AC_MSG_CHECKING([which interpreter of the JVM to build])
simonis@965 63 AC_ARG_WITH([jvm-interpreter], [AS_HELP_STRING([--with-jvm-interpreter],
simonis@965 64 [JVM interpreter to build (template, cpp) @<:@template@:>@])])
simonis@965 65
simonis@965 66 if test "x$with_jvm_interpreter" = x; then
simonis@965 67 with_jvm_interpreter="template"
simonis@965 68 fi
simonis@965 69
simonis@965 70 JVM_INTERPRETER="$with_jvm_interpreter"
simonis@965 71
simonis@965 72 if test "x$JVM_INTERPRETER" != xtemplate && test "x$JVM_INTERPRETER" != xcpp; then
simonis@965 73 AC_MSG_ERROR([The available JVM interpreters are: template, cpp])
simonis@965 74 fi
simonis@965 75
simonis@965 76 AC_SUBST(JVM_INTERPRETER)
simonis@965 77
simonis@965 78 AC_MSG_RESULT([$with_jvm_interpreter])
simonis@965 79 ])
simonis@965 80
erikj@459 81 AC_DEFUN_ONCE([JDKOPT_SETUP_JVM_VARIANTS],
erikj@459 82 [
erikj@459 83
ihse@839 84 ###############################################################################
ihse@839 85 #
ihse@839 86 # Check which variants of the JVM that we want to build.
ihse@839 87 # Currently we have:
ihse@839 88 # server: normal interpreter and a tiered C1/C2 compiler
ihse@839 89 # client: normal interpreter and C1 (no C2 compiler) (only 32-bit platforms)
ihse@839 90 # minimal1: reduced form of client with optional VM services and features stripped out
ihse@839 91 # kernel: kernel footprint JVM that passes the TCK without major performance problems,
ihse@839 92 # ie normal interpreter and C1, only the serial GC, kernel jvmti etc
ihse@839 93 # zero: no machine code interpreter, no compiler
ihse@839 94 # zeroshark: zero interpreter and shark/llvm compiler backend
simonis@965 95 # core: interpreter only, no compiler (only works on some platforms)
ihse@839 96 AC_MSG_CHECKING([which variants of the JVM to build])
ihse@839 97 AC_ARG_WITH([jvm-variants], [AS_HELP_STRING([--with-jvm-variants],
simonis@965 98 [JVM variants (separated by commas) to build (server, client, minimal1, kernel, zero, zeroshark, core) @<:@server@:>@])])
erikj@459 99
ihse@839 100 if test "x$with_jvm_variants" = x; then
ihse@839 101 with_jvm_variants="server"
ihse@839 102 fi
erikj@459 103
ihse@839 104 JVM_VARIANTS=",$with_jvm_variants,"
kvn@972 105 TEST_VARIANTS=`$ECHO "$JVM_VARIANTS" | $SED -e 's/server,//' -e 's/client,//' -e 's/minimal1,//' -e 's/kernel,//' -e 's/zero,//' -e 's/zeroshark,//' -e 's/core,//'`
erikj@459 106
ihse@839 107 if test "x$TEST_VARIANTS" != "x,"; then
kvn@972 108 AC_MSG_ERROR([The available JVM variants are: server, client, minimal1, kernel, zero, zeroshark, core])
ihse@839 109 fi
ihse@839 110 AC_MSG_RESULT([$with_jvm_variants])
erikj@459 111
ihse@839 112 JVM_VARIANT_SERVER=`$ECHO "$JVM_VARIANTS" | $SED -e '/,server,/!s/.*/false/g' -e '/,server,/s/.*/true/g'`
ihse@839 113 JVM_VARIANT_CLIENT=`$ECHO "$JVM_VARIANTS" | $SED -e '/,client,/!s/.*/false/g' -e '/,client,/s/.*/true/g'`
ihse@839 114 JVM_VARIANT_MINIMAL1=`$ECHO "$JVM_VARIANTS" | $SED -e '/,minimal1,/!s/.*/false/g' -e '/,minimal1,/s/.*/true/g'`
ihse@839 115 JVM_VARIANT_KERNEL=`$ECHO "$JVM_VARIANTS" | $SED -e '/,kernel,/!s/.*/false/g' -e '/,kernel,/s/.*/true/g'`
ihse@839 116 JVM_VARIANT_ZERO=`$ECHO "$JVM_VARIANTS" | $SED -e '/,zero,/!s/.*/false/g' -e '/,zero,/s/.*/true/g'`
ihse@839 117 JVM_VARIANT_ZEROSHARK=`$ECHO "$JVM_VARIANTS" | $SED -e '/,zeroshark,/!s/.*/false/g' -e '/,zeroshark,/s/.*/true/g'`
kvn@972 118 JVM_VARIANT_CORE=`$ECHO "$JVM_VARIANTS" | $SED -e '/,core,/!s/.*/false/g' -e '/,core,/s/.*/true/g'`
erikj@459 119
ihse@839 120 if test "x$JVM_VARIANT_CLIENT" = xtrue; then
erikj@459 121 if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
ihse@839 122 AC_MSG_ERROR([You cannot build a client JVM for a 64-bit machine.])
erikj@459 123 fi
ihse@839 124 fi
ihse@839 125 if test "x$JVM_VARIANT_KERNEL" = xtrue; then
erikj@459 126 if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
ihse@839 127 AC_MSG_ERROR([You cannot build a kernel JVM for a 64-bit machine.])
erikj@459 128 fi
ihse@839 129 fi
ihse@839 130 if test "x$JVM_VARIANT_MINIMAL1" = xtrue; then
dholmes@542 131 if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
ihse@839 132 AC_MSG_ERROR([You cannot build a minimal JVM for a 64-bit machine.])
dholmes@542 133 fi
ihse@839 134 fi
erikj@459 135
ihse@839 136 # Replace the commas with AND for use in the build directory name.
mikael@1138 137 ANDED_JVM_VARIANTS=`$ECHO "$JVM_VARIANTS" | $SED -e 's/^,//' -e 's/,$//' -e 's/,/AND/g'`
kvn@972 138 COUNT_VARIANTS=`$ECHO "$JVM_VARIANTS" | $SED -e 's/server,/1/' -e 's/client,/1/' -e 's/minimal1,/1/' -e 's/kernel,/1/' -e 's/zero,/1/' -e 's/zeroshark,/1/' -e 's/core,/1/'`
ihse@839 139 if test "x$COUNT_VARIANTS" != "x,1"; then
erikj@459 140 BUILDING_MULTIPLE_JVM_VARIANTS=yes
ihse@839 141 else
erikj@459 142 BUILDING_MULTIPLE_JVM_VARIANTS=no
ihse@839 143 fi
erikj@459 144
ihse@839 145 AC_SUBST(JVM_VARIANTS)
ihse@839 146 AC_SUBST(JVM_VARIANT_SERVER)
ihse@839 147 AC_SUBST(JVM_VARIANT_CLIENT)
ihse@839 148 AC_SUBST(JVM_VARIANT_MINIMAL1)
ihse@839 149 AC_SUBST(JVM_VARIANT_KERNEL)
ihse@839 150 AC_SUBST(JVM_VARIANT_ZERO)
ihse@839 151 AC_SUBST(JVM_VARIANT_ZEROSHARK)
kvn@972 152 AC_SUBST(JVM_VARIANT_CORE)
erikj@459 153
ihse@839 154 INCLUDE_SA=true
ihse@839 155 if test "x$JVM_VARIANT_ZERO" = xtrue ; then
omajid@671 156 INCLUDE_SA=false
ihse@839 157 fi
ihse@839 158 if test "x$JVM_VARIANT_ZEROSHARK" = xtrue ; then
omajid@671 159 INCLUDE_SA=false
ihse@839 160 fi
kvn@972 161 if test "x$VAR_CPU" = xppc64 ; then
simonis@965 162 INCLUDE_SA=false
kvn@972 163 fi
ihse@839 164 AC_SUBST(INCLUDE_SA)
omajid@671 165
ihse@839 166 if test "x$OPENJDK_TARGET_OS" = "xmacosx"; then
ddehaven@1304 167 MACOSX_UNIVERSAL="false"
ihse@839 168 fi
ohair@478 169
ihse@839 170 AC_SUBST(MACOSX_UNIVERSAL)
erikj@459 171 ])
erikj@459 172
erikj@459 173 AC_DEFUN_ONCE([JDKOPT_SETUP_DEBUG_LEVEL],
erikj@459 174 [
ihse@839 175 ###############################################################################
ihse@839 176 #
ihse@839 177 # Set the debug level
ihse@839 178 # release: no debug information, all optimizations, no asserts.
ihse@839 179 # fastdebug: debug information (-g), all optimizations, all asserts
ihse@839 180 # slowdebug: debug information (-g), no optimizations, all asserts
ihse@839 181 #
ihse@839 182 DEBUG_LEVEL="release"
ihse@839 183 AC_MSG_CHECKING([which debug level to use])
ihse@839 184 AC_ARG_ENABLE([debug], [AS_HELP_STRING([--enable-debug],
ihse@839 185 [set the debug level to fastdebug (shorthand for --with-debug-level=fastdebug) @<:@disabled@:>@])],
ihse@839 186 [
erikj@459 187 ENABLE_DEBUG="${enableval}"
erikj@459 188 DEBUG_LEVEL="fastdebug"
ihse@839 189 ], [ENABLE_DEBUG="no"])
erikj@459 190
ihse@839 191 AC_ARG_WITH([debug-level], [AS_HELP_STRING([--with-debug-level],
ihse@839 192 [set the debug level (release, fastdebug, slowdebug) @<:@release@:>@])],
ihse@839 193 [
erikj@459 194 DEBUG_LEVEL="${withval}"
erikj@459 195 if test "x$ENABLE_DEBUG" = xyes; then
ihse@839 196 AC_MSG_ERROR([You cannot use both --enable-debug and --with-debug-level at the same time.])
erikj@459 197 fi
ihse@839 198 ])
ihse@839 199 AC_MSG_RESULT([$DEBUG_LEVEL])
erikj@459 200
ihse@839 201 if test "x$DEBUG_LEVEL" != xrelease && \
ihse@839 202 test "x$DEBUG_LEVEL" != xfastdebug && \
ihse@839 203 test "x$DEBUG_LEVEL" != xslowdebug; then
ihse@839 204 AC_MSG_ERROR([Allowed debug levels are: release, fastdebug and slowdebug])
ihse@839 205 fi
erikj@459 206
erikj@459 207
ihse@839 208 ###############################################################################
ihse@839 209 #
ihse@839 210 # Setup legacy vars/targets and new vars to deal with different debug levels.
ihse@839 211 #
erikj@459 212
ihse@839 213 case $DEBUG_LEVEL in
ihse@839 214 release )
ihse@839 215 VARIANT="OPT"
ihse@839 216 FASTDEBUG="false"
ihse@839 217 DEBUG_CLASSFILES="false"
ihse@839 218 BUILD_VARIANT_RELEASE=""
ihse@839 219 HOTSPOT_DEBUG_LEVEL="product"
ihse@839 220 HOTSPOT_EXPORT="product"
ihse@839 221 ;;
ihse@839 222 fastdebug )
ihse@839 223 VARIANT="DBG"
ihse@839 224 FASTDEBUG="true"
ihse@839 225 DEBUG_CLASSFILES="true"
ihse@839 226 BUILD_VARIANT_RELEASE="-fastdebug"
ihse@839 227 HOTSPOT_DEBUG_LEVEL="fastdebug"
ihse@839 228 HOTSPOT_EXPORT="fastdebug"
ihse@839 229 ;;
ihse@839 230 slowdebug )
ihse@839 231 VARIANT="DBG"
ihse@839 232 FASTDEBUG="false"
ihse@839 233 DEBUG_CLASSFILES="true"
ihse@839 234 BUILD_VARIANT_RELEASE="-debug"
ihse@839 235 HOTSPOT_DEBUG_LEVEL="jvmg"
ihse@839 236 HOTSPOT_EXPORT="debug"
ihse@839 237 ;;
ihse@839 238 esac
erikj@459 239
ihse@839 240 #####
ihse@839 241 # Generate the legacy makefile targets for hotspot.
ihse@839 242 # The hotspot api for selecting the build artifacts, really, needs to be improved.
ihse@839 243 # JDK-7195896 will fix this on the hotspot side by using the JVM_VARIANT_* variables to
ihse@839 244 # determine what needs to be built. All we will need to set here is all_product, all_fastdebug etc
ihse@839 245 # But until then ...
ihse@839 246 HOTSPOT_TARGET=""
erikj@459 247
ihse@839 248 if test "x$JVM_VARIANT_SERVER" = xtrue; then
erikj@459 249 HOTSPOT_TARGET="$HOTSPOT_TARGET${HOTSPOT_DEBUG_LEVEL} "
ihse@839 250 fi
erikj@459 251
ihse@839 252 if test "x$JVM_VARIANT_CLIENT" = xtrue; then
erikj@459 253 HOTSPOT_TARGET="$HOTSPOT_TARGET${HOTSPOT_DEBUG_LEVEL}1 "
ihse@839 254 fi
erikj@459 255
ihse@839 256 if test "x$JVM_VARIANT_MINIMAL1" = xtrue; then
dholmes@542 257 HOTSPOT_TARGET="$HOTSPOT_TARGET${HOTSPOT_DEBUG_LEVEL}minimal1 "
ihse@839 258 fi
dholmes@542 259
ihse@839 260 if test "x$JVM_VARIANT_KERNEL" = xtrue; then
erikj@459 261 HOTSPOT_TARGET="$HOTSPOT_TARGET${HOTSPOT_DEBUG_LEVEL}kernel "
ihse@839 262 fi
erikj@459 263
ihse@839 264 if test "x$JVM_VARIANT_ZERO" = xtrue; then
erikj@459 265 HOTSPOT_TARGET="$HOTSPOT_TARGET${HOTSPOT_DEBUG_LEVEL}zero "
ihse@839 266 fi
erikj@459 267
ihse@839 268 if test "x$JVM_VARIANT_ZEROSHARK" = xtrue; then
erikj@459 269 HOTSPOT_TARGET="$HOTSPOT_TARGET${HOTSPOT_DEBUG_LEVEL}shark "
ihse@839 270 fi
erikj@459 271
kvn@972 272 if test "x$JVM_VARIANT_CORE" = xtrue; then
simonis@965 273 HOTSPOT_TARGET="$HOTSPOT_TARGET${HOTSPOT_DEBUG_LEVEL}core "
kvn@972 274 fi
simonis@965 275
ihse@839 276 HOTSPOT_TARGET="$HOTSPOT_TARGET docs export_$HOTSPOT_EXPORT"
erikj@459 277
ihse@839 278 # On Macosx universal binaries are produced, but they only contain
ihse@839 279 # 64 bit intel. This invalidates control of which jvms are built
ihse@839 280 # from configure, but only server is valid anyway. Fix this
ihse@839 281 # when hotspot makefiles are rewritten.
ihse@839 282 if test "x$MACOSX_UNIVERSAL" = xtrue; then
erikj@560 283 HOTSPOT_TARGET=universal_${HOTSPOT_EXPORT}
ihse@839 284 fi
ohair@478 285
ihse@839 286 #####
erikj@459 287
ihse@839 288 AC_SUBST(DEBUG_LEVEL)
ihse@839 289 AC_SUBST(VARIANT)
ihse@839 290 AC_SUBST(FASTDEBUG)
ihse@839 291 AC_SUBST(DEBUG_CLASSFILES)
ihse@839 292 AC_SUBST(BUILD_VARIANT_RELEASE)
erikj@459 293 ])
erikj@459 294
erikj@459 295
erikj@459 296 ###############################################################################
erikj@459 297 #
erikj@459 298 # Should we build only OpenJDK even if closed sources are present?
erikj@459 299 #
erikj@575 300 AC_DEFUN_ONCE([JDKOPT_SETUP_OPEN_OR_CUSTOM],
erikj@575 301 [
erikj@575 302 AC_ARG_ENABLE([openjdk-only], [AS_HELP_STRING([--enable-openjdk-only],
ihse@839 303 [suppress building custom source even if present @<:@disabled@:>@])],,[enable_openjdk_only="no"])
erikj@459 304
erikj@575 305 AC_MSG_CHECKING([for presence of closed sources])
erikj@575 306 if test -d "$SRC_ROOT/jdk/src/closed"; then
ohair@494 307 CLOSED_SOURCE_PRESENT=yes
erikj@575 308 else
ohair@494 309 CLOSED_SOURCE_PRESENT=no
erikj@575 310 fi
erikj@575 311 AC_MSG_RESULT([$CLOSED_SOURCE_PRESENT])
ohair@494 312
erikj@575 313 AC_MSG_CHECKING([if closed source is suppressed (openjdk-only)])
erikj@575 314 SUPPRESS_CLOSED_SOURCE="$enable_openjdk_only"
erikj@575 315 AC_MSG_RESULT([$SUPPRESS_CLOSED_SOURCE])
ohair@494 316
erikj@575 317 if test "x$CLOSED_SOURCE_PRESENT" = xno; then
erikj@575 318 OPENJDK=true
erikj@575 319 if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then
erikj@575 320 AC_MSG_WARN([No closed source present, --enable-openjdk-only makes no sense])
erikj@575 321 fi
erikj@575 322 else
erikj@575 323 if test "x$SUPPRESS_CLOSED_SOURCE" = "xyes"; then
erikj@575 324 OPENJDK=true
erikj@575 325 else
erikj@575 326 OPENJDK=false
erikj@575 327 fi
ohair@494 328 fi
erikj@575 329
erikj@575 330 if test "x$OPENJDK" = "xtrue"; then
erikj@575 331 SET_OPENJDK="OPENJDK=true"
ohair@494 332 fi
erikj@459 333
erikj@575 334 AC_SUBST(SET_OPENJDK)
erikj@575 335 ])
erikj@459 336
erikj@575 337 AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_OPTIONS],
erikj@575 338 [
erikj@459 339
ihse@839 340 ###############################################################################
ihse@839 341 #
ihse@839 342 # Should we build a JDK/JVM with headful support (ie a graphical ui)?
ihse@839 343 # We always build headless support.
ihse@839 344 #
ihse@839 345 AC_MSG_CHECKING([headful support])
ihse@839 346 AC_ARG_ENABLE([headful], [AS_HELP_STRING([--disable-headful],
ihse@839 347 [disable building headful support (graphical UI support) @<:@enabled@:>@])],
ihse@839 348 [SUPPORT_HEADFUL=${enable_headful}], [SUPPORT_HEADFUL=yes])
erikj@459 349
ihse@839 350 SUPPORT_HEADLESS=yes
ihse@839 351 BUILD_HEADLESS="BUILD_HEADLESS:=true"
erikj@459 352
ihse@839 353 if test "x$SUPPORT_HEADFUL" = xyes; then
erikj@459 354 # We are building both headful and headless.
ihse@811 355 headful_msg="include support for both headful and headless"
ihse@839 356 fi
erikj@459 357
ihse@839 358 if test "x$SUPPORT_HEADFUL" = xno; then
erikj@459 359 # Thus we are building headless only.
erikj@459 360 BUILD_HEADLESS="BUILD_HEADLESS:=true"
erikj@459 361 headful_msg="headless only"
ihse@839 362 fi
erikj@459 363
ihse@839 364 AC_MSG_RESULT([$headful_msg])
erikj@459 365
ihse@839 366 AC_SUBST(SUPPORT_HEADLESS)
ihse@839 367 AC_SUBST(SUPPORT_HEADFUL)
ihse@839 368 AC_SUBST(BUILD_HEADLESS)
erikj@459 369
ihse@839 370 # Control wether Hotspot runs Queens test after build.
ihse@839 371 AC_ARG_ENABLE([hotspot-test-in-build], [AS_HELP_STRING([--enable-hotspot-test-in-build],
ihse@839 372 [run the Queens test after Hotspot build @<:@disabled@:>@])],,
ihse@839 373 [enable_hotspot_test_in_build=no])
ihse@839 374 if test "x$enable_hotspot_test_in_build" = "xyes"; then
erikj@459 375 TEST_IN_BUILD=true
ihse@839 376 else
erikj@459 377 TEST_IN_BUILD=false
ihse@839 378 fi
ihse@839 379 AC_SUBST(TEST_IN_BUILD)
erikj@459 380
ihse@839 381 ###############################################################################
ihse@839 382 #
ihse@839 383 # Choose cacerts source file
ihse@839 384 #
ihse@839 385 AC_ARG_WITH(cacerts-file, [AS_HELP_STRING([--with-cacerts-file],
ihse@839 386 [specify alternative cacerts file])])
ihse@839 387 if test "x$with_cacerts_file" != x; then
erikj@459 388 CACERTS_FILE=$with_cacerts_file
ihse@839 389 else
erikj@734 390 CACERTS_FILE=${SRC_ROOT}/jdk/src/share/lib/security/cacerts
ihse@839 391 fi
ihse@839 392 AC_SUBST(CACERTS_FILE)
erikj@459 393
ihse@839 394 ###############################################################################
ihse@839 395 #
ihse@839 396 # Enable or disable unlimited crypto
ihse@839 397 #
ihse@839 398 AC_ARG_ENABLE(unlimited-crypto, [AS_HELP_STRING([--enable-unlimited-crypto],
ihse@839 399 [Enable unlimited crypto policy @<:@disabled@:>@])],,
ihse@839 400 [enable_unlimited_crypto=no])
ihse@839 401 if test "x$enable_unlimited_crypto" = "xyes"; then
ihse@495 402 UNLIMITED_CRYPTO=true
ihse@839 403 else
ihse@495 404 UNLIMITED_CRYPTO=false
ihse@839 405 fi
ihse@839 406 AC_SUBST(UNLIMITED_CRYPTO)
ihse@495 407
ihse@839 408 ###############################################################################
ihse@839 409 #
ihse@839 410 # Enable or disable the elliptic curve crypto implementation
ihse@839 411 #
ihse@839 412 AC_DEFUN_ONCE([JDKOPT_DETECT_INTREE_EC],
ihse@839 413 [
ihse@839 414 AC_MSG_CHECKING([if elliptic curve crypto implementation is present])
omajid@656 415
ihse@839 416 if test -d "${SRC_ROOT}/jdk/src/share/native/sun/security/ec/impl"; then
ihse@839 417 ENABLE_INTREE_EC=yes
ihse@839 418 AC_MSG_RESULT([yes])
ihse@839 419 else
ihse@839 420 ENABLE_INTREE_EC=no
ihse@839 421 AC_MSG_RESULT([no])
ihse@839 422 fi
omajid@656 423
ihse@839 424 AC_SUBST(ENABLE_INTREE_EC)
ihse@839 425 ])
omajid@656 426
ihse@839 427 ###############################################################################
ihse@839 428 #
ihse@839 429 # Compress jars
ihse@839 430 #
ihse@839 431 COMPRESS_JARS=false
erikj@459 432
ihse@839 433 AC_SUBST(COMPRESS_JARS)
erikj@459 434 ])
erikj@459 435
erikj@562 436 ###############################################################################
erikj@562 437 #
erikj@562 438 # Setup version numbers
erikj@562 439 #
erikj@459 440 AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_VERSION_NUMBERS],
erikj@459 441 [
ihse@839 442 # Source the version numbers
ihse@839 443 . $AUTOCONF_DIR/version-numbers
erikj@561 444
ihse@839 445 # Get the settings from parameters
ihse@839 446 AC_ARG_WITH(milestone, [AS_HELP_STRING([--with-milestone],
ihse@839 447 [Set milestone value for build @<:@internal@:>@])])
ihse@839 448 if test "x$with_milestone" = xyes; then
ihse@839 449 AC_MSG_ERROR([Milestone must have a value])
ihse@839 450 elif test "x$with_milestone" != x; then
erikj@561 451 MILESTONE="$with_milestone"
ihse@839 452 fi
ihse@839 453 if test "x$MILESTONE" = x; then
ihse@839 454 MILESTONE=internal
ihse@839 455 fi
erikj@561 456
ihse@839 457 AC_ARG_WITH(update-version, [AS_HELP_STRING([--with-update-version],
ihse@839 458 [Set update version value for build @<:@b00@:>@])])
ihse@839 459 if test "x$with_update_version" = xyes; then
ihse@839 460 AC_MSG_ERROR([Update version must have a value])
ihse@839 461 elif test "x$with_update_version" != x; then
ihse@839 462 JDK_UPDATE_VERSION="$with_update_version"
erikj@990 463 # On macosx 10.7, it's not possible to set --with-update-version=0X due
erikj@990 464 # to a bug in expr (which reduces it to just X). To work around this, we
erikj@990 465 # always add a 0 to one digit update versions.
erikj@990 466 if test "${#JDK_UPDATE_VERSION}" = "1"; then
erikj@990 467 JDK_UPDATE_VERSION="0${JDK_UPDATE_VERSION}"
erikj@990 468 fi
ihse@839 469 fi
erikj@727 470
ihse@839 471 AC_ARG_WITH(user-release-suffix, [AS_HELP_STRING([--with-user-release-suffix],
ihse@839 472 [Add a custom string to the version string if build number isn't set.@<:@username_builddateb00@:>@])])
ihse@839 473 if test "x$with_user_release_suffix" = xyes; then
ihse@839 474 AC_MSG_ERROR([Release suffix must have a value])
ihse@839 475 elif test "x$with_user_release_suffix" != x; then
ihse@839 476 USER_RELEASE_SUFFIX="$with_user_release_suffix"
ihse@839 477 fi
erikj@813 478
ihse@839 479 AC_ARG_WITH(build-number, [AS_HELP_STRING([--with-build-number],
ihse@839 480 [Set build number value for build @<:@b00@:>@])])
ihse@839 481 if test "x$with_build_number" = xyes; then
ihse@839 482 AC_MSG_ERROR([Build number must have a value])
ihse@839 483 elif test "x$with_build_number" != x; then
ihse@839 484 JDK_BUILD_NUMBER="$with_build_number"
erikj@813 485 fi
ihse@839 486 # Define default USER_RELEASE_SUFFIX if BUILD_NUMBER and USER_RELEASE_SUFFIX are not set
ihse@839 487 if test "x$JDK_BUILD_NUMBER" = x; then
ihse@839 488 JDK_BUILD_NUMBER=b00
ihse@839 489 if test "x$USER_RELEASE_SUFFIX" = x; then
ihse@839 490 BUILD_DATE=`date '+%Y_%m_%d_%H_%M'`
ihse@839 491 # Avoid [:alnum:] since it depends on the locale.
ihse@839 492 CLEAN_USERNAME=`echo "$USER" | $TR -d -c 'abcdefghijklmnopqrstuvqxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'`
ihse@839 493 USER_RELEASE_SUFFIX=`echo "${CLEAN_USERNAME}_${BUILD_DATE}" | $TR 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
ihse@839 494 fi
ihse@839 495 fi
erikj@561 496
ihse@839 497 # Now set the JDK version, milestone, build number etc.
ihse@839 498 AC_SUBST(USER_RELEASE_SUFFIX)
ihse@839 499 AC_SUBST(JDK_MAJOR_VERSION)
ihse@839 500 AC_SUBST(JDK_MINOR_VERSION)
ihse@839 501 AC_SUBST(JDK_MICRO_VERSION)
ihse@839 502 AC_SUBST(JDK_UPDATE_VERSION)
ihse@839 503 AC_SUBST(JDK_BUILD_NUMBER)
ihse@839 504 AC_SUBST(MILESTONE)
ihse@839 505 AC_SUBST(LAUNCHER_NAME)
ihse@839 506 AC_SUBST(PRODUCT_NAME)
ihse@839 507 AC_SUBST(PRODUCT_SUFFIX)
ihse@839 508 AC_SUBST(JDK_RC_PLATFORM_NAME)
ihse@839 509 AC_SUBST(COMPANY_NAME)
ihse@839 510 AC_SUBST(MACOSX_BUNDLE_NAME_BASE)
ihse@839 511 AC_SUBST(MACOSX_BUNDLE_ID_BASE)
erikj@459 512
erikj@1202 513 AC_ARG_WITH(copyright-year, [AS_HELP_STRING([--with-copyright-year],
erikj@1202 514 [Set copyright year value for build @<:@current year@:>@])])
erikj@1202 515 if test "x$with_copyright_year" = xyes; then
erikj@1202 516 AC_MSG_ERROR([Copyright year must have a value])
erikj@1202 517 elif test "x$with_copyright_year" != x; then
erikj@1202 518 COPYRIGHT_YEAR="$with_copyright_year"
erikj@1202 519 else
erikj@1202 520 COPYRIGHT_YEAR=`date +'%Y'`
erikj@1202 521 fi
ihse@839 522 AC_SUBST(COPYRIGHT_YEAR)
erikj@459 523
ihse@839 524 if test "x$JDK_UPDATE_VERSION" != x; then
ihse@839 525 JDK_VERSION="${JDK_MAJOR_VERSION}.${JDK_MINOR_VERSION}.${JDK_MICRO_VERSION}_${JDK_UPDATE_VERSION}"
ihse@839 526 else
ihse@839 527 JDK_VERSION="${JDK_MAJOR_VERSION}.${JDK_MINOR_VERSION}.${JDK_MICRO_VERSION}"
ihse@839 528 fi
ihse@839 529 AC_SUBST(JDK_VERSION)
erikj@459 530
ihse@839 531 COOKED_BUILD_NUMBER=`$ECHO $JDK_BUILD_NUMBER | $SED -e 's/^b//' -e 's/^0//'`
ihse@839 532 AC_SUBST(COOKED_BUILD_NUMBER)
erikj@459 533 ])
erikj@459 534
erikj@459 535 AC_DEFUN_ONCE([JDKOPT_SETUP_BUILD_TWEAKS],
erikj@459 536 [
ihse@839 537 HOTSPOT_MAKE_ARGS="$HOTSPOT_TARGET"
ihse@839 538 AC_SUBST(HOTSPOT_MAKE_ARGS)
erikj@459 539
ihse@839 540 # The name of the Service Agent jar.
ihse@839 541 SALIB_NAME="${LIBRARY_PREFIX}saproc${SHARED_LIBRARY_SUFFIX}"
ihse@839 542 if test "x$OPENJDK_TARGET_OS" = "xwindows"; then
ihse@839 543 SALIB_NAME="${LIBRARY_PREFIX}sawindbg${SHARED_LIBRARY_SUFFIX}"
ihse@839 544 fi
ihse@839 545 AC_SUBST(SALIB_NAME)
erikj@459 546 ])
erikj@459 547
erikj@459 548 AC_DEFUN_ONCE([JDKOPT_SETUP_DEBUG_SYMBOLS],
erikj@459 549 [
ihse@839 550 #
ihse@839 551 # ENABLE_DEBUG_SYMBOLS
ihse@839 552 # This must be done after the toolchain is setup, since we're looking at objcopy.
ihse@839 553 #
ihse@839 554 AC_ARG_ENABLE([debug-symbols],
ihse@839 555 [AS_HELP_STRING([--disable-debug-symbols],[disable generation of debug symbols @<:@enabled@:>@])])
erikj@459 556
ihse@839 557 AC_MSG_CHECKING([if we should generate debug symbols])
erikj@459 558
ihse@839 559 if test "x$enable_debug_symbols" = "xyes" && test "x$OBJCOPY" = x; then
ihse@839 560 # explicit enabling of enable-debug-symbols and can't find objcopy
ihse@839 561 # this is an error
ihse@839 562 AC_MSG_ERROR([Unable to find objcopy, cannot enable debug-symbols])
ihse@839 563 fi
erikj@459 564
ihse@839 565 if test "x$enable_debug_symbols" = "xyes"; then
ihse@839 566 ENABLE_DEBUG_SYMBOLS=true
ihse@839 567 elif test "x$enable_debug_symbols" = "xno"; then
erikj@813 568 ENABLE_DEBUG_SYMBOLS=false
erikj@813 569 else
dcubed@874 570 # Default is on if objcopy is found
dcubed@874 571 if test "x$OBJCOPY" != x; then
dcubed@874 572 ENABLE_DEBUG_SYMBOLS=true
dcubed@874 573 # MacOS X and Windows don't use objcopy but default is on for those OSes
dcubed@874 574 elif test "x$OPENJDK_TARGET_OS" = xmacosx || test "x$OPENJDK_TARGET_OS" = xwindows; then
ihse@839 575 ENABLE_DEBUG_SYMBOLS=true
ihse@839 576 else
ihse@839 577 ENABLE_DEBUG_SYMBOLS=false
ihse@839 578 fi
erikj@813 579 fi
erikj@813 580
ihse@839 581 AC_MSG_RESULT([$ENABLE_DEBUG_SYMBOLS])
erikj@813 582
ihse@839 583 #
ihse@839 584 # ZIP_DEBUGINFO_FILES
ihse@839 585 #
ihse@839 586 AC_MSG_CHECKING([if we should zip debug-info files])
ihse@839 587 AC_ARG_ENABLE([zip-debug-info],
ihse@839 588 [AS_HELP_STRING([--disable-zip-debug-info],[disable zipping of debug-info files @<:@enabled@:>@])],
ihse@839 589 [enable_zip_debug_info="${enableval}"], [enable_zip_debug_info="yes"])
ihse@839 590 AC_MSG_RESULT([${enable_zip_debug_info}])
erikj@813 591
ihse@839 592 if test "x${enable_zip_debug_info}" = "xno"; then
ihse@839 593 ZIP_DEBUGINFO_FILES=false
erikj@459 594 else
ihse@839 595 ZIP_DEBUGINFO_FILES=true
erikj@459 596 fi
erikj@459 597
ihse@839 598 AC_SUBST(ENABLE_DEBUG_SYMBOLS)
ihse@839 599 AC_SUBST(ZIP_DEBUGINFO_FILES)
ihse@839 600 AC_SUBST(CFLAGS_DEBUG_SYMBOLS)
ihse@839 601 AC_SUBST(CXXFLAGS_DEBUG_SYMBOLS)
erikj@459 602 ])
ohair@478 603
ohair@478 604 # Support for customization of the build process. Some build files
ohair@478 605 # will include counterparts from this location, if they exist. This allows
ohair@478 606 # for a degree of customization of the build targets and the rules/recipes
ohair@478 607 # to create them
ohair@478 608 AC_ARG_WITH([custom-make-dir], [AS_HELP_STRING([--with-custom-make-dir],
ihse@839 609 [use this directory for custom build/make files])], [CUSTOM_MAKE_DIR=$with_custom_make_dir])
ohair@478 610 AC_SUBST(CUSTOM_MAKE_DIR)

mercurial