Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

LLVM 18 #123

Merged
merged 36 commits into from
Mar 12, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
bd60141
gh: bump code version
csegarragonz Feb 9, 2024
1158e8b
faasmtools: bump llvm version
csegarragonz Feb 9, 2024
2aa9661
llvm: changes for latest wasi-libc and wasi-sdk
csegarragonz Feb 12, 2024
6afffa4
llvm: install libclang_rt.builitins-wasm32.a
csegarragonz Feb 13, 2024
9969423
cmake: change system name from Wasm to WASI to align with wasi-sdk
csegarragonz Feb 13, 2024
a61d8b0
faasmtools: enable linker feature sign extension as it is the default…
csegarragonz Feb 13, 2024
852fc4a
libs: install in <sysroot>/lib/wasm32-wasi and copy imports appropria…
csegarragonz Feb 13, 2024
53f6567
docker: enable some features
csegarragonz Feb 13, 2024
4c65d67
libs: install libraries and headers in the right location
csegarragonz Feb 13, 2024
29403d4
llvm: fix libclanv_rt.builitins installation
csegarragonz Feb 13, 2024
f7fe16b
mpi: more fixes to the cmake file
csegarragonz Feb 13, 2024
65cc765
wasi: attempt at having two different targets for threads and non-thr…
csegarragonz Feb 13, 2024
0f0125d
func: comment out temporarily disabled functions
csegarragonz Feb 15, 2024
4242785
func: move threaded functions to separate top-level directory
csegarragonz Feb 16, 2024
d69921e
tasks: configurable compilation for different targets
csegarragonz Feb 16, 2024
47be01e
threads: support for pthread apis
csegarragonz Feb 16, 2024
0b67978
cpython: changes to make cpython build work
csegarragonz Feb 19, 2024
022ab93
llvm: add c compiler target flag for compiler-rt build
csegarragonz Feb 19, 2024
eaaf4d5
libs: fix use of (auto)conf with different sysroots
csegarragonz Feb 19, 2024
6cf9946
more fixes
csegarragonz Feb 19, 2024
ca0d78e
faasmtools: change default target when building a threaded application
csegarragonz Feb 20, 2024
2ca4ee6
llvm: bump to version 18 rc2 to fix the frontend bug with openmp
csegarragonz Feb 20, 2024
17e844e
llvm: no harm in using clang-18 to build llvm-18
csegarragonz Feb 20, 2024
676ce38
llvm: use clang-17 for native compilation
csegarragonz Feb 20, 2024
5a2ec10
nits: fix python formatting
csegarragonz Feb 20, 2024
c785471
nits: fix cpp formatting
csegarragonz Feb 20, 2024
1460297
nit: run python formatting
csegarragonz Feb 21, 2024
4b6e62f
func: build all threads func
csegarragonz Feb 21, 2024
27aae15
gha: skip code formatting with clang-format-17
csegarragonz Feb 21, 2024
89c98da
clang-format: fix formatting after llvm bump
csegarragonz Mar 1, 2024
8d5c4a9
nits: clang-format passing with llvm 17
csegarragonz Mar 4, 2024
e42390a
tasks(libs): build threads/non-threads in different directories
csegarragonz Mar 5, 2024
bfad3a8
docker: fix strange libfaasm overwrite
csegarragonz Mar 5, 2024
731744f
funcs: set the threads target when appropriate
csegarragonz Mar 5, 2024
1e23e89
nits: self-review
csegarragonz Mar 12, 2024
16b97f2
libffi: fix build by passing --host flag to configure
csegarragonz Mar 12, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
more fixes
  • Loading branch information
csegarragonz committed Feb 19, 2024
commit 6cf99463223b22c274314b22304578bbfdaf7309
14 changes: 6 additions & 8 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,12 @@ on:
branches: [main]
types: [opened, synchronize, reopened, ready_for_review]

jobs:
# Cancel previous running actions for the same PR
cancel_previous:
runs-on: ubuntu-latest
steps:
- name: Cancel Workflow Action
uses: styfle/cancel-workflow-action@0.11.0
# Cancel previous running actions for the same PR
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}

