bjorn3 edited PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [ ] Don't misuse
INVALID
, but introduce a proper type.- [ ] Implement this correctly for WindowsFastcall or give an error.
bjorn3 edited PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [ ] Implement this correctly for WindowsFastcall or give an error.
bjorn3 edited PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
tschneidereit requested bnjbvr for a review on PR #1559.
tschneidereit requested cfallin and bnjbvr for a review on PR #1559.
cfallin submitted PR Review.
cfallin submitted PR Review.
cfallin created PR Review Comment:
Is there a reason for the double-underscore here? I see it consistently below and am wondering if
sarg__
is part of the ABI definition -- if so, let's document it / add a reference to its definition here.
cfallin created PR Review Comment:
Comment here to describe the string format being parsed (
// Parse 'sarg(size)'
?)
cfallin created PR Review Comment:
nit: s/as most/at most/
cfallin created PR Review Comment:
Add doc comment here?
cfallin created PR Review Comment:
Perhaps
args.len() == types.len() && args.iter().zip(types.iter()).all(|(arg, type)| ...)
?
cfallin created PR Review Comment:
Not totally clear here why "incoming arg" always reduces to "incoming struct arg" -- I suppose it's the case that no other argument types are passed in stack slots? Let's have a comment saying this, if so. The API also seems somewhat misleading -- it doesn't really make sense to call
make_incoming_arg(I32, ...)
for a normal (non-struct) argument, right? (I know the API is pre-existing -- just trying to make sense of it.)
cfallin created PR Review Comment:
Maybe pull out this and the
import_function
call below into animport_memcpy
helper?Also, it seems that this will create a new signature/import for every struct argument; can we lazily initialize it once instead?
bjorn3 submitted PR Review.
bjorn3 created PR Review Comment:
I am using
sarg__
for the type to distinguish it from thesarg(size)
argument purpose. Otherwise there is a lexer (and maybe parser) ambiguity.
bjorn3 submitted PR Review.
bjorn3 created PR Review Comment:
make_incoming_arg
is used for when a "regular" argument doesn't fit in registers anymore and needs to be stored on the stack. I could renamemake_incoming_struct_arg
and usety.bytes()
at every caller of the currentmake_incoming_arg
.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
cfallin submitted PR Review.
cfallin created PR Review Comment:
Yep, that makes sense to me; thanks.
cfallin submitted PR Review.
cfallin created PR Review Comment:
Ah, right. Perhaps
sarg_t
(to borrow a C-ism) then? The double underscore just seems a bit out of place, is all.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bjorn3 submitted PR Review.
bjorn3 created PR Review Comment:
Done
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bnjbvr submitted PR Review.
bnjbvr submitted PR Review.
bnjbvr created PR Review Comment:
uber nit: can you add a \n after this match (or
if
, if you agree with the above proposal)
bnjbvr created PR Review Comment:
nit: incorrect comment, this changes the type to
ty
// Assign argument to a location, change type to the requested one and move on to the next one.
bnjbvr created PR Review Comment:
Since this is a match with one arm,
if let ArgumentPurpose::StructArgument(size) = abi_type.purpose {
would look slightly better.
bnjbvr created PR Review Comment:
Maybe add a comment in this if's body, to indicate that the incoming argument had been added during legalization?
bnjbvr created PR Review Comment:
Last argument to memcpy is a size_t, which apparently can be different from the size of a pointer on certain obscure architectures. Can you add a comment that it doesn't matter in our case, that is, that size_t should be the size of a machine word, for all the architectures we're interested in?
bnjbvr created PR Review Comment:
ditto
bnjbvr created PR Review Comment:
Can you add a second test with a function that takes two parameters, say, one i64 and one struct argument (in final position), please?
bjorn3 updated PR #1559 from abi_struct_args
to main
:
According to the SystemV abi, struct arguments must be passed at a fixed stack offset. Cranelift didn't have any way to implement this before. This is necessary to compile proc-macros using cg_clif: https://github.com/bjorn3/rustc_codegen_cranelift/issues/905#issuecomment-616173297
Fixes #1108
TODO
- [x] Don't misuse
INVALID
, but introduce a proper type.- [x] Implement this correctly for WindowsFastcall or give an error.
bnjbvr merged PR #1559.
Last updated: Jan 24 2025 at 00:11 UTC