jdk/make/jdk_generic_profile.sh
author andrew
Thu, 03 Jun 2010 19:37:48 +0100
changeset 5639 730861c04a99
parent 5506 202f599c92aa
child 5633 d20431ead333
permissions -rw-r--r--
6958257: Add support for alpha Summary: Allow the Zero port to be built on alpha architectures Reviewed-by: ohair

#!/bin/sh

#
# Copyright (c) 2007, 2008, Oracle and/or its affiliates. All rights reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
#
# This code is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License version 2 only, as
# published by the Free Software Foundation.  Oracle designates this
# particular file as subject to the "Classpath" exception as provided
# by Oracle in the LICENSE file that accompanied this code.
#
# This code is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
# version 2 for more details (a copy is included in the LICENSE file that
# accompanied this code).
#
# You should have received a copy of the GNU General Public License version
# 2 along with this work; if not, write to the Free Software Foundation,
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
#
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
# or visit www.oracle.com if you need additional information or have any
# questions.
#


#############################################################################
#
# Generic build profile.sh for all platforms, works in bash, sh, and ksh.
#
# Copy this file to your own area, and edit it to suit your needs.
#
# Ideally you either won't need to set the ALT_* variables because the
#   build system will find what it needs through system provided paths
#   or environment variables, or you have installed the component in the
#   recommended default path.
#
# If you find yourself forced to set an ALT_* environment variable and
#   suspect we could have figured it out automatically, please let us know.
#
# Most ALT_* directory defaults are based on being in the parent directory in
#    ALT_SLASH_JAVA, so it's possible to create for example a "C:/jdk6"
#    directory, assign that to ALT_SLASH_JAVA, and place all the components
#    in that directory. This could also minimize the ALT_* environment
#    variables you need to set.
#
########
#
# Assumes basic unix utilities are in the PATH already (uname, hostname, etc.).
#
# On Windows, assumes PROCESSOR_IDENTIFIER, VS71COMNTOOLS,
#   SYSTEMROOT (or SystemRoot), COMPUTERNAME (or hostname works), and
#   USERNAME is defined in the environment.
#   This profile does not rely on using vcvars32.bat and 64bit Setup.bat.
#   Uses CYGWIN cygpath to make sure paths are space-free.
#
# The JDK Makefiles may change in the future, making some of these
#   settings unnecessary or redundant.
#
# This is a working example, but may or may not work on all systems.
#
#############################################################################
#
# WARNING: This file will clobber the value of some environment variables.
#
# Sets up these environment variables for doing JDK builds:
#    USERNAME
#    COMPUTERNAME
#    PATH
#    Windows Only:
#      LIB
#      INCLUDE
#      PS1
#      SHELL
#
# Attempts to set these variables for the JDK builds:           
#    ALT_COMPILER_PATH
#    ALT_BOOTDIR
#    ALT_BINARY_PLUGS_PATH
#    ALT_CLOSED_JDK_IMPORT_PATH
#    Windows Only:
#      ALT_UNIXCOMMAND_PATH
#      ALT_MSDEVTOOLS_PATH
#      ALT_DXSDK_PATH
#      ALT_MSVCRT_DLL_PATH
#      ALT_MSVCR71_DLL_PATH
#
#############################################################################
#
# Keep in mind that at this point, we are running in some kind of shell
#   (sh, ksh, or bash). We don't know if it's solaris, linux, or windows 
#   CYGWIN. We need to figure that out.

# Find user name
if [ "${USERNAME}" = "" ] ; then
    USERNAME="${LOGNAME}"
fi
if [ "${USERNAME}" = "" ] ; then
    USERNAME="${USER}"
fi
export USERNAME

# Find machine name
if [ "${COMPUTERNAME}" = "" ] ; then
    COMPUTERNAME="$(hostname)"
fi
export COMPUTERNAME

# Boot jdk
bootjdk=jdk1.6.0
importjdk=jdk1.7.0

# Uses 'uname -s', but only expect SunOS or Linux, assume Windows otherwise.
osname=$(uname -s)
if [ "${osname}" = SunOS ] ; then
  
  # System place where JDK installed images are stored?
  jdk_instances=/usr/jdk/instances

  # Get the Sun Studio compilers (and latest patches for them too)
  if [ "${ALT_COMPILER_PATH}" = "" ] ; then
    ALT_COMPILER_PATH=/opt/SUNWspro/bin
    export ALT_COMPILER_PATH
  fi
  if [ ! -d ${ALT_COMPILER_PATH} ] ; then
    echo "WARNING: Cannot access ALT_COMPILER_PATH=${ALT_COMPILER_PATH}"
  fi
  
  # Place compiler path early in PATH to avoid 'cc' conflicts.
  path4sdk=${ALT_COMPILER_PATH}:/usr/ccs/bin:/usr/ccs/lib:/usr/bin:/bin:/usr/sfw/bin

  # Make sure these are unset
  unset JAVA_HOME
  unset LD_LIBRARY_PATH

  # Build in C locale
  LANG=C
  export LANG
  LC_ALL=C
  export LC_ALL

  umask 002

