Fixes issue# 27983: Cause lack of llvm-profdata tool when using clang -
required for PGO linking - to be a configure time error rather than make time when --with-optimizations is enabled. Also improve our ability to find the llvm-profdata tool on MacOS and some Linuxes.
This commit is contained in:
parent
dc1650ca06
commit
799520c91e
|
@ -10,6 +10,11 @@ Release date: TBA
|
||||||
Core and Builtins
|
Core and Builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- Issue #27983: Cause lack of llvm-profdata tool when using clang as
|
||||||
|
required for PGO linking to be a configure time error rather than
|
||||||
|
make time when --with-optimizations is enabled. Also improve our
|
||||||
|
ability to find the llvm-profdata tool on MacOS and some Linuxes.
|
||||||
|
|
||||||
- Issue #26307: The profile-opt build now applys PGO to the built-in modules.
|
- Issue #26307: The profile-opt build now applys PGO to the built-in modules.
|
||||||
|
|
||||||
- Issue #27812: Properly clear out a generator's frame's backreference to the
|
- Issue #27812: Properly clear out a generator's frame's backreference to the
|
||||||
|
|
|
@ -668,6 +668,11 @@ CFLAGS_NODIST
|
||||||
BASECFLAGS
|
BASECFLAGS
|
||||||
OPT
|
OPT
|
||||||
LLVM_PROF_FOUND
|
LLVM_PROF_FOUND
|
||||||
|
target_os
|
||||||
|
target_vendor
|
||||||
|
target_cpu
|
||||||
|
target
|
||||||
|
LLVM_PROFDATA
|
||||||
LLVM_PROF_ERR
|
LLVM_PROF_ERR
|
||||||
LLVM_PROF_FILE
|
LLVM_PROF_FILE
|
||||||
LLVM_PROF_MERGER
|
LLVM_PROF_MERGER
|
||||||
|
@ -776,6 +781,7 @@ infodir
|
||||||
docdir
|
docdir
|
||||||
oldincludedir
|
oldincludedir
|
||||||
includedir
|
includedir
|
||||||
|
runstatedir
|
||||||
localstatedir
|
localstatedir
|
||||||
sharedstatedir
|
sharedstatedir
|
||||||
sysconfdir
|
sysconfdir
|
||||||
|
@ -887,6 +893,7 @@ datadir='${datarootdir}'
|
||||||
sysconfdir='${prefix}/etc'
|
sysconfdir='${prefix}/etc'
|
||||||
sharedstatedir='${prefix}/com'
|
sharedstatedir='${prefix}/com'
|
||||||
localstatedir='${prefix}/var'
|
localstatedir='${prefix}/var'
|
||||||
|
runstatedir='${localstatedir}/run'
|
||||||
includedir='${prefix}/include'
|
includedir='${prefix}/include'
|
||||||
oldincludedir='/usr/include'
|
oldincludedir='/usr/include'
|
||||||
docdir='${datarootdir}/doc/${PACKAGE_TARNAME}'
|
docdir='${datarootdir}/doc/${PACKAGE_TARNAME}'
|
||||||
|
@ -1139,6 +1146,15 @@ do
|
||||||
| -silent | --silent | --silen | --sile | --sil)
|
| -silent | --silent | --silen | --sile | --sil)
|
||||||
silent=yes ;;
|
silent=yes ;;
|
||||||
|
|
||||||
|
-runstatedir | --runstatedir | --runstatedi | --runstated \
|
||||||
|
| --runstate | --runstat | --runsta | --runst | --runs \
|
||||||
|
| --run | --ru | --r)
|
||||||
|
ac_prev=runstatedir ;;
|
||||||
|
-runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \
|
||||||
|
| --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \
|
||||||
|
| --run=* | --ru=* | --r=*)
|
||||||
|
runstatedir=$ac_optarg ;;
|
||||||
|
|
||||||
-sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
|
-sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
|
||||||
ac_prev=sbindir ;;
|
ac_prev=sbindir ;;
|
||||||
-sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
|
-sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
|
||||||
|
@ -1276,7 +1292,7 @@ fi
|
||||||
for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \
|
for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \
|
||||||
datadir sysconfdir sharedstatedir localstatedir includedir \
|
datadir sysconfdir sharedstatedir localstatedir includedir \
|
||||||
oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
|
oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
|
||||||
libdir localedir mandir
|
libdir localedir mandir runstatedir
|
||||||
do
|
do
|
||||||
eval ac_val=\$$ac_var
|
eval ac_val=\$$ac_var
|
||||||
# Remove trailing slashes.
|
# Remove trailing slashes.
|
||||||
|
@ -1429,6 +1445,7 @@ Fine tuning of the installation directories:
|
||||||
--sysconfdir=DIR read-only single-machine data [PREFIX/etc]
|
--sysconfdir=DIR read-only single-machine data [PREFIX/etc]
|
||||||
--sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com]
|
--sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com]
|
||||||
--localstatedir=DIR modifiable single-machine data [PREFIX/var]
|
--localstatedir=DIR modifiable single-machine data [PREFIX/var]
|
||||||
|
--runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run]
|
||||||
--libdir=DIR object code libraries [EPREFIX/lib]
|
--libdir=DIR object code libraries [EPREFIX/lib]
|
||||||
--includedir=DIR C header files [PREFIX/include]
|
--includedir=DIR C header files [PREFIX/include]
|
||||||
--oldincludedir=DIR C header files for non-gcc [/usr/include]
|
--oldincludedir=DIR C header files for non-gcc [/usr/include]
|
||||||
|
@ -1449,6 +1466,7 @@ _ACEOF
|
||||||
System types:
|
System types:
|
||||||
--build=BUILD configure for building on BUILD [guessed]
|
--build=BUILD configure for building on BUILD [guessed]
|
||||||
--host=HOST cross-compile to build programs to run on HOST [BUILD]
|
--host=HOST cross-compile to build programs to run on HOST [BUILD]
|
||||||
|
--target=TARGET configure for building compilers for TARGET [HOST]
|
||||||
_ACEOF
|
_ACEOF
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -6555,9 +6573,11 @@ if test "$Py_OPT" = 'true' ; then
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
DEF_MAKE_ALL_RULE="profile-opt"
|
DEF_MAKE_ALL_RULE="profile-opt"
|
||||||
|
REQUIRE_PGO="yes"
|
||||||
DEF_MAKE_RULE="build_all"
|
DEF_MAKE_RULE="build_all"
|
||||||
else
|
else
|
||||||
DEF_MAKE_ALL_RULE="build_all"
|
DEF_MAKE_ALL_RULE="build_all"
|
||||||
|
REQUIRE_PGO="no"
|
||||||
DEF_MAKE_RULE="all"
|
DEF_MAKE_RULE="all"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -6609,25 +6629,84 @@ fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Make this work on systems where llvm tools are not installed with their
|
||||||
|
# normal names in the default $PATH (ie: Ubuntu). They exist under the
|
||||||
|
# non-suffixed name in their versioned llvm directory.
|
||||||
|
llvm_bin_dir=''
|
||||||
|
llvm_path="${PATH}"
|
||||||
|
if test "${CC}" = "clang"
|
||||||
|
then
|
||||||
|
clang_bin=`which clang`
|
||||||
|
# Some systems install clang elsewhere as a symlink to the real path
|
||||||
|
# which is where the related llvm tools are located.
|
||||||
|
if test -L "${clang_bin}"
|
||||||
|
then
|
||||||
|
clang_dir=`dirname "${clang_bin}"`
|
||||||
|
clang_bin=`readlink "${clang_bin}"`
|
||||||
|
llvm_bin_dir="${clang_dir}/"`dirname "${clang_bin}"`
|
||||||
|
llvm_path="${llvm_path}${PATH_SEPARATOR}${llvm_bin_dir}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Extract the first word of "llvm-profdata", so it can be a program name with args.
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking target system type" >&5
|
||||||
set dummy llvm-profdata; ac_word=$2
|
$as_echo_n "checking target system type... " >&6; }
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
|
if ${ac_cv_target+:} false; then :
|
||||||
$as_echo_n "checking for $ac_word... " >&6; }
|
|
||||||
if ${ac_cv_prog_LLVM_PROF_FOUND+:} false; then :
|
|
||||||
$as_echo_n "(cached) " >&6
|
$as_echo_n "(cached) " >&6
|
||||||
else
|
else
|
||||||
if test -n "$LLVM_PROF_FOUND"; then
|
if test "x$target_alias" = x; then
|
||||||
ac_cv_prog_LLVM_PROF_FOUND="$LLVM_PROF_FOUND" # Let the user override the test.
|
ac_cv_target=$ac_cv_host
|
||||||
else
|
else
|
||||||
as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
|
ac_cv_target=`$SHELL "$ac_aux_dir/config.sub" $target_alias` ||
|
||||||
for as_dir in $PATH
|
as_fn_error $? "$SHELL $ac_aux_dir/config.sub $target_alias failed" "$LINENO" 5
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_target" >&5
|
||||||
|
$as_echo "$ac_cv_target" >&6; }
|
||||||
|
case $ac_cv_target in
|
||||||
|
*-*-*) ;;
|
||||||
|
*) as_fn_error $? "invalid value of canonical target" "$LINENO" 5;;
|
||||||
|
esac
|
||||||
|
target=$ac_cv_target
|
||||||
|
ac_save_IFS=$IFS; IFS='-'
|
||||||
|
set x $ac_cv_target
|
||||||
|
shift
|
||||||
|
target_cpu=$1
|
||||||
|
target_vendor=$2
|
||||||
|
shift; shift
|
||||||
|
# Remember, the first character of IFS is used to create $*,
|
||||||
|
# except with old shells:
|
||||||
|
target_os=$*
|
||||||
|
IFS=$ac_save_IFS
|
||||||
|
case $target_os in *\ *) target_os=`echo "$target_os" | sed 's/ /-/g'`;; esac
|
||||||
|
|
||||||
|
|
||||||
|
# The aliases save the names the user supplied, while $host etc.
|
||||||
|
# will get canonicalized.
|
||||||
|
test -n "$target_alias" &&
|
||||||
|
test "$program_prefix$program_suffix$program_transform_name" = \
|
||||||
|
NONENONEs,x,x, &&
|
||||||
|
program_prefix=${target_alias}-
|
||||||
|
# Extract the first word of "$target_alias-llvm-profdata", so it can be a program name with args.
|
||||||
|
set dummy $target_alias-llvm-profdata; ac_word=$2
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
|
||||||
|
$as_echo_n "checking for $ac_word... " >&6; }
|
||||||
|
if ${ac_cv_path_LLVM_PROFDATA+:} false; then :
|
||||||
|
$as_echo_n "(cached) " >&6
|
||||||
|
else
|
||||||
|
case $LLVM_PROFDATA in
|
||||||
|
[\\/]* | ?:[\\/]*)
|
||||||
|
ac_cv_path_LLVM_PROFDATA="$LLVM_PROFDATA" # Let the user override the test with a path.
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
|
||||||
|
for as_dir in ${llvm_path}
|
||||||
do
|
do
|
||||||
IFS=$as_save_IFS
|
IFS=$as_save_IFS
|
||||||
test -z "$as_dir" && as_dir=.
|
test -z "$as_dir" && as_dir=.
|
||||||
for ac_exec_ext in '' $ac_executable_extensions; do
|
for ac_exec_ext in '' $ac_executable_extensions; do
|
||||||
if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
|
if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
|
||||||
ac_cv_prog_LLVM_PROF_FOUND="found"
|
ac_cv_path_LLVM_PROFDATA="$as_dir/$ac_word$ac_exec_ext"
|
||||||
$as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
|
$as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
|
||||||
break 2
|
break 2
|
||||||
fi
|
fi
|
||||||
|
@ -6635,30 +6714,105 @@ done
|
||||||
done
|
done
|
||||||
IFS=$as_save_IFS
|
IFS=$as_save_IFS
|
||||||
|
|
||||||
test -z "$ac_cv_prog_LLVM_PROF_FOUND" && ac_cv_prog_LLVM_PROF_FOUND="not-found"
|
;;
|
||||||
|
esac
|
||||||
fi
|
fi
|
||||||
fi
|
LLVM_PROFDATA=$ac_cv_path_LLVM_PROFDATA
|
||||||
LLVM_PROF_FOUND=$ac_cv_prog_LLVM_PROF_FOUND
|
if test -n "$LLVM_PROFDATA"; then
|
||||||
if test -n "$LLVM_PROF_FOUND"; then
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $LLVM_PROFDATA" >&5
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $LLVM_PROF_FOUND" >&5
|
$as_echo "$LLVM_PROFDATA" >&6; }
|
||||||
$as_echo "$LLVM_PROF_FOUND" >&6; }
|
|
||||||
else
|
else
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
|
||||||
$as_echo "no" >&6; }
|
$as_echo "no" >&6; }
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if test -z "$ac_cv_path_LLVM_PROFDATA"; then
|
||||||
|
if test "$build" = "$target"; then
|
||||||
|
ac_pt_LLVM_PROFDATA=$LLVM_PROFDATA
|
||||||
|
# Extract the first word of "llvm-profdata", so it can be a program name with args.
|
||||||
|
set dummy llvm-profdata; ac_word=$2
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
|
||||||
|
$as_echo_n "checking for $ac_word... " >&6; }
|
||||||
|
if ${ac_cv_path_ac_pt_LLVM_PROFDATA+:} false; then :
|
||||||
|
$as_echo_n "(cached) " >&6
|
||||||
|
else
|
||||||
|
case $ac_pt_LLVM_PROFDATA in
|
||||||
|
[\\/]* | ?:[\\/]*)
|
||||||
|
ac_cv_path_ac_pt_LLVM_PROFDATA="$ac_pt_LLVM_PROFDATA" # Let the user override the test with a path.
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
|
||||||
|
for as_dir in ${llvm_path}
|
||||||
|
do
|
||||||
|
IFS=$as_save_IFS
|
||||||
|
test -z "$as_dir" && as_dir=.
|
||||||
|
for ac_exec_ext in '' $ac_executable_extensions; do
|
||||||
|
if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
|
||||||
|
ac_cv_path_ac_pt_LLVM_PROFDATA="$as_dir/$ac_word$ac_exec_ext"
|
||||||
|
$as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
|
||||||
|
break 2
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
done
|
||||||
|
IFS=$as_save_IFS
|
||||||
|
|
||||||
|
test -z "$ac_cv_path_ac_pt_LLVM_PROFDATA" && ac_cv_path_ac_pt_LLVM_PROFDATA="''"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
ac_pt_LLVM_PROFDATA=$ac_cv_path_ac_pt_LLVM_PROFDATA
|
||||||
|
if test -n "$ac_pt_LLVM_PROFDATA"; then
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_pt_LLVM_PROFDATA" >&5
|
||||||
|
$as_echo "$ac_pt_LLVM_PROFDATA" >&6; }
|
||||||
|
else
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
|
||||||
|
$as_echo "no" >&6; }
|
||||||
|
fi
|
||||||
|
|
||||||
|
LLVM_PROFDATA=$ac_pt_LLVM_PROFDATA
|
||||||
|
else
|
||||||
|
LLVM_PROFDATA="''"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
LLVM_PROFDATA="$ac_cv_path_LLVM_PROFDATA"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if test -n "${LLVM_PROFDATA}" -a -x "${LLVM_PROFDATA}"
|
||||||
|
then
|
||||||
|
LLVM_PROF_FOUND="found"
|
||||||
|
else
|
||||||
|
LLVM_PROF_FOUND="not-found"
|
||||||
|
fi
|
||||||
|
if test "$ac_sys_system" = "Darwin" -a "${LLVM_PROF_FOUND}" = "not-found"
|
||||||
|
then
|
||||||
|
found_llvm_profdata=`/usr/bin/xcrun -find llvm-profdata 2>/dev/null`
|
||||||
|
if test -n "${found_llvm_profdata}"
|
||||||
|
then
|
||||||
|
# llvm-profdata isn't directly in $PATH in some cases.
|
||||||
|
# https://apple.stackexchange.com/questions/197053/
|
||||||
|
LLVM_PROFDATA='/usr/bin/xcrun llvm-profdata'
|
||||||
|
LLVM_PROF_FOUND=found
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: llvm-profdata found via xcrun: ${LLVM_PROFDATA}" >&5
|
||||||
|
$as_echo "$as_me: llvm-profdata found via xcrun: ${LLVM_PROFDATA}" >&6;}
|
||||||
|
fi
|
||||||
|
fi
|
||||||
LLVM_PROF_ERR=no
|
LLVM_PROF_ERR=no
|
||||||
case $CC in
|
case $CC in
|
||||||
*clang*)
|
*clang*)
|
||||||
# Any changes made here should be reflected in the GCC+Darwin case below
|
# Any changes made here should be reflected in the GCC+Darwin case below
|
||||||
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
||||||
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
||||||
LLVM_PROF_MERGER="llvm-profdata merge -output=code.profclangd *.profclangr"
|
LLVM_PROF_MERGER="${LLVM_PROFDATA} merge -output=code.profclangd *.profclangr"
|
||||||
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
||||||
if test $LLVM_PROF_FOUND = not-found
|
if test $LLVM_PROF_FOUND = not-found
|
||||||
then
|
then
|
||||||
LLVM_PROF_ERR=yes
|
LLVM_PROF_ERR=yes
|
||||||
|
if test "${REQUIRE_PGO}" = "yes"
|
||||||
|
then
|
||||||
|
as_fn_error $? "llvm-profdata is required for a --with-optimizations build but could not be found." "$LINENO" 5
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*gcc*)
|
*gcc*)
|
||||||
|
@ -6666,11 +6820,15 @@ case $CC in
|
||||||
Darwin*)
|
Darwin*)
|
||||||
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
||||||
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
||||||
LLVM_PROF_MERGER="llvm-profdata merge -output=code.profclangd *.profclangr"
|
LLVM_PROF_MERGER="${LLVM_PROFDATA} merge -output=code.profclangd *.profclangr"
|
||||||
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
||||||
if test $LLVM_PROF_FOUND = not-found
|
if test "${LLVM_PROF_FOUND}" = "not-found"
|
||||||
then
|
then
|
||||||
LLVM_PROF_ERR=yes
|
LLVM_PROF_ERR=yes
|
||||||
|
if test "${REQUIRE_PGO}" = "yes"
|
||||||
|
then
|
||||||
|
as_fn_error $? "llvm-profdata is required for a --with-optimizations build but could not be found." "$LINENO" 5
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
|
|
55
configure.ac
55
configure.ac
|
@ -1255,9 +1255,11 @@ if test "$Py_OPT" = 'true' ; then
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
DEF_MAKE_ALL_RULE="profile-opt"
|
DEF_MAKE_ALL_RULE="profile-opt"
|
||||||
|
REQUIRE_PGO="yes"
|
||||||
DEF_MAKE_RULE="build_all"
|
DEF_MAKE_RULE="build_all"
|
||||||
else
|
else
|
||||||
DEF_MAKE_ALL_RULE="build_all"
|
DEF_MAKE_ALL_RULE="build_all"
|
||||||
|
REQUIRE_PGO="no"
|
||||||
DEF_MAKE_RULE="all"
|
DEF_MAKE_RULE="all"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -1300,19 +1302,60 @@ AC_SUBST(PGO_PROF_USE_FLAG)
|
||||||
AC_SUBST(LLVM_PROF_MERGER)
|
AC_SUBST(LLVM_PROF_MERGER)
|
||||||
AC_SUBST(LLVM_PROF_FILE)
|
AC_SUBST(LLVM_PROF_FILE)
|
||||||
AC_SUBST(LLVM_PROF_ERR)
|
AC_SUBST(LLVM_PROF_ERR)
|
||||||
|
# Make this work on systems where llvm tools are not installed with their
|
||||||
|
# normal names in the default $PATH (ie: Ubuntu). They exist under the
|
||||||
|
# non-suffixed name in their versioned llvm directory.
|
||||||
|
llvm_bin_dir=''
|
||||||
|
llvm_path="${PATH}"
|
||||||
|
if test "${CC}" = "clang"
|
||||||
|
then
|
||||||
|
clang_bin=`which clang`
|
||||||
|
# Some systems install clang elsewhere as a symlink to the real path
|
||||||
|
# which is where the related llvm tools are located.
|
||||||
|
if test -L "${clang_bin}"
|
||||||
|
then
|
||||||
|
clang_dir=`dirname "${clang_bin}"`
|
||||||
|
clang_bin=`readlink "${clang_bin}"`
|
||||||
|
llvm_bin_dir="${clang_dir}/"`dirname "${clang_bin}"`
|
||||||
|
llvm_path="${llvm_path}${PATH_SEPARATOR}${llvm_bin_dir}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
AC_SUBST(LLVM_PROFDATA)
|
||||||
|
AC_PATH_TARGET_TOOL(LLVM_PROFDATA, llvm-profdata, '', ${llvm_path})
|
||||||
AC_SUBST(LLVM_PROF_FOUND)
|
AC_SUBST(LLVM_PROF_FOUND)
|
||||||
AC_CHECK_PROG(LLVM_PROF_FOUND, llvm-profdata, found, not-found)
|
if test -n "${LLVM_PROFDATA}" -a -x "${LLVM_PROFDATA}"
|
||||||
|
then
|
||||||
|
LLVM_PROF_FOUND="found"
|
||||||
|
else
|
||||||
|
LLVM_PROF_FOUND="not-found"
|
||||||
|
fi
|
||||||
|
if test "$ac_sys_system" = "Darwin" -a "${LLVM_PROF_FOUND}" = "not-found"
|
||||||
|
then
|
||||||
|
found_llvm_profdata=`/usr/bin/xcrun -find llvm-profdata 2>/dev/null`
|
||||||
|
if test -n "${found_llvm_profdata}"
|
||||||
|
then
|
||||||
|
# llvm-profdata isn't directly in $PATH in some cases.
|
||||||
|
# https://apple.stackexchange.com/questions/197053/
|
||||||
|
LLVM_PROFDATA='/usr/bin/xcrun llvm-profdata'
|
||||||
|
LLVM_PROF_FOUND=found
|
||||||
|
AC_MSG_NOTICE([llvm-profdata found via xcrun: ${LLVM_PROFDATA}])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
LLVM_PROF_ERR=no
|
LLVM_PROF_ERR=no
|
||||||
case $CC in
|
case $CC in
|
||||||
*clang*)
|
*clang*)
|
||||||
# Any changes made here should be reflected in the GCC+Darwin case below
|
# Any changes made here should be reflected in the GCC+Darwin case below
|
||||||
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
||||||
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
||||||
LLVM_PROF_MERGER="llvm-profdata merge -output=code.profclangd *.profclangr"
|
LLVM_PROF_MERGER="${LLVM_PROFDATA} merge -output=code.profclangd *.profclangr"
|
||||||
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
||||||
if test $LLVM_PROF_FOUND = not-found
|
if test $LLVM_PROF_FOUND = not-found
|
||||||
then
|
then
|
||||||
LLVM_PROF_ERR=yes
|
LLVM_PROF_ERR=yes
|
||||||
|
if test "${REQUIRE_PGO}" = "yes"
|
||||||
|
then
|
||||||
|
AC_MSG_ERROR([llvm-profdata is required for a --with-optimizations build but could not be found.])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*gcc*)
|
*gcc*)
|
||||||
|
@ -1320,11 +1363,15 @@ case $CC in
|
||||||
Darwin*)
|
Darwin*)
|
||||||
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
PGO_PROF_GEN_FLAG="-fprofile-instr-generate"
|
||||||
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
PGO_PROF_USE_FLAG="-fprofile-instr-use=code.profclangd"
|
||||||
LLVM_PROF_MERGER="llvm-profdata merge -output=code.profclangd *.profclangr"
|
LLVM_PROF_MERGER="${LLVM_PROFDATA} merge -output=code.profclangd *.profclangr"
|
||||||
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
LLVM_PROF_FILE="LLVM_PROFILE_FILE=\"code-%p.profclangr\""
|
||||||
if test $LLVM_PROF_FOUND = not-found
|
if test "${LLVM_PROF_FOUND}" = "not-found"
|
||||||
then
|
then
|
||||||
LLVM_PROF_ERR=yes
|
LLVM_PROF_ERR=yes
|
||||||
|
if test "${REQUIRE_PGO}" = "yes"
|
||||||
|
then
|
||||||
|
AC_MSG_ERROR([llvm-profdata is required for a --with-optimizations build but could not be found.])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
|
|
Loading…
Reference in New Issue