summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorKrzysztof Parzyszek <kparzysz@codeaurora.org>2015-03-18 17:20:51 +0000
committerKrzysztof Parzyszek <kparzysz@codeaurora.org>2015-03-18 17:20:51 +0000
commit5d7e8fcd5297169b461f2465470f620b2dd9f9c9 (patch)
tree0bbaf56876afccb329a6faed2d7cd28efff09fc4 /llvm/lib
parent833d798b0e7e9a497974d8fff882e6b109be7f43 (diff)
downloadbcm5719-llvm-5d7e8fcd5297169b461f2465470f620b2dd9f9c9.tar.gz
bcm5719-llvm-5d7e8fcd5297169b461f2465470f620b2dd9f9c9.zip
[Hexagon] Use pseudo-instructions for true/false predicate values
llvm-svn: 232650
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp29
1 files changed, 6 insertions, 23 deletions
diff --git a/llvm/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp b/llvm/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp
index 6e8d431ee10..22a7b27c12c 100644
--- a/llvm/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp
+++ b/llvm/lib/Target/Hexagon/HexagonISelDAGToDAG.cpp
@@ -997,30 +997,13 @@ SDNode *HexagonDAGToDAGISel::SelectConstantFP(SDNode *N) {
SDNode *HexagonDAGToDAGISel::SelectConstant(SDNode *N) {
SDLoc dl(N);
if (N->getValueType(0) == MVT::i1) {
- SDNode* Result;
+ SDNode* Result = 0;
int32_t Val = cast<ConstantSDNode>(N)->getSExtValue();
- if (Val == -1) {
- // Create the IntReg = 1 node.
- SDNode* IntRegTFR =
- CurDAG->getMachineNode(Hexagon::A2_tfrsi, dl, MVT::i32,
- CurDAG->getTargetConstant(0, MVT::i32));
-
- // Pd = IntReg
- SDNode* Pd = CurDAG->getMachineNode(Hexagon::C2_tfrrp, dl, MVT::i1,
- SDValue(IntRegTFR, 0));
-
- // not(Pd)
- SDNode* NotPd = CurDAG->getMachineNode(Hexagon::C2_not, dl, MVT::i1,
- SDValue(Pd, 0));
-
- // xor(not(Pd))
- Result = CurDAG->getMachineNode(Hexagon::C2_xor, dl, MVT::i1,
- SDValue(Pd, 0), SDValue(NotPd, 0));
-
- // We have just built:
- // Rs = Pd
- // Pd = xor(not(Pd), Pd)
-
+ if (Val == -1)
+ Result = CurDAG->getMachineNode(Hexagon::TFR_PdTrue, dl, MVT::i1);
+ else if (Val == 0)
+ Result = CurDAG->getMachineNode(Hexagon::TFR_PdFalse, dl, MVT::i1);
+ if (Result) {
ReplaceUses(N, Result);
return Result;
}
OpenPOWER on IntegriCloud