Skip to content

Commit 7151916

Browse files
committed
General improvements to Emscripten llvm build
1 parent 7a65d6c commit 7151916

File tree

3 files changed

+19
-113
lines changed

3 files changed

+19
-113
lines changed

.github/workflows/emscripten.yml

Lines changed: 15 additions & 113 deletions
Original file line numberDiff line numberDiff line change
@@ -21,25 +21,22 @@ jobs:
2121
fail-fast: false
2222
matrix:
2323
include:
24-
- name: ubu24-arm-gcc12-clang-repl-19-emscripten
24+
- name: ubu24-arm-clang-repl-19-emscripten
2525
os: ubuntu-24.04-arm
26-
compiler: gcc-12
2726
clang-runtime: '19'
2827
cling: Off
2928
llvm_enable_projects: "clang;lld"
3029
llvm_targets_to_build: "WebAssembly"
3130
emsdk_ver: "3.1.73"
32-
- name: osx15-arm-clang-clang-repl-19-emscripten
31+
- name: osx15-arm-clang-repl-19-emscripten
3332
os: macos-15
34-
compiler: clang
3533
clang-runtime: '19'
3634
cling: Off
3735
llvm_enable_projects: "clang;lld"
3836
llvm_targets_to_build: "WebAssembly"
3937
emsdk_ver: "3.1.73"
40-
- name: ubu24-x86-gcc12-clang-repl-19-emscripten
38+
- name: ubu24-x86-clang-repl-19-emscripten
4139
os: ubuntu-24.04
42-
compiler: gcc-12
4340
clang-runtime: '19'
4441
cling: Off
4542
llvm_enable_projects: "clang;lld"
@@ -112,7 +109,7 @@ jobs:
112109
path: |
113110
llvm-project
114111
${{ matrix.cling=='On' && 'cling' || '' }}
115-
key: ${{ env.CLING_HASH }}-${{ runner.os }}-${{ matrix.os }}-${{ matrix.compiler }}-clang-${{ matrix.clang-runtime }}.x-emscripten
112+
key: ${{ env.CLING_HASH }}-${{ runner.os }}-${{ matrix.os }}-clang-${{ matrix.clang-runtime }}.x-emscripten
116113
lookup-only: true
117114

