PPCSchedule.td 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. //===-- PPCSchedule.td - PowerPC Scheduling Definitions ----*- tablegen -*-===//
  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. // Instruction Itinerary classes used for PowerPC
  10. //
  11. def IIC_IntSimple : InstrItinClass;
  12. def IIC_IntGeneral : InstrItinClass;
  13. def IIC_IntCompare : InstrItinClass;
  14. def IIC_IntISEL : InstrItinClass;
  15. def IIC_IntDivD : InstrItinClass;
  16. def IIC_IntDivW : InstrItinClass;
  17. def IIC_IntMFFS : InstrItinClass;
  18. def IIC_IntMFVSCR : InstrItinClass;
  19. def IIC_IntMTFSB0 : InstrItinClass;
  20. def IIC_IntMTSRD : InstrItinClass;
  21. def IIC_IntMulHD : InstrItinClass;
  22. def IIC_IntMulHW : InstrItinClass;
  23. def IIC_IntMulHWU : InstrItinClass;
  24. def IIC_IntMulLI : InstrItinClass;
  25. def IIC_IntRFID : InstrItinClass;
  26. def IIC_IntRotateD : InstrItinClass;
  27. def IIC_IntRotateDI : InstrItinClass;
  28. def IIC_IntRotate : InstrItinClass;
  29. def IIC_IntShift : InstrItinClass;
  30. def IIC_IntTrapD : InstrItinClass;
  31. def IIC_IntTrapW : InstrItinClass;
  32. def IIC_BrB : InstrItinClass;
  33. def IIC_BrCR : InstrItinClass;
  34. def IIC_BrMCR : InstrItinClass;
  35. def IIC_BrMCRX : InstrItinClass;
  36. def IIC_LdStDCBA : InstrItinClass;
  37. def IIC_LdStDCBF : InstrItinClass;
  38. def IIC_LdStDCBI : InstrItinClass;
  39. def IIC_LdStLoad : InstrItinClass;
  40. def IIC_LdStLoadUpd : InstrItinClass;
  41. def IIC_LdStLoadUpdX : InstrItinClass;
  42. def IIC_LdStStore : InstrItinClass;
  43. def IIC_LdStDSS : InstrItinClass;
  44. def IIC_LdStICBI : InstrItinClass;
  45. def IIC_LdStLD : InstrItinClass;
  46. def IIC_LdStLDU : InstrItinClass;
  47. def IIC_LdStLDUX : InstrItinClass;
  48. def IIC_LdStLDARX : InstrItinClass;
  49. def IIC_LdStLFD : InstrItinClass;
  50. def IIC_LdStLFDU : InstrItinClass;
  51. def IIC_LdStLFDUX : InstrItinClass;
  52. def IIC_LdStLHA : InstrItinClass;
  53. def IIC_LdStLHAU : InstrItinClass;
  54. def IIC_LdStLHAUX : InstrItinClass;
  55. def IIC_LdStLMW : InstrItinClass;
  56. def IIC_LdStLQ : InstrItinClass;
  57. def IIC_LdStLQARX : InstrItinClass;
  58. def IIC_LdStLVecX : InstrItinClass;
  59. def IIC_LdStLWA : InstrItinClass;
  60. def IIC_LdStLWARX : InstrItinClass;
  61. def IIC_LdStSLBIA : InstrItinClass;
  62. def IIC_LdStSLBIE : InstrItinClass;
  63. def IIC_LdStSTD : InstrItinClass;
  64. def IIC_LdStSTDCX : InstrItinClass;
  65. def IIC_LdStSTQ : InstrItinClass;
  66. def IIC_LdStSTQCX : InstrItinClass;
  67. def IIC_LdStSTU : InstrItinClass;
  68. def IIC_LdStSTUX : InstrItinClass;
  69. def IIC_LdStSTFD : InstrItinClass;
  70. def IIC_LdStSTFDU : InstrItinClass;
  71. def IIC_LdStSTVEBX : InstrItinClass;
  72. def IIC_LdStSTWCX : InstrItinClass;
  73. def IIC_LdStSync : InstrItinClass;
  74. def IIC_LdStCOPY : InstrItinClass;
  75. def IIC_LdStPASTE : InstrItinClass;
  76. def IIC_SprISYNC : InstrItinClass;
  77. def IIC_SprMFSR : InstrItinClass;
  78. def IIC_SprMTMSR : InstrItinClass;
  79. def IIC_SprMTSR : InstrItinClass;
  80. def IIC_SprTLBSYNC : InstrItinClass;
  81. def IIC_SprMFCR : InstrItinClass;
  82. def IIC_SprMFCRF : InstrItinClass;
  83. def IIC_SprMFMSR : InstrItinClass;
  84. def IIC_SprMFSPR : InstrItinClass;
  85. def IIC_SprMFTB : InstrItinClass;
  86. def IIC_SprMTSPR : InstrItinClass;
  87. def IIC_SprMTSRIN : InstrItinClass;
  88. def IIC_SprRFI : InstrItinClass;
  89. def IIC_SprSC : InstrItinClass;
  90. def IIC_FPGeneral : InstrItinClass;
  91. def IIC_FPDGeneral : InstrItinClass;
  92. def IIC_FPSGeneral : InstrItinClass;
  93. def IIC_FPAddSub : InstrItinClass;
  94. def IIC_FPCompare : InstrItinClass;
  95. def IIC_FPDivD : InstrItinClass;
  96. def IIC_FPDivS : InstrItinClass;
  97. def IIC_FPFused : InstrItinClass;
  98. def IIC_FPRes : InstrItinClass;
  99. def IIC_FPSqrtD : InstrItinClass;
  100. def IIC_FPSqrtS : InstrItinClass;
  101. def IIC_VecGeneral : InstrItinClass;
  102. def IIC_VecFP : InstrItinClass;
  103. def IIC_VecFPCompare : InstrItinClass;
  104. def IIC_VecComplex : InstrItinClass;
  105. def IIC_VecPerm : InstrItinClass;
  106. def IIC_VecFPRound : InstrItinClass;
  107. def IIC_VecVSL : InstrItinClass;
  108. def IIC_VecVSR : InstrItinClass;
  109. def IIC_SprMTMSRD : InstrItinClass;
  110. def IIC_SprSLIE : InstrItinClass;
  111. def IIC_SprSLBFEE : InstrItinClass;
  112. def IIC_SprSLBIE : InstrItinClass;
  113. def IIC_SprSLBIEG : InstrItinClass;
  114. def IIC_SprSLBMTE : InstrItinClass;
  115. def IIC_SprSLBMFEE : InstrItinClass;
  116. def IIC_SprSLBMFEV : InstrItinClass;
  117. def IIC_SprSLBIA : InstrItinClass;
  118. def IIC_SprSLBSYNC : InstrItinClass;
  119. def IIC_SprTLBIA : InstrItinClass;
  120. def IIC_SprTLBIEL : InstrItinClass;
  121. def IIC_SprTLBIE : InstrItinClass;
  122. def IIC_SprABORT : InstrItinClass;
  123. def IIC_SprMSGSYNC : InstrItinClass;
  124. def IIC_SprSTOP : InstrItinClass;
  125. def IIC_SprMFPMR : InstrItinClass;
  126. def IIC_SprMTPMR : InstrItinClass;
  127. //===----------------------------------------------------------------------===//
  128. // Processor instruction itineraries.
  129. include "PPCInstrInfo.td"
  130. include "PPCSchedPredicates.td"
  131. include "PPCScheduleG3.td"
  132. include "PPCSchedule440.td"
  133. include "PPCScheduleG4.td"
  134. include "PPCScheduleG4Plus.td"
  135. include "PPCScheduleG5.td"
  136. include "PPCScheduleP7.td"
  137. include "PPCScheduleP8.td"
  138. include "PPCScheduleP9.td"
  139. include "PPCScheduleP10.td"
  140. include "PPCScheduleA2.td"
  141. include "PPCScheduleE500.td"
  142. include "PPCScheduleE500mc.td"
  143. include "PPCScheduleE5500.td"