Stream: git-wasmtime

Topic: wasmtime / issue #5261 Shrink the size of SigData in Cran...


view this post on Zulip Wasmtime GitHub notifications bot (Nov 14 2022 at 05:33):

tnachen commented on issue #5261:

@fitzgen

view this post on Zulip Wasmtime GitHub notifications bot (Nov 14 2022 at 17:22):

abrown commented on issue #5261:

Glancing at this, is there a test out there that checks the size of SigData? I have found that kind of test helpful in other parts of this project.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 14 2022 at 18:24):

jameysharp commented on issue #5261:

I don't see an existing test for the size of SigData, no. I'm not entirely convinced we're doing the right thing with the existing tests—the fact that the most recent rustc upgrade broke one of the tests by doing a better job of laying out one of our structs makes me think maybe that's not exactly what we should be testing. But I don't have a better idea at the moment, and it's reassuring to know that at least we'll find out if the sizes change.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 14 2022 at 19:49):

abrown commented on issue #5261:

... and it's reassuring to know that at least we'll find out if the sizes change.

Yeah, exactly. If such a test is too brittle across OSes or compiler versions for some reason then it doesn't make sense. But a general reassurance has been nice with, e.g., instruction data.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 15 2022 at 06:21):

tnachen commented on issue #5261:

Thanks @jameysharp for the review! Updated based on comments, let me know if a test makes sense here (though as mentioned seems like the results will differ)

view this post on Zulip Wasmtime GitHub notifications bot (Nov 15 2022 at 17:03):

jameysharp commented on issue #5261:

I think it would be useful to have a test for SigData's size, but at the same time, I'm not expecting you to add it unless you want to.

If you do want to write that test, I think we should replace the one use of usize (the stack_ret_arg field) with a type whose size doesn't depend on the target's pointer size. That way the test doesn't depend on which target we're compiling for. Then it should only change when the Rust compiler changes its ABI, which is infrequent enough that we can deal with it.

Given the other changes in this PR, I think giving that field the type Option<u16> ought to work fine, since it's an index into the arguments. As a bonus, that's a substantial improvement in size:

None of that is necessary for merging this PR. If you'd like to make these additional changes in this PR, feel free. If you want me to merge this PR as-is, let me know and I'm happy to do that (after the remaining usize::from change). These additional changes would make a good follow-up PR too.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 15 2022 at 18:19):

tnachen commented on issue #5261:

@jameysharp sounds good I'll make these changes! seems like it's simple enough. In the mean time just ran the benchmark ->

 Running `target/release/sightglass-cli benchmark -e /tmp/main.so -e /tmp/smaller-sig-data.so --stop-after compilation -- benchmarks/default.suite`

compilation :: cycles :: benchmarks/spidermonkey/benchmark.wasm

Δ = 460930934.38 ± 351410455.73 (confidence = 99%)

smaller-sig-data.so is 1.01x to 1.07x faster than main.so!

[11432848277 12881522406.46 16050235396] main.so
[11050769166 12420591472.08 15404617502] smaller-sig-data.so

compilation :: cycles :: benchmarks/pulldown-cmark/benchmark.wasm

No difference in performance.

[524369235 620830497.53 829897789] main.so
[492571419 606893937.78 868345984] smaller-sig-data.so

compilation :: cycles :: benchmarks/bz2/benchmark.wasm

No difference in performance.

[324283951 399934581.50 681479969] main.so
[306842933 394721779.72 550360275] smaller-sig-data.so

view this post on Zulip Wasmtime GitHub notifications bot (Nov 15 2022 at 18:24):

fitzgen edited a comment on issue #5261:

@jameysharp sounds good I'll make these changes! seems like it's simple enough. In the mean time just ran the benchmark ->

     Running `target/release/sightglass-cli benchmark -e /tmp/main.so -e /tmp/smaller-sig-data.so --stop-after compilation -- benchmarks/default.suite`

compilation :: cycles :: benchmarks/spidermonkey/benchmark.wasm

  Δ = 460930934.38 ± 351410455.73 (confidence = 99%)

  smaller-sig-data.so is 1.01x to 1.07x faster than main.so!

  [11432848277 12881522406.46 16050235396] main.so
  [11050769166 12420591472.08 15404617502] smaller-sig-data.so

compilation :: cycles :: benchmarks/pulldown-cmark/benchmark.wasm

  No difference in performance.

  [524369235 620830497.53 829897789] main.so
  [492571419 606893937.78 868345984] smaller-sig-data.so