118115
- name: Setup emsdk
@@ -127,12 +124,6 @@ jobs:
127124
run: |
128125
echo "BUILD_TYPE=Release" >> $GITHUB_ENV
129126
echo "CODE_COVERAGE=0" >> $GITHUB_ENV
130-
os="${{ matrix.os }}"
131-
if [[ "${os}" == "macos"* ]]; then
132-
echo "ncpus=$(sysctl -n hw.ncpu)" >> $GITHUB_ENV
133-
else
134-
echo "ncpus=$(nproc --all)" >> $GITHUB_ENV
135-
fi
136127
137128
- name: Setup default Build Type on Windows
138129
if: ${{ runner.os == 'windows' && steps.cache.outputs.cache-hit != 'true' }}
@@ -142,92 +133,6 @@ jobs:
142133
$env:ncpus=$([Environment]::ProcessorCount)
143134
echo "ncpus=$env:ncpus" >> $env:GITHUB_ENV
144135
145-
- name: Setup compiler on Linux
146-
if: ${{ runner.os == 'Linux' && steps.cache.outputs.cache-hit != 'true' }}
147-
run: |
148-
# https://www.gnu.org/software/bash/manual/html_node/Shell-Parameter-Expansion.html
149-
vers="${compiler#*-}"
150-
os_codename="`cat /etc/os-release | grep UBUNTU_CODENAME | cut -d = -f 2`"
151-
##sudo apt update
152-
if [[ "${{ matrix.compiler }}" == *"gcc"* ]]; then
153-
sudo apt install -y gcc-${vers} g++-${vers} lld
154-
echo "CC=gcc-${vers}" >> $GITHUB_ENV
155-
echo "CXX=g++-${vers}" >> $GITHUB_ENV
156-
else
157-
if ! sudo apt install -y clang-${vers}; then
158-
curl https://apt.llvm.org/llvm-snapshot.gpg.key | sudo apt-key add -
159-
echo "deb https://apt.llvm.org/${os_codename}/ llvm-toolchain-${os_codename}-${vers} main" | sudo tee -a /etc/apt/sources.list
160-
sudo apt-get update
161-
sudo apt-get install -y clang-${vers}
162-
fi
163-
echo "CC=clang-${vers}" >> $GITHUB_ENV
164-
echo "CXX=clang++-${vers}" >> $GITHUB_ENV
165-
fi
166-
env:
167-
compiler: ${{ matrix.compiler }}
168-
169-
- name: Setup compiler on macOS
170-
if: ${{ runner.os == 'macOS' && steps.cache.outputs.cache-hit != 'true' }}
171-
run: |
172-
vers="${compiler#*-}"
173-
if [[ "${{ matrix.compiler }}" == *"gcc"* ]]; then
174-
brew install "gcc@$vers"
175-
echo "CC=gcc-${vers}" >> $GITHUB_ENV
176-
echo "CXX=g++-${vers}" >> $GITHUB_ENV
177-
else
178-
export ARCHITECHURE=$(uname -m)
179-
if [[ "$ARCHITECHURE" == "arm64" ]]; then
180-
cling_on=$(echo "${{ matrix.cling }}" | tr '[:lower:]' '[:upper:]')
181-
if [[ "${cling_on}" == "ON" ]]; then
182-
brew install llvm@15
183-
brew remove llvm@18
184-
brew cleanup
185-
#FIXME: Do not believe setting all these environment variables are necessary
186-
# They were set to avoid using Xcodes libc++ and to stop CppInterOp using llvm@18 in tests
187-
echo 'LDFLAGS="-L/opt/homebrew/opt/llvm@15/lib/ -L/opt/homebrew/opt/llvm@15/c++/"' >> $GITHUB_ENV
188-
echo 'CPPFLAGS="-I/opt/homebrew/opt/llvm@15/include"' >> $GITHUB_ENV
189-
echo 'CPATH="/opt/homebrew/include/"' >> $GITHUB_ENV
190-
echo 'LIBRARY_PATH="/opt/homebrew/lib/"' >> $GITHUB_ENV
191-
echo "CC=$(brew --prefix llvm@15)/bin/clang" >> $GITHUB_ENV
192-
echo "CXX=$(brew --prefix llvm@15)/bin/clang++" >> $GITHUB_ENV
193-
else
194-
echo "CC=$(brew --prefix llvm@18)/bin/clang" >> $GITHUB_ENV
195-
echo "CXX=$(brew --prefix llvm@18)/bin/clang++" >> $GITHUB_ENV
196-
fi
197-
else
198-
echo "CC=$(brew --prefix llvm@15)/bin/clang" >> $GITHUB_ENV
199-
echo "CXX=$(brew --prefix llvm@15)/bin/clang++" >> $GITHUB_ENV
200-
fi
201-
fi
202-
echo "SDKROOT=$(xcrun --sdk macosx --show-sdk-path)" >> $GITHUB_ENV
203-
env:
204-
compiler: ${{ matrix.compiler }}
205-
206-
#Section slightly modified version of
207-
#https://github.com/vgvassilev/clad/blob/40d8bec11bde47b14a281078183a4f6147abeac5/.github/workflows/ci.yml#L510C1-L534C10
208-
- name: Setup compiler on Windows
209-
if: ${{ runner.os == 'windows' && steps.cache.outputs.cache-hit != 'true' }}
210-
run: |
211-
if ( "${{ matrix.compiler }}" -imatch "clang" )
212-
{
213-
$ver="${{ matrix.compiler }}".split("-")[1]
214-
choco install llvm --version=$ver --no-progress -my
215-
clang --version
216-
#
217-
$env:CC="clang"
218-
$env:CXX="clang++"
219-
echo "CC=clang" >> $env:GITHUB_ENV
220-
echo "CXX=clang++" >> $env:GITHUB_ENV
221-
}
222-
elseif ( "${{ matrix.compiler }}" -imatch "msvc" )
223-
{
224-
# MSVC is builtin in container image
225-
}
226-
else
227-
{
228-
echo "Unsupported compiler - fix YAML file"
229-
}
230-
231136
- name: Install deps on Windows
232137
if: ${{ runner.os == 'windows' && steps.cache.outputs.cache-hit != 'true' }}
233138
run: |
@@ -299,8 +204,10 @@ jobs:
299204
-DLLVM_INCLUDE_TESTS=OFF \
300205
-DLLVM_ENABLE_THREADS=OFF \
301206
-G Ninja \
207+
-DLLVM_BUILD_TOOLS=OFF \
208+
-DLLVM_ENABLE_LIBPFM=OFF \
302209
../llvm
303-
emmake ninja clang cling lld gtest_main -j ${{ env.ncpus }}
210+
emmake ninja clang cling lld gtest_main
304211
else
305212
# Apply patches
306213
llvm_vers=$(echo "${{ matrix.clang-runtime }}" | tr '[:lower:]' '[:upper:]')
@@ -325,10 +232,13 @@ jobs:
325232
-DLLVM_INCLUDE_EXAMPLES=OFF \
326233
-DLLVM_INCLUDE_TESTS=OFF \
327234
-DLLVM_ENABLE_THREADS=OFF \
235+
-DLLVM_BUILD_TOOLS=OFF \
236+
-DLLVM_ENABLE_LIBPFM=OFF \
328237
-G Ninja \
329238
../llvm
330-
emmake ninja libclang clangInterpreter clangStaticAnalyzerCore lldWasm -j ${{ env.ncpus }}
239+
emmake ninja libclang clangInterpreter clangStaticAnalyzerCore lldWasm
331240
fi
241+
rm -rf ./NATIVE/
332242
cd ../
333243
rm -rf $(find . -maxdepth 1 ! -name "build" ! -name "llvm" ! -name "clang" ! -name ".")
334244
if [[ "${cling_on}" == "ON" ]]; then
@@ -457,23 +367,20 @@ jobs:
457367
fail-fast: false
458368
matrix:
459369
include:
460-
- name: ubu24-x86-gcc12-clang-repl-19-emscripten_wasm
370+
- name: ubu24-x86-clang-repl-19-emscripten_wasm
461371
os: ubuntu-24.04
462-
compiler: gcc-12
463372
clang-runtime: '19'
464373
cling: Off
465374
micromamba_shell_init: bash
466375
emsdk_ver: "3.1.73"
467-
- name: osx15-arm-clang-clang-repl-19-emscripten_wasm
376+
- name: osx15-arm-clang-repl-19-emscripten_wasm
468377
os: macos-15
469-
compiler: clang
470378
clang-runtime: '19'
471379
cling: Off
472380
micromamba_shell_init: bash
473381
emsdk_ver: "3.1.73"
474-
- name: ubu24-arm-gcc12-clang-repl-19-emscripten_wasm
382+
- name: ubu24-arm-clang-repl-19-emscripten_wasm
475383
os: ubuntu-24.04-arm
476-
compiler: gcc-12
477384
clang-runtime: '19'
478385
cling: Off
479386
micromamba_shell_init: bash
@@ -484,11 +391,6 @@ jobs:
484391
with:
485392
fetch-depth: 0
486393

