This is an archive of the discontinued LLVM Phabricator instance.

[ARM|GlobalISel] : Adding legalizer tests for Thumb
Needs ReviewPublic

Authored by javed.absar on Nov 3 2017, 5:00 AM.

Details

Reviewers
rovka
Summary

This is repeat of the legalizer tests done for ARM mode.

Diff Detail

Event Timeline

javed.absar created this revision.Nov 3 2017, 5:00 AM
rovka edited edge metadata.Nov 3 2017, 6:10 AM

Hi Javed,

Is there a reason why you're not just adding a RUN line to the existing test file?
Also, could you have a look at arm-legalize-fp.mir and arm-legalize-divmod.mir while you're at it?

Thanks,
Diana

Hi Diana.
Yes I too was thinking of adding just the run line, but I don't know when we move to instruction-selection would/could we do the same.
And if not, the separation upfront might be a good idea. Please advise. I am ok either way.

Yes, I will have a look at arm-legalize-fp.mir and arm-legalize-divmod.mir

Thanks a lot.

rovka added a comment.Nov 3 2017, 8:52 AM

I think it would be simpler to add a RUN line to the existing test (you can rename it to just legalizer.mir if you think the current name would be misleading).

It's ok to have separate tests for ARM vs Thumb instruction selection (*), since there would be more differences there, but I think for simple passes like the legalizer and reg bank select it's easier to follow if we keep them together in the same file.

(*) Alternatively, we can split up the instruction selection tests into smaller chunks and make them mixed ARM/Thumb if it turns out to be easier to read that way.

Added thumb tests to all three. Also renamed the files to make it clear the test run both arm and thumb

It seems the thumb instruction selection will take more work and needs probably split up into smaller ones (as discussed with Diana). So they will come later.

rovka added inline comments.Nov 6 2017, 3:05 AM
test/CodeGen/ARM/GlobalISel/legalize-divmod.mir
5

Thumb division is actually controlled by the hwdiv feature, not by hwdiv-arm. The test should expose that behaviour (you'll also need to update the LegalizerInfo code to make it pass, but it's going to be very similar to what already exists for ARM).

53

Hmm, this shouldn't be a BL for Thumb. You'll have to update ARMCallLowering to handle Thumb before we can test this properly.

javed.absar marked an inline comment as done.Nov 6 2017, 10:30 AM

Thanks Diana for the review.

test/CodeGen/ARM/GlobalISel/legalize-divmod.mir
5

Thanks for this.

53

Would you recommend then that I hold on to this patch till I have sorted out CallLowering for thumb in general. I don't see a change in ARMCallLowering.cpp for GlobalISel ARM, to understand what needs to be done for Thumb (maybe I am looking at the wrong place)

rovka added inline comments.Nov 7 2017, 4:04 AM
lib/Target/ARM/ARMLegalizerInfo.cpp
60 ↗(On Diff #121752)

You should check if you're generating ARM or Thumb, since you don't want the Thumb hardware divide to influence ARM code generation and vice versa. So, something like (ST.isThumb() && ST.hasDivideInThumbMode()) || (!ST.isThumb() && ST.hasDivideInARMMode())

test/CodeGen/ARM/GlobalISel/legalize-divmod.mir
53

I think that might be for the best.

The change would be in ARMCallLowering::lowerCall, where you set the opcode for the call (at the moment we only choose between ARM-specific opcodes). It should be easy to update the arm-call-lowering.ll test to account for that, but if we want to be thorough about testing we should also update arm-param-lowering.ll, and for that you'd also need to fix ARMCallLowering::lowerFormalArguments (I'm not sure off the top of my head, but it might be enough to just remove the check for Thumb and let the CCAssignFn work its magic).

In any case, that's probably enough work for a patch in its own right.

javed.absar marked an inline comment as done.Nov 8 2017, 2:52 PM

This patch is now dependent on https://reviews.llvm.org/D39808