118 lines
5.5 KiB
Diff
118 lines
5.5 KiB
Diff
|
Pull in r200131 from upstream llvm trunk (by Jakob Stoklund Olesen):
|
||
|
|
||
|
Only generate the popc instruction for SPARC CPUs that implement it.
|
||
|
|
||
|
The popc instruction is defined in the SPARCv9 instruction set
|
||
|
architecture, but it was emulated on CPUs older than Niagara 2.
|
||
|
|
||
|
Introduced here: http://svn.freebsd.org/changeset/base/262261
|
||
|
|
||
|
Index: lib/Target/Sparc/SparcISelLowering.cpp
|
||
|
===================================================================
|
||
|
--- lib/Target/Sparc/SparcISelLowering.cpp
|
||
|
+++ lib/Target/Sparc/SparcISelLowering.cpp
|
||
|
@@ -1461,7 +1461,8 @@ SparcTargetLowering::SparcTargetLowering(TargetMac
|
||
|
setOperationAction(ISD::BR_CC, MVT::i64, Custom);
|
||
|
setOperationAction(ISD::SELECT_CC, MVT::i64, Custom);
|
||
|
|
||
|
- setOperationAction(ISD::CTPOP, MVT::i64, Legal);
|
||
|
+ if (Subtarget->usePopc())
|
||
|
+ setOperationAction(ISD::CTPOP, MVT::i64, Legal);
|
||
|
setOperationAction(ISD::CTTZ , MVT::i64, Expand);
|
||
|
setOperationAction(ISD::CTTZ_ZERO_UNDEF, MVT::i64, Expand);
|
||
|
setOperationAction(ISD::CTLZ , MVT::i64, Expand);
|
||
|
@@ -1567,7 +1568,7 @@ SparcTargetLowering::SparcTargetLowering(TargetMac
|
||
|
|
||
|
setStackPointerRegisterToSaveRestore(SP::O6);
|
||
|
|
||
|
- if (Subtarget->isV9())
|
||
|
+ if (Subtarget->isV9() && Subtarget->usePopc())
|
||
|
setOperationAction(ISD::CTPOP, MVT::i32, Legal);
|
||
|
|
||
|
if (Subtarget->isV9() && Subtarget->hasHardQuad()) {
|
||
|
Index: lib/Target/Sparc/Sparc.td
|
||
|
===================================================================
|
||
|
--- lib/Target/Sparc/Sparc.td
|
||
|
+++ lib/Target/Sparc/Sparc.td
|
||
|
@@ -34,6 +34,9 @@ def FeatureHardQuad
|
||
|
: SubtargetFeature<"hard-quad-float", "HasHardQuad", "true",
|
||
|
"Enable quad-word floating point instructions">;
|
||
|
|
||
|
+def UsePopc : SubtargetFeature<"popc", "UsePopc", "true",
|
||
|
+ "Use the popc (population count) instruction">;
|
||
|
+
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
// Register File, Calling Conv, Instruction Descriptions
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
@@ -69,9 +72,9 @@ def : Proc<"v9", [FeatureV9]>;
|
||
|
def : Proc<"ultrasparc", [FeatureV9, FeatureV8Deprecated]>;
|
||
|
def : Proc<"ultrasparc3", [FeatureV9, FeatureV8Deprecated]>;
|
||
|
def : Proc<"niagara", [FeatureV9, FeatureV8Deprecated]>;
|
||
|
-def : Proc<"niagara2", [FeatureV9, FeatureV8Deprecated]>;
|
||
|
-def : Proc<"niagara3", [FeatureV9, FeatureV8Deprecated]>;
|
||
|
-def : Proc<"niagara4", [FeatureV9, FeatureV8Deprecated]>;
|
||
|
+def : Proc<"niagara2", [FeatureV9, FeatureV8Deprecated, UsePopc]>;
|
||
|
+def : Proc<"niagara3", [FeatureV9, FeatureV8Deprecated, UsePopc]>;
|
||
|
+def : Proc<"niagara4", [FeatureV9, FeatureV8Deprecated, UsePopc]>;
|
||
|
|
||
|
def SparcAsmWriter : AsmWriter {
|
||
|
string AsmWriterClassName = "InstPrinter";
|
||
|
Index: lib/Target/Sparc/SparcSubtarget.h
|
||
|
===================================================================
|
||
|
--- lib/Target/Sparc/SparcSubtarget.h
|
||
|
+++ lib/Target/Sparc/SparcSubtarget.h
|
||
|
@@ -30,6 +30,7 @@ class SparcSubtarget : public SparcGenSubtargetInf
|
||
|
bool IsVIS;
|
||
|
bool Is64Bit;
|
||
|
bool HasHardQuad;
|
||
|
+ bool UsePopc;
|
||
|
|
||
|
public:
|
||
|
SparcSubtarget(const std::string &TT, const std::string &CPU,
|
||
|
@@ -39,6 +40,7 @@ class SparcSubtarget : public SparcGenSubtargetInf
|
||
|
bool isVIS() const { return IsVIS; }
|
||
|
bool useDeprecatedV8Instructions() const { return V8DeprecatedInsts; }
|
||
|
bool hasHardQuad() const { return HasHardQuad; }
|
||
|
+ bool usePopc() const { return UsePopc; }
|
||
|
|
||
|
/// ParseSubtargetFeatures - Parses features string setting specified
|
||
|
/// subtarget options. Definition of function is auto generated by tblgen.
|
||
|
Index: lib/Target/Sparc/SparcSubtarget.cpp
|
||
|
===================================================================
|
||
|
--- lib/Target/Sparc/SparcSubtarget.cpp
|
||
|
+++ lib/Target/Sparc/SparcSubtarget.cpp
|
||
|
@@ -31,7 +31,8 @@ SparcSubtarget::SparcSubtarget(const std::string &
|
||
|
V8DeprecatedInsts(false),
|
||
|
IsVIS(false),
|
||
|
Is64Bit(is64Bit),
|
||
|
- HasHardQuad(false) {
|
||
|
+ HasHardQuad(false),
|
||
|
+ UsePopc(false) {
|
||
|
|
||
|
// Determine default and user specified characteristics
|
||
|
std::string CPUName = CPU;
|
||
|
Index: test/CodeGen/SPARC/ctpop.ll
|
||
|
===================================================================
|
||
|
--- test/CodeGen/SPARC/ctpop.ll
|
||
|
+++ test/CodeGen/SPARC/ctpop.ll
|
||
|
@@ -1,13 +1,13 @@
|
||
|
; RUN: llc < %s -march=sparc -mattr=-v9 | FileCheck %s -check-prefix=V8
|
||
|
-; RUN: llc < %s -march=sparc -mattr=+v9 | FileCheck %s -check-prefix=V9
|
||
|
-; RUN: llc < %s -march=sparc -mcpu=v9 | FileCheck %s -check-prefix=V9
|
||
|
-; RUN: llc < %s -march=sparc -mcpu=ultrasparc | FileCheck %s -check-prefix=V9
|
||
|
-; RUN: llc < %s -march=sparc -mcpu=ultrasparc3 | FileCheck %s -check-prefix=V9
|
||
|
-; RUN: llc < %s -march=sparc -mcpu=niagara | FileCheck %s -check-prefix=V9
|
||
|
+; RUN: llc < %s -march=sparc -mattr=+v9,+popc | FileCheck %s -check-prefix=V9
|
||
|
+; RUN: llc < %s -march=sparc -mcpu=v9 | FileCheck %s -check-prefix=V8
|
||
|
+; RUN: llc < %s -march=sparc -mcpu=ultrasparc | FileCheck %s -check-prefix=V8
|
||
|
+; RUN: llc < %s -march=sparc -mcpu=ultrasparc3 | FileCheck %s -check-prefix=V8
|
||
|
+; RUN: llc < %s -march=sparc -mcpu=niagara | FileCheck %s -check-prefix=V8
|
||
|
; RUN: llc < %s -march=sparc -mcpu=niagara2 | FileCheck %s -check-prefix=V9
|
||
|
; RUN: llc < %s -march=sparc -mcpu=niagara3 | FileCheck %s -check-prefix=V9
|
||
|
; RUN: llc < %s -march=sparc -mcpu=niagara4 | FileCheck %s -check-prefix=V9
|
||
|
-; RUN: llc < %s -march=sparcv9 | FileCheck %s -check-prefix=SPARC64
|
||
|
+; RUN: llc < %s -march=sparcv9 -mattr=+popc | FileCheck %s -check-prefix=SPARC64
|
||
|
|
||
|
declare i32 @llvm.ctpop.i32(i32)
|
||
|
|