Stream: git-wasmtime

Topic: wasmtime / PR #1995 x64 new backend: most integer opcodes...


view this post on Zulip Wasmtime GitHub notifications bot (Jul 08 2020 at 17:09):

bnjbvr opened PR #1995 from x64 to main:

I've implemented basic support for Baldrdash so as to be able to run the extensive Spidermonkey test suite, and then could get back to fix a few integer operators implemented before. Also implemented most of the integer opcodes required for wasm; I could start to run successfully a few large wasm integer-only programs with wasmtime too.

I plan on enabling limited testing of wast files on CI soon, to catch future regressions in codegen.

Sorry about the large PR!

view this post on Zulip Wasmtime GitHub notifications bot (Jul 08 2020 at 17:09):

bnjbvr requested julian-seward1 for a review on PR #1995.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 09 2020 at 08:31):

bnjbvr updated PR #1995 from x64 to main:

I've implemented basic support for Baldrdash so as to be able to run the extensive Spidermonkey test suite, and then could get back to fix a few integer operators implemented before. Also implemented most of the integer opcodes required for wasm; I could start to run successfully a few large wasm integer-only programs with wasmtime too.

I plan on enabling limited testing of wast files on CI soon, to catch future regressions in codegen.

Sorry about the large PR!

view this post on Zulip Wasmtime GitHub notifications bot (Jul 10 2020 at 05:45):

jlb6740 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 10 2020 at 05:45):

jlb6740 created PR Review Comment:

Rotate in shift enum ... making the naming a little inconsistent from the first 3? Perhaps a more generic name (and comment update) for the Enum to show that Rotate is also housed. Also for consistency could prepend shift to Left, RightZ, and RightS, i.e. ShiftLeft, ShiftRightZ, ShiftRightS.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 10 2020 at 05:52):

jlb6740 deleted PR Review Comment.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 10 2020 at 05:53):

jlb6740 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 10 2020 at 05:53):

jlb6740 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 10 2020 at 05:53):

jlb6740 created PR Review Comment:

Rotate in shift enum ... making the naming a little inconsistent from the first 3? Perhaps a more generic name (and comment update) for the Enum to show that Rotate is also housed. Also for consistency could prepend shift to Left, RightZ, and RightS, i.e. ShiftLeft, ShiftRightZ, ShiftRightS.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 11:11):

bnjbvr requested cfallin and julian-seward1 for a review on PR #1995.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:08):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:08):

julian-seward1 created PR Review Comment:

+1 for that suggestion.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:13):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:13):

julian-seward1 created PR Review Comment:

Could you clarify the register usage in this comment a bit? Something like: RDX:RAX <- RAX * rhs.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:16):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:16):

julian-seward1 created PR Review Comment:

Hmm, gen_move has its destination on the left? That feels inconsistent with the rest of the x64 stuff, which I thought had destinations as the rightmost argument. But maybe that's because gen_move is from the applies-to-all-targets trait Inst, right? I guess the use of Writable guarantees we're safe here.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:18):

julian-seward1 created PR Review Comment:

ReadOnlyGprRmR* feels a bit cumbersome to me (and did when I looked at it some days ago). Would you consider instead UnaryRmR (and consistent renaming for the derived-from-it names?)

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:18):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:24):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:24):

julian-seward1 created PR Review Comment:

nit-level, at best, but .. (eg) *Extend32 doesn't make it obvious to the casual reader whether the 32 is the source or dest width. Would you consider adding To in front of the number? eg *ExtendTo32 ?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:34):

cfallin submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:34):

cfallin submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:34):

cfallin created PR Review Comment:

Add a comment giving the instruction this is emitting? movq $imm64, %dst or similar...

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:34):

cfallin created PR Review Comment:

Perhaps for a future refactor, but IMHO we should move from is_64 bools to a purpose-built enum.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:34):

cfallin created PR Review Comment:

Just a stylistic preference, but I tend to prefer panics for things like this, e.g. _ => panic!("Int args only supported for SysV calling conventions") or somesuch...

(similar comment below)

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:34):

cfallin created PR Review Comment:

Drive-by / pre-existing, but perhaps we could turn is_div and is_signed into their own (combined) enum -- SDiv, UDiv, SRem, URem?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 15 2020 at 17:34):

cfallin created PR Review Comment:

I know this is just following the aarch64 backend (so it's OK for now!), but I'm wondering if we should make the pinned register a flags option, and then set it explicitly in Baldrdash, to avoid the hardcoded reference to SpiderMonkey here. Perhaps for a future refactor?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 06:59):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 06:59):

julian-seward1 created PR Review Comment:

I'm sure this works correctly, but it concerns me in two ways:

Given that the current goal is to get correct x64 code generation landed, I'd be happy for these to be looked at in a followup. They don't need to block landing.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:03):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:03):

julian-seward1 created PR Review Comment:

+1 for that; please add comments always, indicating what insns are being emitted. Inferring from the opcodes is nearly impossible.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:05):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:05):

julian-seward1 created PR Review Comment:

