github-actions[bot] commented on issue #3693:
Subscribe to Label Action
cc @fitzgen
<details>
This issue or pull request has been labeled: "fuzzing"Thus the following users have been cc'd because of the following labels:
- fitzgen: fuzzing
To subscribe or unsubscribe from this label, edit the <code>.github/subscribe-to-label.json</code> configuration file.
Learn more.
</details>
akirilov-arm commented on issue #3693:
Note that the
region
crate lacks support for BTI (reported in darfink/region-rs#21), so I have used a work-around - a direct call tolibc::mprotect()
.
akirilov-arm commented on issue #3693:
@alexcrichton I added you as reviewer for the Wasmtime bits.
akirilov-arm commented on issue #3693:
@alexcrichton I wanted to finish with the pointer authentication PR before coming back to this one:
* If a module is compiled with bti support and loaded into an engine that has bti support disabled, that's fine right? (since everything is a nop)
Yes, that is correct; we just have to make sure that we do not request the
PROT_BTI
memory protection mode from the kernel, since the system call is going to fail.* If a module is not compiled with bti support, but is loaded into an engine with bti support, that's bad right? (in that none of the branches are protected but the page permissions say that all branches need protection?)
Yes, assuming that the engine applies
PROT_BTI
unconditionally to all executable memory pages.The current implementation supports the full flexibility the BTI extension enables, so we have to decouple the following:
- whether the user passed
--cranelift-enable use_bti
on the Wasmtime command line- whether the environment (i.e. CPU and OS) supports BTI
- whether the module that the engine is trying to load has been compiled to use BTI instructions; also, if I am not mistaken, the engine could be trying to load several modules, which might not necessarily have been compiled with the same settings
afonso360 commented on issue #3693:
We should add a
target aarch64 use_bti
toruntests/br_table.clif
, we now use the cranelift JIT to run runtests so we can also test the JIT portion of this PR.We don't yet support
call
s, but that's something I'm addressing in #4667, and can add some bti runtests there as well.
afonso360 edited a comment on issue #3693:
We should add a
target aarch64 use_bti
toruntests/br_table.clif
, we now use the cranelift JIT to run runtests so we can also test thecranelift-jit
portion of this PR.We don't yet support
call
s, but that's something I'm addressing in #4667, and can add some bti runtests there as well.
afonso360 edited a comment on issue #3693:
We should add a
target aarch64 use_bti
toruntests/br_table.clif
, we now use the cranelift JIT to run runtests so we can also test thecranelift-jit
portion of this PR.We don't yet support
call
's, but that's something I'm addressing in #4667, and can add some bti runtests there as well.
afonso360 edited a comment on issue #3693:
We should add a
target aarch64 use_bti
toruntests/br_table.clif
, we now use thecranelift-jit
to run runtests so we can also test thecranelift-jit
portion of this PR.We don't yet support
call
's, but that's something I'm addressing in #4667, and can add some bti runtests there as well.
afonso360 edited a comment on issue #3693:
We should add a
target aarch64 use_bti
toruntests/br_table.clif
, we now use thecranelift-jit
to run runtests so we can also test thecranelift-jit
portion of this PR.We don't yet support
call
's, but that's something I'm addressing in #4667, and can add some bti runtests there as well.Also, should we add
bti
detection incranelift-native
?
afonso360 edited a comment on issue #3693:
We should add a
target aarch64 use_bti
toruntests/br_table.clif
, we now use thecranelift-jit
to run runtests so we can also test thecranelift-jit
portion of this PR.We don't yet support
call
's, but that's something I'm addressing in #4667, and can add some bti runtests there as well.
alexcrichton commented on issue #3693:
Ah sorry ok I see why this can't be an
Engine
-level thing. If that's the case though instead of ferrying a separatebool
through the system could this get attached toCompiledModuleInfo
somewhere internally?
akirilov-arm commented on issue #3693:
@cfallin I think that I have resolved all of @alexcrichton's comments that are related to Wasmtime, so do you have any feedback on the Cranelift side of things?
Last updated: Jan 24 2025 at 00:11 UTC