[PATCH] D67981: [NFC][PowerPC] Adding FeatureFPU in the definition of FeatureISA3_0

Nemanja Ivanovic via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Sep 30 21:13:28 PDT 2019


nemanjai added inline comments.


================
Comment at: llvm/lib/Target/PowerPC/PPC.td:193
+                                     "Enable instructions added in ISA 3.0.",
+                                     [FeatureFPU]>;
 def FeatureP9Altivec : SubtargetFeature<"power9-altivec", "HasP9Altivec", "true",
----------------
jsji wrote:
> nemanjai wrote:
> > jsji wrote:
> > > jsji wrote:
> > > > Looks like there is some misunderstanding of what `FeatureISA3_0` is for?
> > > > 
> > > > As in the description, `FeatureISA3_0` is for new instruction added in ISA 3.0, not all the instructions in ISA 3.0.
> > > > Why it need to depend on FeatureFPU?
> > > > 
> > > > In other words, with the new patch `-mattr=-fpu` will also remove `isa-v30-instructions` effectively.
> > > > So that means, if you add -mattr=-fpu, you can't use any of the new instruction added for P8? 
> > > > Is that what you intended?
> > > > 
> > > I meant `P9`.
> > Yes. That is very much part of the intent here. It is not possible to have a CPU that conforms to ISA 3.0 that does not support HW floating point operations (i.e. doesn't have a HW FPU).
> > 
> > Having an FPU does not imply we have an implementation of ISA 3.0. But having an implementation of ISA 3.0 **absolutely** implies having an FPU.
> Yes, you are right, and I also agree that ` having an implementation of ISA 3.0 absolutely implies having an FPU`. 
> 
> However, looks like to me that `FeatureISA3_0` is NOT corresponding to `compliant implementation of ISA 3.0`.
> But rather controlling whether we can generate *new instructions in ISA 3.0*.
> Also, `FeatureFPU` is also not corresponding to `having an FPU`, but rather controlling whether we can generates FPU instructions.
> 
> So if we add the *Implies* to `FPU` here, we are more or less saying: all ISA 3.0 instructions are also FPU instructions,
> we can only generate ISA 3.0 instructions if we are allow to generate FPU instructions.
> 
> Does this dependency really exists?
> 
> What if someone would like to avoid generating FPU instructions (eg: kernel users), 
> but still would like to take advantage of P9 new instructions like `extswsli`, `maddld`,`modud`. 
> 
> I believe he/she can use `-mcpu=pwr9 -mattr=-fpu` right now, but will get performance deg if we apply this patch.
> 
> What do you think?
> 
If we are aware of a valid use case for something like this (i.e. we want instructions that were added in ISA 3.0) but we want a guarantee that no floating point instructions are emitted, we need to do a bit more work than just stop this patch from going in.

The reason we added this feature is to differentiate SPE codegen from codegen for CPUs that have an FPU. That is about all it is good for. As an example, the following will produce FP instructions:
```
define dso_local signext i32 @test(double %a, double %b) local_unnamed_addr #0 {
entry:
  %cmp = fcmp olt double %a, %b
  %conv = zext i1 %cmp to i32
  ret i32 %conv
}

llc -mattr=-fpu < a.ll | grep fcmpu
        fcmpu 0, 1, 2
```

So the addition of this implication is really to avoid having to add the predicate for every pattern we want to add going forward.


Repository:
  rL LLVM

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D67981/new/

https://reviews.llvm.org/D67981





More information about the llvm-commits mailing list