Also .. is there a typo in the commit message? "movaps" isn't the insn you mean AFAIK; that's an aligned SSE load (move-aligned-packed-singleprecision). Maybe you mean "movabsq" ?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:08):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:08):

julian-seward1 created PR Review Comment:

If it's an outright bug that should never happen, then +1 for panicing rather than continuing (returning false or whatever). I'm not convinced that's the case here, though (can't infer)

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:11):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:11):

julian-seward1 created PR Review Comment:

I just want to check here that these changes to the register numbering don't change the order at which they appear in the final RealRegUniverse. (To be specific: you are not reordering registers within each reg-class, in the universe). Is that true? I ask because the ordering of regs within each reg class is relevant -- at least for RA/BT -- to whether caller- or callee-saved registers are used in preference, and that has an effect on the quality of the generated allocation.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:13):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:13):

julian-seward1 created PR Review Comment:

+1; losing r15 in configurations where that isn't necessary would be unfortunate, given that there are only circa 12 int regs available for allocation anyway. And in the 32-bit x86 case (if we ever do that) it would be quite serious.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:16):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:28):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 07:28):

julian-seward1 created PR Review Comment:

Please can this be upgraded to a release assert, or at least somehow be checked even in release builds? If for whatever reason ty of I16 or I8 ever gets here, we will silently generate wrong code and it could be hard to track down.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 09:16):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 09:16):

julian-seward1 created PR Review Comment:

Also .. for "Make sure to zero %rdx right before this instruction!" please add a line explaining why this is necessary and what will (or might) happen if you don't.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 09:53):

bjorn3 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 09:53):

bjorn3 created PR Review Comment:

CallConv::Fast and CallConv::Cold can also reach this I think.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 10:00):

bjorn3 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 10:00):

bjorn3 created PR Review Comment:

If you implement Display instead, you get ToString for free.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 10:03):

bjorn3 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 10:03):

bjorn3 created PR Review Comment:

It is already conditionally used as pinned register: https://github.com/bytecodealliance/wasmtime/pull/1995/files#diff-d4cd987e797b464cfda540d1f41fcfb3R200-R210

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 12:42):

bnjbvr submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 12:42):

bnjbvr created PR Review Comment:

Indeed, gen_move is on the target-independent trait. Maybe we can change this at some point, if the aarch64 backend agrees with the x64 convention?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 12:59):

bnjbvr submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 12:59):

bnjbvr created PR Review Comment:

Yes! Recent PRs with OperandSize enum have inspired me... Added to the backlog!

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:00):

bnjbvr submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:00):

bnjbvr created PR Review Comment:

+1 to what @bjorn3 said, its usage is opt-in, disabled by default.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:01):

bnjbvr submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:01):

bnjbvr created PR Review Comment:

I've mostly ported what the old backend did, and I'm happy to revisit it later when this has landed. Thanks for the comments!

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:08):

bnjbvr submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:08):

bnjbvr created PR Review Comment:

It's a long story, but... yes, this does put R15 at the end of the allocatable list.

The reason is the following: regalloc has the concept of overall allocatable registers. So if in certain modes (i.e. when the use_pinned_reg flag is true), we want to mark one register as allocatable or not, then it must be at the edge of the "allocatable" list, so at the end of its register class (otherwise its register index changes when the pinned reg is in use).

To keep BT happy with the order of caller or callee-saved registers, I guess we could have a different register index for r15, according to whether it's pinned or not. I think it might cause more churn for other registers (namely, those which will be placed after r15). So maybe this justifies a completely different RegUniverse of its own? If that's ok, i'd like to defer this. We may need having different RegUniverse for respecting the win64 calling convention.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:16):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:16):

julian-seward1 created PR Review Comment:

If that's ok, i'd like to defer this.

Oh, definitely defer. Let's get this landed and running first, then we can come back and optimise later. (Sorry .. I should have made this clearer in the comment)

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 13:24):

bnjbvr updated PR #1995 from x64 to main:

I've implemented basic support for Baldrdash so as to be able to run the extensive Spidermonkey test suite, and then could get back to fix a few integer operators implemented before. Also implemented most of the integer opcodes required for wasm; I could start to run successfully a few large wasm integer-only programs with wasmtime too.

I plan on enabling limited testing of wast files on CI soon, to catch future regressions in codegen.

Sorry about the large PR!

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 15:29):

bnjbvr updated PR #1995 from x64 to main:

I've implemented basic support for Baldrdash so as to be able to run the extensive Spidermonkey test suite, and then could get back to fix a few integer operators implemented before. Also implemented most of the integer opcodes required for wasm; I could start to run successfully a few large wasm integer-only programs with wasmtime too.

I plan on enabling limited testing of wast files on CI soon, to catch future regressions in codegen.

Sorry about the large PR!

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2020 at 16:21):

bnjbvr merged PR #1995.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 17 2020 at 08:28):

julian-seward1 submitted PR Review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 17 2020 at 08:28):

julian-seward1 created PR Review Comment:

Well, aarch64 has destinations on the left. So it's never going to agree with x64 (the AT&T conventions, at least.).


Last updated: Dec 23 2024 at 12:05 UTC