elif [ "${osname}" = Linux ] ; then
  
  # System place where JDK installed images are stored?
  jdk_instances=/opt/java
    
  # Use compilers from /usr/bin
  path4sdk=/usr/bin:/bin:/usr/sbin:/sbin

  # Make sure these are unset
  unset JAVA_HOME
  unset LD_LIBRARY_PATH

  # Build in C locale
  LANG=C
  export LANG
  LC_ALL=C
  export LC_ALL

  umask 002

else

  # System place where JDK installed images are stored?
  jdk_instances="C:"

  # Windows: Differs on CYGWIN and the compiler available.
  #   Also, blanks in pathnames gives make headaches, so anything placed
  #   in any ALT_* variable should be the short windows DOS names.
   
  # Check CYGWIN (should have already been done)
  #   Assumption here is that you are in a shell window via cygwin.
  proc_arch=`echo "$(PROCESSOR_IDENTIFIER)" | expand | cut -d' ' -f1 | sed -e 's@x86@X86@g' -e 's@Intel64@X64@g' -e 's@em64t@X64@g' -e 's@EM64T@X64@g' -e 's@amd64@X64@g' -e 's@AMD64@X64@g' -e 's@ia64@IA64@g'`
  if [ "${proc_arch}" = "X64" ] ; then
    windows_arch=amd64
  else
    windows_arch=i586
  fi
  # We need to check if we are running a CYGWIN shell
  if [ "$(uname -a | fgrep Cygwin)" != "" -a -f /bin/cygpath ] ; then
    # For CYGWIN, uname will have "Cygwin" in it, and /bin/cygpath should exist
    # Utility to convert to short pathnames without spaces
    cygpath="/usr/bin/cygpath -a -m -s"
    # Most unix utilities are in the /usr/bin
    unixcommand_path="/usr/bin"
    # Make the prompt tell you CYGWIN
    export PS1="CYGWIN:${COMPUTERNAME}:${USERNAME}[\!] "
  else
    echo "ERROR: Cannot find CYGWIN on this machine"
    exit 1
  fi
  if [ "${ALT_UNIXCOMMAND_PATH}" != "" ] ; then
    unixcommand_path=${ALT_UNIXCOMMAND_PATH}
  fi
    
  # Default shell
  export SHELL="${unixcommand_path}/sh"

  # Setup path system (verify this is right)
  if [ "${SystemRoot}" != "" ] ; then
    sys_root=$(${cygpath} "${SystemRoot}")
  elif [ "${SYSTEMROOT}" != "" ] ; then
    sys_root=$(${cygpath} "${SYSTEMROOT}")
  else
    sys_root=$(${cygpath} "C:/WINNT")
  fi
  path4sdk="${unixcommand_path};${sys_root}/system32;${sys_root};${sys_root}/System32/Wbem"
  if [ ! -d "${sys_root}" ] ; then
    echo "WARNING: No system root found at: ${sys_root}"
  fi

  # Compiler setup (nasty part)
  #   NOTE: You can use vcvars32.bat to set PATH, LIB, and INCLUDE.
  #   NOTE: CYGWIN has a link.exe too, make sure the compilers are first
  if [ "${windows_arch}" = i586 ] ; then
    # 32bit Windows compiler settings
    # VisualStudio .NET 2003 VC++ 7.1 (VS71COMNTOOLS should be defined)
    vs_root=$(${cygpath} "${VS71COMNTOOLS}/../..")
    # Fill in PATH, LIB, and INCLUDE (unset all others to make sure)
    msdev_root="${vs_root}/Common7/Tools"
    msdevtools_path="${msdev_root}/bin"
    vc7_root="${vs_root}/Vc7"
    compiler_path="${vc7_root}/bin"
    platform_sdk="${vc7_root}/PlatformSDK"
        
    # LIB and INCLUDE must use ; as a separator
    include4sdk="${vc7_root}/atlmfc/include"
    include4sdk="${include4sdk};${vc7_root}/include"
    include4sdk="${include4sdk};${platform_sdk}/include/prerelease"
    include4sdk="${include4sdk};${platform_sdk}/include"
    include4sdk="${include4sdk};${vs_root}/SDK/v1.1/include"
    lib4sdk="${lib4sdk};${vc7_root}/lib"
    lib4sdk="${lib4sdk};${platform_sdk}/lib/prerelease"
    lib4sdk="${lib4sdk};${platform_sdk}/lib"
    lib4sdk="${lib4sdk};${vs_root}/SDK/v1.1/lib"
    # Search path and DLL locating path
    #   WARNING: CYGWIN has a link.exe too, make sure compilers are first
    path4sdk="${vs_root}/Common7/Tools/bin;${path4sdk}"
    path4sdk="${vs_root}/SDK/v1.1/bin;${path4sdk}"
    path4sdk="${vs_root}/Common7/Tools;${path4sdk}"
    path4sdk="${vs_root}/Common7/Tools/bin/prerelease;${path4sdk}"
    path4sdk="${vs_root}/Common7/IDE;${path4sdk}"
    path4sdk="${compiler_path};${path4sdk}"
  elif [ "${windows_arch}" = amd64 ] ; then
    # AMD64 64bit Windows compiler settings
    if [ "${ALT_DEPLOY_MSSDK}" != "" ] ; then
      platform_sdk=${ALT_DEPLOY_MSSDK}
    else
      platform_sdk=$(${cygpath} "C:/Program Files/Microsoft Platform SDK/")
    fi
    if [ "${ALT_COMPILER_PATH}" != "" ] ; then
      compiler_path=${ALT_COMPILER_PATH}
      if [ "${ALT_DEPLOY_MSSDK}" = "" ] ; then
        platform_sdk=${ALT_COMPILER_PATH}/../../../..
      fi
    else
      compiler_path="${platform_sdk}/Bin/win64/x86/AMD64"
    fi
    if [ "${ALT_MSDEVTOOLS_PATH}" != "" ] ; then
      msdevtools_path=${ALT_MSDEVTOOLS_PATH}
    else
      msdevtools_path="${platform_sdk}/Bin/win64/x86/AMD64"
    fi
    msdevtools_path="${compiler_path}"
    # LIB and INCLUDE must use ; as a separator
    include4sdk="${platform_sdk}/Include"
    include4sdk="${include4sdk};${platform_sdk}/Include/crt/sys"
    include4sdk="${include4sdk};${platform_sdk}/Include/mfc"
    include4sdk="${include4sdk};${platform_sdk}/Include/atl"
    include4sdk="${include4sdk};${platform_sdk}/Include/crt"
    lib4sdk="${platform_sdk}/Lib/AMD64"
    lib4sdk="${lib4sdk};${platform_sdk}/Lib/AMD64/atlmfc"
    # Search path and DLL locating path
    #   WARNING: CYGWIN has a link.exe too, make sure compilers are first
    path4sdk="${platform_sdk}/bin;${path4sdk}"
    path4sdk="${compiler_path};${path4sdk}"
  fi
  # Export LIB and INCLUDE
  unset lib
  unset Lib
  LIB="${lib4sdk}"
  export LIB
  unset include
  unset Include
  INCLUDE="${include4sdk}"
  export INCLUDE
    
  # Turn all \\ into /, remove duplicates and trailing /
  slash_path="$(echo ${path4sdk} | sed -e 's@\\\\@/@g' -e 's@//@/@g' -e 's@/$@@' -e 's@/;@;@g')"
  path4sdk="${slash_path}"
   
  # Convert path4sdk to cygwin style
  path4sdk="$(/usr/bin/cygpath -p ${path4sdk})"

