###
### %CopyrightBegin%
### 
### Copyright Ericsson AB 2009. All Rights Reserved.
### 
### The contents of this file are subject to the Erlang Public License,
### Version 1.1, (the "License"); you may not use this file except in
### compliance with the License. You should have received a copy of the
### Erlang Public License along with this software. If not, it can be
### retrieved online at http://www.erlang.org/.
### 
### Software distributed under the License is distributed on an "AS IS"
### basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
### the License for the specific language governing rights and limitations
### under the License.
### 
### %CopyrightEnd%
###
### File: erl-xcomp.conf
### Author: Rickard Green
###

### ----------------------------------------------------------------------------
### When cross compiling Erlang/OTP, copy this file and set the variables
### needed below. Then pass the path to the copy of this file as an argument
### to "eval `otp_build env_cross <absolute path to erl-xcomp.conf file>`".
### ----------------------------------------------------------------------------

### ----------------------------------------------------------------------------
### Variables in the following section *have* to be set.
###

##
## Target system. The value will be passed as '--host' argument to the configure
## script. It does not have to be a full CPU-VENDOR-OS tripplet, but can be. The
## full CPU-VENDOR-OS tripplet will be created by:
##  $ERL_TOP/erts/autoconf/config.sub $erl_xcomp_host
##
erl_xcomp_host=

### ----------------------------------------------------------------------------
### To override the configure flags for a special target system, You
### can set this variable which overrides configure parameters on the 
### command line and instead uses the specified options. The variable
### leaves the build-host system untouched.
### ----------------------------------------------------------------------------
erl_xcomp_configure_flags=

###-----------------------------------------------------------------------------
### You can specify a specific CC or LD for the build target (the cross 
### compiler) here along with magic CFLAGS and/or LDFLAGS if needed
### ar and ranlib might also be specified if needed.
###-----------------------------------------------------------------------------

erl_xcomp_cc=

erl_xcomp_ld=

erl_xcomp_cflags=

erl_xcomp_cpp=

erl_xcomp_ldflags=

erl_xcomp_ranlib=

erl_xcomp_ar=

###-----------------------------------------------------------------------------
### The ded_ls and ded_ldflags variables control linking of dynamically loaded
### erlang drivers. On i.e. Linux these are set to
### $(CC) and "-shared" respectively, but other OS'es might need other
### programs and flags to build a dynamic library. 
### erl_xcomp_ded_ld_runtime_library_path is the flag to set a
### specific runtime library path for the shared library at link time, 
### usually this should be left empty.
###-----------------------------------------------------------------------------

erl_xcomp_ded_ld=

erl_xcomp_ded_ldflags=

erl_xcomp_ded_ld_runtime_library_path=

###
### Optional feature, or bug tests
###
### These tests cannot (always) be done automatically when cross compiling.
### You usually does not need to set these variables. Only set these if you
### really know what you are doing.
###

##
## erl_xcomp_bigendian - yes|no
##  If yes, the target system must be big endian. If no, little endian. This
##  can often be automatically detected, but not always. If not automatically
##  detected, configure will fail unless this variable is set. No default value
##  is used, i.e., configure will try to figure this out automatically.
erl_xcomp_bigendian=

##
## erl_xcomp_linux_clock_gettime_correction - yes|no (defaults to yes)
##  If yes, clock_gettime(CLOCK_MONOTONIC, _) on the target system must work.
##  This variable is recommended to be set to no on Linux systems with kernel
##  versions less than 2.6.
##
erl_xcomp_linux_clock_gettime_correction=

##
## erl_xcomp_linux_nptl - yes|no (defaults to yes on Linux; otherwise, no)
##  If yes, the target system must have NPTL (Native POSIX Thread Library).
##  Older Linux systems have LinuxThreads instead of NPTL (Linux kernel
##  versions typically less than 2.6).
##
erl_xcomp_linux_nptl=

##
## erl_xcomp_linux_usable_sigusrx - yes|no (defaults to yes)
##  If yes, the SIGUSR1 and SIGUSR2 must be usable by the ERTS. Old
##  LinuxThreads thread libraries (Linux kernel versions less than 2.2) used
##  these signals and made them unusable by the ERTS.
##
erl_xcomp_linux_usable_sigusrx=

##
## erl_xcomp_linux_usable_sigaltstack - yes|no (defaults to yes)
##  If yes, sigaltstack() must be usable on the target system. sigaltstack()
##  on Linux kernel versions less than 2.4 are broken.
##
erl_xcomp_linux_usable_sigaltstack=

##
## erl_xcomp_poll - yes|no (defaults to no on Darwin/MacOSX; otherwise, yes)
##  If yes, the target system must have a working poll() implementation that
##  also can handle devices. If no, select() will be used instead of poll().
##
erl_xcomp_poll=

##
## erl_xcomp_kqueue - yes|no (defaults to no)
##  If yes, the target system must have a working kqueue() implementation that
##  returns a file descriptor which can be used by poll() and/or select().
##  If no and the target system has not got epoll() or /dev/poll, the
##  kernel-poll feature will be disabled.
##
erl_xcomp_kqueue=

##
## erl_xcomp_putenv_copy - yes|no (defaults to no)
##  If yes, the target system must have a putenv() implementation that stores a
##  copy of the key/value pair.
##
erl_xcomp_putenv_copy=

##
## erl_xcomp_reliable_fpe - yes|no (defaults to no)
##  If yes, the target system must have reliable floating point exceptions.
##
erl_xcomp_reliable_fpe=

##
## erl_xcomp_getaddrinfo - yes|no (defaults to no)
##  If yes, the target system must have a working getaddrinfo() implementation
##  that can handle both IPv4 and IPv6.
##
erl_xcomp_getaddrinfo=

##
## erl_xcomp_gethrvtime_procfs_ioctl - yes|no (defaults to no)
##  If yes, the target system must have a working gethrvtime() implementation
##  and is used with procfs ioctl().
##
erl_xcomp_gethrvtime_procfs_ioctl=

##
## erl_xcomp_clock_gettime - yes|no (defaults to no)
##  If yes, the target system must have a working clock_gettime()
##  implementation that can be used for retrieving process CPU time.
##
erl_xcomp_clock_gettime=

##
## erl_xcomp_after_morecore_hook - yes|no (defaults to no)
##  If yes, the target system must have a working __after_morecore_hook that
##  can be used for tracking used malloc() implementations core memory usage.
##
erl_xcomp_after_morecore_hook=

##
## erl_xcomp_dlsym_brk_wrappers - yes|no (defaults to no)
##  If yes, the target system must have a working dlsym(RTLD_NEXT, <S>)
##  implementation that can be used on 'brk' and 'sbrk' symbols used by the
##  malloc() implementation in use, and by this track the malloc()
##  implementations core memory usage.
##
erl_xcomp_dlsym_brk_wrappers=

### ----------------------------------------------------------------------------