487-
- name: Set up Python
488-
uses: actions/setup-python@v5
489-
with:
490-
python-version: '3.11'
491-
492394
- name: Save PR Info on Unix systems
493395
if: ${{ runner.os != 'windows' }}
494396
run: |
@@ -542,7 +444,7 @@ jobs:
542444
path: |
543445
llvm-project
544446
${{ matrix.cling=='On' && 'cling' || '' }}
545-
key: ${{ env.CLING_HASH }}-${{ runner.os }}-${{ matrix.os }}-${{ matrix.compiler }}-clang-${{ matrix.clang-runtime }}.x-emscripten
447+
key: ${{ env.CLING_HASH }}-${{ runner.os }}-${{ matrix.os }}-clang-${{ matrix.clang-runtime }}.x-emscripten
546448

547449
- name: Emscripten build of CppInterOp on Unix systems
548450
if: ${{ runner.os != 'windows' }}

Emscripten-build-instructions.md

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -69,6 +69,8 @@ emcmake cmake -DCMAKE_BUILD_TYPE=Release \
6969
-DLLVM_INCLUDE_EXAMPLES=OFF \
7070
-DLLVM_INCLUDE_TESTS=OFF \
7171
-DLLVM_ENABLE_THREADS=OFF \
72+
-DLLVM_BUILD_TOOLS=OFF \
73+
-DLLVM_ENABLE_LIBPFM=OFF \
7274
../llvm
7375
emmake make libclang -j $(nproc --all)
7476
emmake make clangInterpreter clangStaticAnalyzerCore -j $(nproc --all)

docs/Emscripten-build-instructions.rst

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -85,6 +85,8 @@ executing the following
8585
-DLLVM_INCLUDE_EXAMPLES=OFF \
8686
-DLLVM_INCLUDE_TESTS=OFF \
8787
-DLLVM_ENABLE_THREADS=OFF \
88+
-DLLVM_BUILD_TOOLS=OFF \
89+
-DLLVM_ENABLE_LIBPFM=OFF \
8890
../llvm
8991
emmake make libclang -j $(nproc --all)
9092
emmake make clangInterpreter clangStaticAnalyzerCore -j $(nproc --all)

0 commit comments

Comments
 (0)