fi

# Get the previous JDK to be used to bootstrap the build
if [ "${ALT_BOOTDIR}" = "" ] ; then
  ALT_BOOTDIR=${jdk_instances}/${bootjdk}
  export ALT_BOOTDIR
fi
if [ ! -d ${ALT_BOOTDIR} ] ; then
  echo "WARNING: Cannot access ALT_BOOTDIR=${ALT_BOOTDIR}"
fi

# Get the import JDK to be used to get hotspot VM if not built
if [ "${ALT_JDK_IMPORT_PATH}" = "" -a -d ${jdk_instances}/${importjdk} ] ; then
  ALT_JDK_IMPORT_PATH=${jdk_instances}/${importjdk}
  export ALT_JDK_IMPORT_PATH
fi

# Get the latest JDK binary plugs or build to import pre-built binaries
if [ "${ALT_BINARY_PLUGS_PATH}" = "" ] ; then
  binplugs=${jdk_instances}/openjdk-binary-plugs
  jdkplugs=${jdk_instances}/${importjdk}
  if [ -d ${binplugs} ] ; then
    ALT_BINARY_PLUGS_PATH=${binplugs}
    export ALT_BINARY_PLUGS_PATH
  elif [  "${ALT_CLOSED_JDK_IMPORT_PATH}" = "" -a -d ${jdkplugs} ] ; then
    ALT_CLOSED_JDK_IMPORT_PATH=${jdkplugs}
    export ALT_CLOSED_JDK_IMPORT_PATH
  fi
  if [ "${ALT_BINARY_PLUGS_PATH}" = "" ] ; then
    echo "WARNING: Missing ALT_BINARY_PLUGS_PATH: ${binplugs}"
  fi
