1//===- AArch64SchedPredExynos.td - AArch64 Sched Preds -----*- 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// This file defines scheduling predicate definitions that are used by the 10// AArch64 Exynos processors. 11// 12//===----------------------------------------------------------------------===// 13 14// Auxiliary predicates. 15 16// Check the shift in arithmetic and logic instructions. 17def ExynosCheckShift : CheckAny<[CheckShiftBy0, 18 CheckAll< 19 [CheckShiftLSL, 20 CheckAny< 21 [CheckShiftBy1, 22 CheckShiftBy2, 23 CheckShiftBy3]>]>]>; 24 25// Exynos predicates. 26 27// Identify BLR specifying the LR register as the indirect target register. 28def ExynosBranchLinkLRPred : MCSchedPredicate< 29 CheckAll<[CheckOpcode<[BLR]>, 30 CheckRegOperand<0, LR>]>>; 31 32// Identify arithmetic instructions without or with limited extension or shift. 33def ExynosArithFn : TIIPredicate< 34 "isExynosArithFast", 35 MCOpcodeSwitchStatement< 36 [MCOpcodeSwitchCase< 37 IsArithExtOp.ValidOpcodes, 38 MCReturnStatement< 39 CheckAny<[CheckExtBy0, 40 CheckAll< 41 [CheckAny< 42 [CheckExtUXTW, 43 CheckExtUXTX]>, 44 CheckAny< 45 [CheckExtBy1, 46 CheckExtBy2, 47 CheckExtBy3]>]>]>>>, 48 MCOpcodeSwitchCase< 49 IsArithShiftOp.ValidOpcodes, 50 MCReturnStatement<ExynosCheckShift>>, 51 MCOpcodeSwitchCase< 52 IsArithUnshiftOp.ValidOpcodes, 53 MCReturnStatement<TruePred>>, 54 MCOpcodeSwitchCase< 55 IsArithImmOp.ValidOpcodes, 56 MCReturnStatement<TruePred>>], 57 MCReturnStatement<FalsePred>>>; 58def ExynosArithPred : MCSchedPredicate<ExynosArithFn>; 59 60// Identify logic instructions with limited shift. 61def ExynosLogicFn : TIIPredicate< 62 "isExynosLogicFast", 63 MCOpcodeSwitchStatement< 64 [MCOpcodeSwitchCase< 65 IsLogicShiftOp.ValidOpcodes, 66 MCReturnStatement<ExynosCheckShift>>, 67 MCOpcodeSwitchCase< 68 IsLogicUnshiftOp.ValidOpcodes, 69 MCReturnStatement<TruePred>>, 70 MCOpcodeSwitchCase< 71 IsLogicImmOp.ValidOpcodes, 72 MCReturnStatement<TruePred>>], 73 MCReturnStatement<FalsePred>>>; 74def ExynosLogicPred : MCSchedPredicate<ExynosLogicFn>; 75 76// Identify more logic instructions with limited shift. 77def ExynosLogicExFn : TIIPredicate< 78 "isExynosLogicExFast", 79 MCOpcodeSwitchStatement< 80 [MCOpcodeSwitchCase< 81 IsLogicShiftOp.ValidOpcodes, 82 MCReturnStatement< 83 CheckAny< 84 [ExynosCheckShift, 85 CheckAll< 86 [CheckShiftLSL, 87 CheckShiftBy8]>]>>>, 88 MCOpcodeSwitchCase< 89 IsLogicUnshiftOp.ValidOpcodes, 90 MCReturnStatement<TruePred>>, 91 MCOpcodeSwitchCase< 92 IsLogicImmOp.ValidOpcodes, 93 MCReturnStatement<TruePred>>], 94 MCReturnStatement<FalsePred>>>; 95def ExynosLogicExPred : MCSchedPredicate<ExynosLogicExFn>; 96 97// Identify a load or store using the register offset addressing mode 98// with a scaled non-extended register. 99def ExynosScaledIdxFn : TIIPredicate<"isExynosScaledAddr", 100 MCOpcodeSwitchStatement< 101 [MCOpcodeSwitchCase< 102 IsLoadStoreRegOffsetOp.ValidOpcodes, 103 MCReturnStatement< 104 CheckAny< 105 [CheckMemExtSXTW, 106 CheckMemExtUXTW, 107 CheckMemScaled]>>>], 108 MCReturnStatement<FalsePred>>>; 109def ExynosScaledIdxPred : MCSchedPredicate<ExynosScaledIdxFn>; 110 111// Identify FP instructions. 112def ExynosFPPred : MCSchedPredicate<CheckFpOrNEON>; 113 114// Identify 128-bit NEON instructions. 115def ExynosQFormPred : MCSchedPredicate<CheckQForm>; 116 117// Identify instructions that reset a register efficiently. 118def ExynosResetFn : TIIPredicate< 119 "isExynosResetFast", 120 MCOpcodeSwitchStatement< 121 [MCOpcodeSwitchCase< 122 [ADR, ADRP, 123 MOVNWi, MOVNXi, 124 MOVZWi, MOVZXi], 125 MCReturnStatement<TruePred>>, 126 MCOpcodeSwitchCase< 127 [ORRWri, ORRXri], 128 MCReturnStatement< 129 CheckAll< 130 [CheckIsRegOperand<1>, 131 CheckAny< 132 [CheckRegOperand<1, WZR>, 133 CheckRegOperand<1, XZR>]>]>>>], 134 MCReturnStatement< 135 CheckAny< 136 [IsCopyIdiomFn, 137 IsZeroFPIdiomFn]>>>>; 138def ExynosResetPred : MCSchedPredicate<ExynosResetFn>; 139 140// Identify EXTR as the alias for ROR (immediate). 141def ExynosRotateRightImmPred : MCSchedPredicate< 142 CheckAll<[CheckOpcode<[EXTRWrri, EXTRXrri]>, 143 CheckSameRegOperand<1, 2>]>>; 144 145// Identify cheap arithmetic and logic immediate instructions. 146def ExynosCheapFn : TIIPredicate< 147 "isExynosCheapAsMove", 148 MCOpcodeSwitchStatement< 149 [MCOpcodeSwitchCase< 150 IsArithLogicImmOp.ValidOpcodes, 151 MCReturnStatement<TruePred>>], 152 MCReturnStatement< 153 CheckAny< 154 [ExynosArithFn, ExynosResetFn, ExynosLogicFn]>>>>; 155