@@ -18,7 +18,6 @@ set -o pipefail
1818
1919MONOREPO_ROOT=" ${MONOREPO_ROOT:= " $( git rev-parse --show-toplevel) " } "
2020BUILD_DIR=" ${BUILD_DIR:= ${MONOREPO_ROOT} / build} "
21- INSTALL_DIR=" ${BUILD_DIR} /install"
2221rm -rf " ${BUILD_DIR} "
2322
2423ccache --zero-stats
@@ -28,10 +27,14 @@ if [[ -n "${CLEAR_CACHE:-}" ]]; then
2827 ccache --clear
2928fi
3029
30+ mkdir -p artifacts/reproducers
31+
32+ # Make sure any clang reproducers will end up as artifacts.
33+ export CLANG_CRASH_DIAGNOSTICS_DIR=` realpath artifacts/reproducers`
34+
3135function at-exit {
3236 retcode=$?
3337
34- mkdir -p artifacts
3538 ccache --print-stats > artifacts/ccache_stats.txt
3639 cp " ${BUILD_DIR} " /.ninja_log artifacts/.ninja_log
3740
@@ -50,17 +53,28 @@ trap at-exit EXIT
5053
5154projects=" ${1} "
5255targets=" ${2} "
56+ runtimes=" ${3} "
5357
5458lit_args=" -v --xunit-xml-output ${BUILD_DIR} /test-results.xml --use-unique-output-file-name --timeout=1200 --time-tests"
5559
5660echo " --- cmake"
61+
5762export PIP_BREAK_SYSTEM_PACKAGES=1
5863pip install -q -r " ${MONOREPO_ROOT} " /mlir/python/requirements.txt
5964pip install -q -r " ${MONOREPO_ROOT} " /lldb/test/requirements.txt
6065pip install -q -r " ${MONOREPO_ROOT} " /.ci/requirements.txt
66+
67+ # Set the system llvm-symbolizer as preferred.
68+ export LLVM_SYMBOLIZER_PATH=` which llvm-symbolizer`
69+ [[ ! -f " ${LLVM_SYMBOLIZER_PATH} " ]] && echo " llvm-symbolizer not found!"
70+
71+ # Set up all runtimes either way. libcxx is a dependency of LLDB.
72+ # If it ends up being unused, not much harm.
6173cmake -S " ${MONOREPO_ROOT} " /llvm -B " ${BUILD_DIR} " \
6274 -D LLVM_ENABLE_PROJECTS=" ${projects} " \
75+ -D LLVM_ENABLE_RUNTIMES=" libcxx;libcxxabi;libunwind" \
6376 -G Ninja \
77+ -D CMAKE_PREFIX_PATH=" ${HOME} /.local" \
6478 -D CMAKE_BUILD_TYPE=Release \
6579 -D LLVM_ENABLE_ASSERTIONS=ON \
6680 -D LLVM_BUILD_EXAMPLES=ON \
@@ -69,69 +83,47 @@ cmake -S "${MONOREPO_ROOT}"/llvm -B "${BUILD_DIR}" \
6983 -D LLVM_ENABLE_LLD=ON \
7084 -D CMAKE_CXX_FLAGS=-gmlt \
7185 -D LLVM_CCACHE_BUILD=ON \
86+ -D LIBCXX_CXX_ABI=libcxxabi \
7287 -D MLIR_ENABLE_BINDINGS_PYTHON=ON \
73- -D CMAKE_INSTALL_PREFIX=" ${INSTALL_DIR} "
88+ -D LLDB_ENABLE_PYTHON=ON \
89+ -D LLDB_ENFORCE_STRICT_TEST_REQUIREMENTS=ON
7490
7591echo " --- ninja"
92+
7693# Targets are not escaped as they are passed as separate arguments.
7794ninja -C " ${BUILD_DIR} " -k 0 ${targets}
7895
79- runtimes=" ${3} "
8096runtime_targets=" ${4} "
8197
82- # Compiling runtimes with just-built Clang and running their tests
83- # as an additional testing for Clang.
98+ # Run runtimes tests.
99+ # We don't need to do a clean separate build of runtimes, because runtimes
100+ # will be built against just built clang, and because LIBCXX_TEST_PARAMS
101+ # and LIBCXXABI_TEST_PARAMS only affect lit configuration, which successfully
102+ # propagates without a clean build. Other that those two variables, builds
103+ # are supposed to be the same.
84104if [[ " ${runtimes} " != " " ]]; then
85105 if [[ " ${runtime_targets} " == " " ]]; then
86106 echo " Runtimes to build are specified, but targets are not."
87107 exit 1
88108 fi
89109
90- echo " --- ninja install-clang"
91-
92- ninja -C ${BUILD_DIR} install-clang install-clang-resource-headers
93-
94- RUNTIMES_BUILD_DIR=" ${MONOREPO_ROOT} /build-runtimes"
95- INSTALL_DIR=" ${BUILD_DIR} /install"
96- mkdir -p ${RUNTIMES_BUILD_DIR}
97-
98110 echo " --- cmake runtimes C++26"
99111
100- rm -rf " ${RUNTIMES_BUILD_DIR} "
101- cmake -S " ${MONOREPO_ROOT} /runtimes" -B " ${RUNTIMES_BUILD_DIR} " -GNinja \
102- -D CMAKE_C_COMPILER=" ${INSTALL_DIR} /bin/clang" \
103- -D CMAKE_CXX_COMPILER=" ${INSTALL_DIR} /bin/clang++" \
104- -D LLVM_ENABLE_RUNTIMES=" ${runtimes} " \
105- -D LIBCXX_CXX_ABI=libcxxabi \
106- -D CMAKE_BUILD_TYPE=RelWithDebInfo \
107- -D CMAKE_INSTALL_PREFIX=" ${INSTALL_DIR} " \
112+ cmake -S " ${MONOREPO_ROOT} " /llvm -B " ${BUILD_DIR} " \
108113 -D LIBCXX_TEST_PARAMS=" std=c++26" \
109- -D LIBCXXABI_TEST_PARAMS=" std=c++26" \
110- -D LLVM_LIT_ARGS=" ${lit_args} "
114+ -D LIBCXXABI_TEST_PARAMS=" std=c++26"
111115
112116 echo " --- ninja runtimes C++26"
113117
114- ninja -vC " ${RUNTIMES_BUILD_DIR } " ${runtime_targets}
118+ ninja -vC " ${BUILD_DIR } " ${runtime_targets}
115119
116120 echo " --- cmake runtimes clang modules"
117121
118- # We don't need to do a clean build of runtimes, because LIBCXX_TEST_PARAMS
119- # and LIBCXXABI_TEST_PARAMS only affect lit configuration, which successfully
120- # propagates without a clean build. Other that those two variables, builds
121- # are supposed to be the same.
122-
123- cmake -S " ${MONOREPO_ROOT} /runtimes" -B " ${RUNTIMES_BUILD_DIR} " -GNinja \
124- -D CMAKE_C_COMPILER=" ${INSTALL_DIR} /bin/clang" \
125- -D CMAKE_CXX_COMPILER=" ${INSTALL_DIR} /bin/clang++" \
126- -D LLVM_ENABLE_RUNTIMES=" ${runtimes} " \
127- -D LIBCXX_CXX_ABI=libcxxabi \
128- -D CMAKE_BUILD_TYPE=RelWithDebInfo \
129- -D CMAKE_INSTALL_PREFIX=" ${INSTALL_DIR} " \
122+ cmake -S " ${MONOREPO_ROOT} " /llvm -B " ${BUILD_DIR} " \
130123 -D LIBCXX_TEST_PARAMS=" enable_modules=clang" \
131- -D LIBCXXABI_TEST_PARAMS=" enable_modules=clang" \
132- -D LLVM_LIT_ARGS=" ${lit_args} "
124+ -D LIBCXXABI_TEST_PARAMS=" enable_modules=clang"
133125
134126 echo " --- ninja runtimes clang modules"
135127
136- ninja -vC " ${RUNTIMES_BUILD_DIR } " ${runtime_targets}
128+ ninja -vC " ${BUILD_DIR } " ${runtime_targets}
137129fi
0 commit comments