Stream: git-wasmtime

Topic: wasmtime / PR #4826 Align functions according to their IS...


view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:08):

elliottt edited PR #4826 from trevor/fix-4812 to main:

<!--

Please ensure that the following steps are all taken care of before submitting
the PR.

Please ensure all communication adheres to the code of conduct.
-->

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:10):

elliottt edited PR #4826 from trevor/fix-4812 to main:

Add a function_alignment function to the TargetIsa trait, and use it to align functions when generating objects. This fixes a bug on x86_64 where rip-relative loads to sse registers could cause a segfault, as functions weren't always guaranteed to be aligned to 16-byte addresses.

Fixes #4812

<!--

Please ensure that the following steps are all taken care of before submitting
the PR.

Please ensure all communication adheres to the code of conduct.
-->

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:10):

elliottt requested alexcrichton for a review on PR #4826.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:21):

alexcrichton submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:21):

alexcrichton created PR review comment:

I think this may have actually been the only place that None was passed in, so with this changing would it be possible to switch the alignment parameter to u32 instead of Option<u32>?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:21):

alexcrichton submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:21):

alexcrichton created PR review comment:

Could you leave a comment here for why this is 16? (reading this in isolation I'd naively expect it to be 1)

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:23):

bjorn3 created PR review comment:

Can you also use this method in cranelift-object and cranelift-jit?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:23):

bjorn3 submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:30):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:30):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:30):

cfallin created PR review comment:

I'm wondering if this is enough?

Specifically, couldn't we hit the same bug on aarch64, where:

So I think we need to either set function_alignment to the highest alignment statically that we know we use, or compute it dynamically based on the alignments actually present in the constant pool, on every architecture; otherwise we don't satisfy the alignment constraints.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:35):

elliottt updated PR #4826 from trevor/fix-4812 to main.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:35):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:35):

elliottt created PR review comment:

Great point, added!

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:36):

elliottt has marked PR #4826 as ready for review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:40):

elliottt created PR review comment:

cranelift-object already has support for specifying function alignment as the function_alignment field on ObjectBuilder, is that sufficient?

cranelift-jit takes an argument that implements TargetIsa already, do we need to modify it to ensure that it's emitting aligned function bodies?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 21:40):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 22:03):

elliottt created PR review comment:

That's a good point. I'm going to include the minimum alignment requirement in the output when compiling the function, and then take the max of that and the isa function_alignment when emitting instructions.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 22:03):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 22:44):

elliottt updated PR #4826 from trevor/fix-4812 to main.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 23:02):

cfallin created PR review comment:

Can we call this just alignment? From a consumer point of view, the EmitResult represents a blob of machine code that has to be placed somewhere, with an alignment specified here; the fact that this alignment requirement comes from our constant pool in this instance is sort of an incidental detail (and there could be other reasons later).

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 23:02):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 23:02):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 23:13):

elliottt updated PR #4826 from trevor/fix-4812 to main.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 23:30):

elliottt created PR review comment:

What do you think about removing the function_alignment field from ObjectBuilder and calling the function_alignment() function in TargetIsa instead? Also it looks like we'll need to slightly adapt the Module trait to pass through the individual function alignment requirements so that we can pick the largest one when emitting machine code. I've made that change on this branch, but held off on removing function_alignment from ObjectBuilder.

Looking through cranelift-jit, it seems like it always 16-byte aligns functions, so there might not be any work needed there.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 23:30):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 30 2022 at 23:31):

elliottt updated PR #4826 from trevor/fix-4812 to main.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 15:16):

akirilov-arm submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 15:16):

akirilov-arm created PR review comment:

I don't think that this is much of a problem because the only instructions I can think of off the top of my head that have strict alignment requirements are the atomic instructions (or SP-relative operations, but they are not applicable in this case), and it sounds a bit unusual to apply them to literals in the instruction stream. Yes, it is possible to enable alignment checking for almost all relevant instructions, but I am not aware of any platform that does that, and in fact unaligned accesses by default is pretty much an aspect of the ABI at this point.

However, stricter function alignment is in fact recommended for performance reasons, i.e. to maximize fetch bandwidth. The recommendation for some of Arm's recent processors is 32 bytes.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 16:29):

elliottt updated PR #4826 from trevor/fix-4812 to main.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 16:31):

elliottt created PR review comment:

@akirilov-arm is it worth changing this to 32 here, or should we leave that for another PR?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 16:31):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 16:38):

akirilov-arm submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 16:38):

akirilov-arm created PR review comment:

Doing it in this PR is fine, but you should add a comment that the value has been chosen for performance reasons; otherwise the correctness requirement is 4 bytes, as in your current code.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 18:29):

elliottt updated PR #4826 from trevor/fix-4812 to main.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 20:40):

elliottt created PR review comment:

I changed this to 32 and added a comment, thanks!

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 20:40):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 31 2022 at 21:41):

elliottt merged PR #4826.


Last updated: Jan 24 2025 at 00:11 UTC