fi
if [ "${ALT_BINARY_PLUGS_PATH}" != "" -a ! -d "${ALT_BINARY_PLUGS_PATH}" ] ; then
  echo "WARNING: Cannot access ALT_BINARY_PLUGS_PATH=${ALT_BINARY_PLUGS_PATH}"
fi
if [ "${ALT_CLOSED_JDK_IMPORT_PATH}" != "" -a ! -d "${ALT_CLOSED_JDK_IMPORT_PATH}" ] ; then
  echo "WARNING: Cannot access ALT_CLOSED_JDK_IMPORT_PATH=${ALT_CLOSED_JDK_IMPORT_PATH}"
fi

# Export PATH setting
PATH="${path4sdk}"
export PATH

# Export variables required for Zero
if [ "${ZERO_BUILD}" = true ] ; then
  # ZERO_LIBARCH is the name of the architecture-specific
  # subdirectory under $JAVA_HOME/jre/lib
  arch=$(uname -m)
  case "${arch}" in
    x86_64)  ZERO_LIBARCH=amd64     ;;
    i?86)    ZERO_LIBARCH=i386      ;;
    sparc64) ZERO_LIBARCH=sparcv9   ;;
    arm*)    ZERO_LIBARCH=arm       ;;
    *)       ZERO_LIBARCH="$(arch)"
  esac
  export ZERO_LIBARCH

  # ARCH_DATA_MODEL is the number of bits in a pointer
  case "${ZERO_LIBARCH}" in
    i386|ppc|s390|sparc|arm)
      ARCH_DATA_MODEL=32
      ;;
    amd64|ppc64|s390x|sparcv9|ia64|alpha)
      ARCH_DATA_MODEL=64
      ;;
    *)
      echo "ERROR: Unable to determine ARCH_DATA_MODEL for ${ZERO_LIBARCH}"
      exit 1
  esac
  export ARCH_DATA_MODEL

  # ZERO_ENDIANNESS is the endianness of the processor
  case "${ZERO_LIBARCH}" in
    i386|amd64|ia64)
      ZERO_ENDIANNESS=little
      ;;
    ppc*|s390*|sparc*|alpha)
      ZERO_ENDIANNESS=big
      ;;
    *)
      echo "ERROR: Unable to determine ZERO_ENDIANNESS for ${ZERO_LIBARCH}"
      exit 1
  esac
  export ZERO_ENDIANNESS

  # ZERO_ARCHDEF is used to enable architecture-specific code
  case "${ZERO_LIBARCH}" in
    i386)   ZERO_ARCHDEF=IA32  ;;
    ppc*)   ZERO_ARCHDEF=PPC   ;;
    s390*)  ZERO_ARCHDEF=S390  ;;
    sparc*) ZERO_ARCHDEF=SPARC ;;
    *)      ZERO_ARCHDEF=$(echo "${ZERO_LIBARCH}" | tr a-z A-Z)
  esac
  export ZERO_ARCHDEF

  # ZERO_ARCHFLAG tells the compiler which mode to build for
  case "${ZERO_LIBARCH}" in
    s390)
      ZERO_ARCHFLAG="-m31"
      ;;
    *)
      ZERO_ARCHFLAG="-m${ARCH_DATA_MODEL}"
  esac
  export ZERO_ARCHFLAG

  # LIBFFI_CFLAGS and LIBFFI_LIBS tell the compiler how to compile and
  # link against libffi
  pkgconfig=$(which pkg-config 2>/dev/null)
  if [ -x "${pkgconfig}" ] ; then
    if [ "${LIBFFI_CFLAGS}" = "" ] ; then
      LIBFFI_CFLAGS=$("${pkgconfig}" --cflags libffi)
    fi
    if [ "${LIBFFI_LIBS}" = "" ] ; then
      LIBFFI_LIBS=$("${pkgconfig}" --libs libffi)
    fi
  fi
  if [ "${LIBFFI_LIBS}" = "" ] ; then
      LIBFFI_LIBS="-lffi"
  fi
  export LIBFFI_CFLAGS
  export LIBFFI_LIBS
fi