[PATCH] D50629: AMDGPU: Fix getInstSizeInBytes

Nicolai Hähnle via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Aug 23 00:27:12 PDT 2018


nhaehnle added a comment.

In https://reviews.llvm.org/D50629#1209494, @arsenm wrote:

> In https://reviews.llvm.org/D50629#1209249, @nhaehnle wrote:
>
> > Always do the sanity check in debug builds.
> >
> > I was originally worried about how expensive this is, but it
> >  doesn't show up in the running time of all the tests in
> >  test/CodeGen/AMDGPU.
>
>
> These are by design almost all small, so that makes sense. It might not be representative in the real world


We shouldn't be running debug builds in the real world anyway.



================
Comment at: lib/Target/AMDGPU/AMDGPUMCInstLower.cpp:308-314
+    // Sanity-check getInstSizeInBytes on explicitly specified CPUs (it cannot
+    // work correctly for the generic CPU).
+    //
+    // The isPseudo check really shouldn't be here, but unfortunately there are
+    // some negative lit tests that depend on being able to continue through
+    // here even when pseudo instructions haven't been lowered.
+    if (!MI->isPseudo() && STI.isCPUStringValid(STI.getCPU())) {
----------------
arsenm wrote:
> We don't actually have a generic CPU? We just pick a default?
No, we don't. That's precisely the problem I mentioned elsewhere at some point and I brought up the possibility of just deciding that running without specifying a CPU is unsupported.

If you don't specify a CPU (or the CPU is unknown), you get a set of inconsistent feature bits that doesn't correspond to any real CPU. The consequence is that all sorts of MachineInstrs are generated during CodeGen which aren't actually considered supported by MC, so entering the instruction encoding logic will fail.

I briefly looked into ways of fixing this, and it's of course be possible, but it'd require fixing a *lot* of the existing tests.


Repository:
  rL LLVM

https://reviews.llvm.org/D50629





More information about the llvm-commits mailing list