compilation :: cycles :: benchmarks/bz2/benchmark.wasm

  No difference in performance.

  [324283951 399934581.50 681479969] main.so
  [306842933 394721779.72 550360275] smaller-sig-data.so

view this post on Zulip Wasmtime GitHub notifications bot (Nov 15 2022 at 18:26):

fitzgen commented on issue #5261:

just ran the benchmark

Great results! 1-7% faster compilation times for spidermonkey.wasm is nothing to sneeze at!

And this is before the further shrinking with the stack_ret_arg field, correct?

view this post on Zulip Wasmtime GitHub notifications bot (Nov 16 2022 at 17:36):

jameysharp commented on issue #5261:

The newest commit ("Change ret arg length to u16") looks good! CI says you need to run cargo fmt, but this is otherwise ready to merge.

I think I did my math wrong before: the original version of the PR should have reduced the size of SigData by 4 bytes (2u32-2u16), not 8. This version replaces 2usize with 2u16, which means now we have 4 u16-aligned fields, so nothing fits into the 7 existing bytes of padding. Oh well.

If you want to add a test for this now, the following should work, assuming I did my math right this time. SigData is currently 56 bytes (according to ddbug) and I believe you've reduced it to 40 bytes.

#[test]
fn sig_data_size() {
    // The size of `SigData` is performance sensitive, so make sure
    // we don't regress it unintentionally.
    assert_eq!(std::mem::size_of::<SigData>(), 40);
}

I copied this from the test for InstructionData in cranelift/codegen/src/ir/instructions.rs, but you can find many examples with git grep 'assert.*size_of::'.

view this post on Zulip Wasmtime GitHub notifications bot (Nov 16 2022 at 23:20):

tnachen commented on issue #5261:

@jameysharp oh awesome! Thanks for the example, not sure what else I should add so I just copied what you have into the test code.

Ran the benchmark and got this ->

Running target/release/sightglass-cli benchmark -e /tmp/main.so -e /tmp/smaller-sig-data.so --stop-after compilation -- benchmarks/default.suite

compilation :: cycles :: benchmarks/pulldown-cmark/benchmark.wasm

Δ = 108117568.68 ± 43286306.96 (confidence = 99%)

smaller-sig-data.so is 1.12x to 1.27x faster than main.so!

[499997365 671467058.89 1397732830] main.so
[483578441 563349490.21 708900294] smaller-sig-data.so

compilation :: cycles :: benchmarks/bz2/benchmark.wasm

Δ = 44610760.31 ± 31993506.80 (confidence = 99%)

smaller-sig-data.so is 1.03x to 1.20x faster than main.so!

[304879457 426284282.91 661512654] main.so
[296608459 381673522.60 829079445] smaller-sig-data.so

compilation :: cycles :: benchmarks/spidermonkey/benchmark.wasm

No difference in performance.

[10560613802 11918560571.18 15092693358] main.so
[9949435804 11698203046.57 14045075735] smaller-sig-data.so

view this post on Zulip Wasmtime GitHub notifications bot (Nov 16 2022 at 23:22):

fitzgen edited a comment on issue #5261:

@jameysharp oh awesome! Thanks for the example, not sure what else I should add so I just copied what you have into the test code.

Ran the benchmark and got this ->

 Running `target/release/sightglass-cli benchmark -e /tmp/main.so -e /tmp/smaller-sig-data.so --stop-after compilation -- benchmarks/default.suite`

compilation :: cycles :: benchmarks/pulldown-cmark/benchmark.wasm

  Δ = 108117568.68 ± 43286306.96 (confidence = 99%)

  smaller-sig-data.so is 1.12x to 1.27x faster than main.so!

  [499997365 671467058.89 1397732830] main.so
  [483578441 563349490.21 708900294] smaller-sig-data.so

compilation :: cycles :: benchmarks/bz2/benchmark.wasm

  Δ = 44610760.31 ± 31993506.80 (confidence = 99%)

  smaller-sig-data.so is 1.03x to 1.20x faster than main.so!

  [304879457 426284282.91 661512654] main.so
  [296608459 381673522.60 829079445] smaller-sig-data.so

compilation :: cycles :: benchmarks/spidermonkey/benchmark.wasm

  No difference in performance.

  [10560613802 11918560571.18 15092693358] main.so
  [9949435804 11698203046.57 14045075735] smaller-sig-data.so


Last updated: Jan 24 2025 at 00:11 UTC