It seems I found a roadblock for implementing the sock_connect proposal. I am getting this:
error: proc macro panicked
--> crates/wasi/src/lib.rs:9:1
|
9 | wig::define_wasi_struct_for_wiggle!("phases/snapshot/witx/wasi_snapshot_preview1.witx");
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
= help: message: unsupported argument type
Which after some tracking seems to be because of this function signature:
;;; Initiate a connection on a socket to the specified address
;;; Note: This is similar to `connect` in POSIX
(@interface func (export "sock_connect")
;;; Socket descriptor
(param $fd $fd)
;;; Address of the local socket (ex '/dev/tmp')
(param $addr $addr)
(result $error $errno)
)
$addr
is a union of three different structs.
;;; Union of all possible addresses type
(typename $addr
(union $addr_type
(field $local $addr_local)
(field $ip4 $addr_ip4_port)
(field $ip6 $addr_ip6_port)
)
)
I'm afraid that I am not knowledgable enough to implement support for that. Can somebody help me out?
@Dan Gohman @Alex Crichton @Pat Hickey @Jakub Konka
@Emiliano Lesende for know struct-by-value isn't supported, so you'll want to put it behind a pointer indirection
e.g. pass a pointer to the sockaddr
That would be (@witx pointer $addr)
right?
I believe so yeah
Thank you @Alex Crichton
it looks like this is a minor issue in the wig
crate, which is the adapter between wasmtime and wiggle. I think the fix is: diff --git a/crates/wasi-common/wig/src/wasi.rs b/crates/wasi-common/wig/src/wasi.rs
index 579e6f3ca..80f7f2f90 100644
--- a/crates/wasi-common/wig/src/wasi.rs
+++ b/crates/wasi-common/wig/src/wasi.rs
@@ -155,7 +155,7 @@ pub fn define_struct(args: TokenStream) -> TokenStream {
}
witx::Type::Struct(_) | witx::Type::Union(_) => {
wiggle believes that structs and unions are valid to pass "by value" and automatically expects them to be behind a pointer
so using a param type of $addr should be equivelant to (@witx const_pointer $addr)
we pass structs by value in other uses of wiggle over in lucet-land, anyway
this is the idea of the func.core_type()
method in witx.
(also, sorry, zulip didnt show me the rest of this discussion before i replied)
Thanks @Pat Hickey. I already converted the param to a pointer.
cool. in the long run, we want to get rid of @witx pointer and const_pointer completely
since that sort of idea isnt really part of interface types
so its better to avoid them now for everywhere theyre not absolutely necessary
but if it doesnt hurt and it keeps you moving, then go for it.
Yeah, for background here, the reason you don't see any examples of pointer-to-aggregate parameters in WASI is that for structs, it's nicer at the wasm level to just pass the individual values as parameters.
Of course that doesn't work for unions, but until now we haven't had a need to pass a union that wasn't part of an array (which needs to be in memory anyway)
Last updated: Jan 24 2025 at 00:11 UTC