PPCPredicates.cpp 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. //===-- PPCPredicates.cpp - PPC Branch Predicate Information --------------===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. //
  9. // This file implements the PowerPC branch predicates.
  10. //
  11. //===----------------------------------------------------------------------===//
  12. #include "PPCPredicates.h"
  13. #include "llvm/Support/ErrorHandling.h"
  14. #include <cassert>
  15. using namespace llvm;
  16. PPC::Predicate PPC::InvertPredicate(PPC::Predicate Opcode) {
  17. switch (Opcode) {
  18. case PPC::PRED_EQ: return PPC::PRED_NE;
  19. case PPC::PRED_NE: return PPC::PRED_EQ;
  20. case PPC::PRED_LT: return PPC::PRED_GE;
  21. case PPC::PRED_GE: return PPC::PRED_LT;
  22. case PPC::PRED_GT: return PPC::PRED_LE;
  23. case PPC::PRED_LE: return PPC::PRED_GT;
  24. case PPC::PRED_NU: return PPC::PRED_UN;
  25. case PPC::PRED_UN: return PPC::PRED_NU;
  26. case PPC::PRED_EQ_MINUS: return PPC::PRED_NE_PLUS;
  27. case PPC::PRED_NE_MINUS: return PPC::PRED_EQ_PLUS;
  28. case PPC::PRED_LT_MINUS: return PPC::PRED_GE_PLUS;
  29. case PPC::PRED_GE_MINUS: return PPC::PRED_LT_PLUS;
  30. case PPC::PRED_GT_MINUS: return PPC::PRED_LE_PLUS;
  31. case PPC::PRED_LE_MINUS: return PPC::PRED_GT_PLUS;
  32. case PPC::PRED_NU_MINUS: return PPC::PRED_UN_PLUS;
  33. case PPC::PRED_UN_MINUS: return PPC::PRED_NU_PLUS;
  34. case PPC::PRED_EQ_PLUS: return PPC::PRED_NE_MINUS;
  35. case PPC::PRED_NE_PLUS: return PPC::PRED_EQ_MINUS;
  36. case PPC::PRED_LT_PLUS: return PPC::PRED_GE_MINUS;
  37. case PPC::PRED_GE_PLUS: return PPC::PRED_LT_MINUS;
  38. case PPC::PRED_GT_PLUS: return PPC::PRED_LE_MINUS;
  39. case PPC::PRED_LE_PLUS: return PPC::PRED_GT_MINUS;
  40. case PPC::PRED_NU_PLUS: return PPC::PRED_UN_MINUS;
  41. case PPC::PRED_UN_PLUS: return PPC::PRED_NU_MINUS;
  42. // Simple predicates for single condition-register bits.
  43. case PPC::PRED_BIT_SET: return PPC::PRED_BIT_UNSET;
  44. case PPC::PRED_BIT_UNSET: return PPC::PRED_BIT_SET;
  45. }
  46. llvm_unreachable("Unknown PPC branch opcode!");
  47. }
  48. PPC::Predicate PPC::getSwappedPredicate(PPC::Predicate Opcode) {
  49. switch (Opcode) {
  50. case PPC::PRED_EQ: return PPC::PRED_EQ;
  51. case PPC::PRED_NE: return PPC::PRED_NE;
  52. case PPC::PRED_LT: return PPC::PRED_GT;
  53. case PPC::PRED_GE: return PPC::PRED_LE;
  54. case PPC::PRED_GT: return PPC::PRED_LT;
  55. case PPC::PRED_LE: return PPC::PRED_GE;
  56. case PPC::PRED_NU: return PPC::PRED_NU;
  57. case PPC::PRED_UN: return PPC::PRED_UN;
  58. case PPC::PRED_EQ_MINUS: return PPC::PRED_EQ_MINUS;
  59. case PPC::PRED_NE_MINUS: return PPC::PRED_NE_MINUS;
  60. case PPC::PRED_LT_MINUS: return PPC::PRED_GT_MINUS;
  61. case PPC::PRED_GE_MINUS: return PPC::PRED_LE_MINUS;
  62. case PPC::PRED_GT_MINUS: return PPC::PRED_LT_MINUS;
  63. case PPC::PRED_LE_MINUS: return PPC::PRED_GE_MINUS;
  64. case PPC::PRED_NU_MINUS: return PPC::PRED_NU_MINUS;
  65. case PPC::PRED_UN_MINUS: return PPC::PRED_UN_MINUS;
  66. case PPC::PRED_EQ_PLUS: return PPC::PRED_EQ_PLUS;
  67. case PPC::PRED_NE_PLUS: return PPC::PRED_NE_PLUS;
  68. case PPC::PRED_LT_PLUS: return PPC::PRED_GT_PLUS;
  69. case PPC::PRED_GE_PLUS: return PPC::PRED_LE_PLUS;
  70. case PPC::PRED_GT_PLUS: return PPC::PRED_LT_PLUS;
  71. case PPC::PRED_LE_PLUS: return PPC::PRED_GE_PLUS;
  72. case PPC::PRED_NU_PLUS: return PPC::PRED_NU_PLUS;
  73. case PPC::PRED_UN_PLUS: return PPC::PRED_UN_PLUS;
  74. case PPC::PRED_BIT_SET:
  75. case PPC::PRED_BIT_UNSET:
  76. llvm_unreachable("Invalid use of bit predicate code");
  77. }
  78. llvm_unreachable("Unknown PPC branch opcode!");
  79. }