jobs:
checks:
if: github.event.pull_request.draft == false
runs-on: ubuntu-latest
Expand All @@ -26,7 +24,7 @@ jobs:
steps:
# --- Update code ---
- name: "Checkout code"
uses: actions/checkout@v3
uses: actions/checkout@v4
with:
submodules: true
# See actions/checkout#766
Expand Down
6 changes: 1 addition & 5 deletions docker/cpp-sysroot.dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -42,13 +42,9 @@ RUN cd /code/cpp \
libfaasmpi --native --shared \
# Install toolchain files
&& inv install \
# Temporarily using llvm --clean as we debug new versions of the toolchain
# to avoid having to re-build the base image
# TODO: remove me
&& inv llvm --clean \
# Build wasi-libc and reset the sysroot. The second call to LLVM just
# installs some headers that are purged
# && inv llvm.libc --purge llvm \
&& inv llvm.libc --purge llvm \
# Build Faasm WASM libraries
&& inv \
libemscripten \
Expand Down
12 changes: 11 additions & 1 deletion docs/upgrade-llvm.md → docs/llvm.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,14 @@
# Upgrading LLVM
# LLVM

We use LLVM to cross-compile C and C++ code to WebAssembly. Our
cross-compilation toolchain consists of a home-built LLVM suite (`clang` and
co.) targetting WebAssembly, together with a sysroot with a set of standard
libraries to link against so that we can cross-compile meaningful applications
(most notably `libc` through [`wasi-libc`](
https://github.com/faasm/wasi-libc).

To this extent, our set-up is very similar to that of [`wasi-sdk`](
https://github.com/WebAssembly/wasi-sdk).

To upgrade the underlying LLVM version you need to:

Expand Down
12 changes: 4 additions & 8 deletions func/demo/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,7 @@ demo_func(fstat fstat.cpp)
demo_func(getcwd getcwd.cpp)
demo_func(getdents getdents.cpp)
demo_func(getenv getenv.cpp)
# FIXME: need pwd.h
# demo_func(getpwuid getpwuid.cpp)
demo_func(getpwuid getpwuid.cpp)
demo_func(gettime gettime.cpp)
demo_func(heap heap.cpp)
demo_func(hello hello.cpp)
Expand Down Expand Up @@ -92,12 +91,10 @@ demo_func(time time.cpp)
demo_func(time_of_day time_of_day.cpp)
demo_func(uname uname.cpp)
demo_func(va_arg va_arg.cpp)
# TODO: needs sys/wait.h
# demo_func(waitpid waitpid.cpp)
demo_func(waitpid waitpid.cpp)
demo_func(x2 x2.cpp)
demo_func(zygote_check zygote_check.cpp)

# 23/09/2020 - removing simd
# WASM-only functions
if (CMAKE_SYSTEM_NAME STREQUAL "WASI")
demo_func(emscripten_check emscripten_check.cpp)
Expand All @@ -109,9 +106,8 @@ if (CMAKE_SYSTEM_NAME STREQUAL "WASI")
# target_link_libraries(blas_check ${FAASM_BLAS_LIBS})
endif()

# FIXME: needs pwd.h
# faasm_dynamic_func(dynlink dynlink.cpp)
# set(ALL_DEMO_FUNCS ${ALL_DEMO_FUNCS} dynlink)
faasm_dynamic_func(dynlink dynlink.cpp)
set(ALL_DEMO_FUNCS ${ALL_DEMO_FUNCS} dynlink)

# Custom target to group all the demo functions
add_custom_target(demo_all_funcs DEPENDS ${ALL_DEMO_FUNCS})
Expand Down
17 changes: 17 additions & 0 deletions libfaasmp/z_Linux_asm_csg.S
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
.data
.global .gomp_critical_user_
.global .gomp_critical_user_.var
.global .gomp_critical_user_.reduction.var
.global __kmp_unnamed_critical_addr
.gomp_critical_user_:
.zero 4
.size .gomp_critical_user_, 4
.gomp_critical_user_.var:
.zero 4
.size .gomp_critical_user_.var, 4
.gomp_critical_user_.reduction.var:
.zero 4
.size .gomp_critical_user_.reduction.var, 4
__kmp_unnamed_critical_addr:
.4byte .gomp_critical_user_
.size __kmp_unnamed_critical_addr, 4
2 changes: 1 addition & 1 deletion tasks/libfaasmp.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,4 @@ def build(ctx, clean=False, native=False, shared=False):
"""
Builds Faasm OpenMP library
"""
build_faasm_lib("libfaasmp", clean=clean, native=native, shared=shared)
build_faasm_lib("libfaasmp", clean=clean, native=native, shared=shared, threads=True)
Loading