Stream: git-wasmtime

Topic: wasmtime / issue #1164 Cranelift: provide a C API


view this post on Zulip Wasmtime GitHub notifications bot (May 04 2022 at 22:27):

cfallin edited issue #1164:

What I'd like to see is a way to use Cranelift apis from another (non rust) language. Currently the cranelift apis are rust only, but having a layer on top of that like "llvm-c" is, would make the cranelift api usable from all languages, and thus a much wider range of compilers could use it as a backend.

view this post on Zulip Wasmtime GitHub notifications bot (Oct 17 2022 at 05:48):

rishavs commented on issue #1164:

Is this likely to happen? I'd really like to try out cranelift for my toy language, but the lack of a simple c api will mean that I will have to stick with llvm instead.

view this post on Zulip Wasmtime GitHub notifications bot (Oct 17 2022 at 06:00):

cfallin commented on issue #1164:

I personally think it would be nice to have this, but it's not a small task to build, and no one currently has the time to do it. If you (or anyone) would like to contribute this, we'd be happy to talk further -- the first step would probably be gathering feedback in an RFC.

view this post on Zulip Wasmtime GitHub notifications bot (Oct 24 2022 at 07:11):

rishavs commented on issue #1164:

This is way out of my league so likely a stupid question; but if I build a so/dll of all the cranelift crates like cranelift = "0.89.0" using cargo, can I use this .so file in other languages which support FFI?

view this post on Zulip Wasmtime GitHub notifications bot (Oct 24 2022 at 07:51):

bjorn3 commented on issue #1164:

No, rust's ABI is not stable, so you can't call any of the methods in this dylib. You have to write a C interface for every function you want to call from non-rust code and then use this C interface.

view this post on Zulip Wasmtime GitHub notifications bot (Oct 24 2022 at 19:46):

cfallin commented on issue #1164:

This is way out of my league so likely a stupid question; but if I build a so/dll of all the cranelift crates like cranelift = "0.89.0" using cargo, can I use this .so file in other languages which support FFI?

To add a little more nuance: (i) Rust does have the ability to produce .sos that can be called with a C ABI; but (ii) that requires explicit work, in defining the C-ABI-compatible exports (#[no_mangle] and extern "C" fn are the relevant search terms, as well as care about data structure layout and use of #[repr(C)] on structs where needed).

view this post on Zulip Wasmtime GitHub notifications bot (Mar 19 2024 at 04:34):

tgross35 commented on issue #1164:

Is there a place for a C API in-tree, or is that solidly out of scope?

@coffeebe4code did some reworking of @carlokok's gist, https://github.com/coffeebe4code/craneliftc. If the methodology looks correct enough, that could likely be a reasonable starting point.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 19 2024 at 04:34):

tgross35 edited a comment on issue #1164:

Is there a place for a C API in-tree, or is that solidly out of scope for the time being?

@coffeebe4code did some reworking of @carlokok's gist, https://github.com/coffeebe4code/craneliftc. If the methodology looks correct enough, that could likely be a reasonable starting point.


Last updated: Jan 24 2025 at 00:11 UTC