2018-12-11 01:17:26 +08:00
|
|
|
//===- AArch64SchedPredExynos.td - AArch64 Sched Preds -----*- tablegen -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2018-12-11 01:17:26 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file defines scheduling predicate definitions that are used by the
|
|
|
|
// AArch64 Exynos processors.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2018-12-14 07:19:46 +08:00
|
|
|
// Auxiliary predicates.
|
|
|
|
|
|
|
|
// Check the shift in arithmetic and logic instructions.
|
|
|
|
def ExynosCheckShift : CheckAny<[CheckShiftBy0,
|
|
|
|
CheckAll<
|
|
|
|
[CheckShiftLSL,
|
|
|
|
CheckAny<
|
|
|
|
[CheckShiftBy1,
|
|
|
|
CheckShiftBy2,
|
|
|
|
CheckShiftBy3]>]>]>;
|
|
|
|
|
|
|
|
// Exynos predicates.
|
|
|
|
|
2018-12-11 01:17:26 +08:00
|
|
|
// Identify BLR specifying the LR register as the indirect target register.
|
|
|
|
def ExynosBranchLinkLRPred : MCSchedPredicate<
|
|
|
|
CheckAll<[CheckOpcode<[BLR]>,
|
|
|
|
CheckRegOperand<0, LR>]>>;
|
|
|
|
|
2019-01-09 06:29:58 +08:00
|
|
|
// Identify arithmetic instructions without or with limited extension or shift.
|
|
|
|
def ExynosArithFn : TIIPredicate<
|
|
|
|
"isExynosArithFast",
|
|
|
|
MCOpcodeSwitchStatement<
|
|
|
|
[MCOpcodeSwitchCase<
|
|
|
|
IsArithExtOp.ValidOpcodes,
|
|
|
|
MCReturnStatement<
|
|
|
|
CheckAny<[CheckExtBy0,
|
|
|
|
CheckAll<
|
|
|
|
[CheckAny<
|
|
|
|
[CheckExtUXTW,
|
|
|
|
CheckExtUXTX]>,
|
|
|
|
CheckAny<
|
|
|
|
[CheckExtBy1,
|
|
|
|
CheckExtBy2,
|
|
|
|
CheckExtBy3]>]>]>>>,
|
|
|
|
MCOpcodeSwitchCase<
|
|
|
|
IsArithShiftOp.ValidOpcodes,
|
2019-01-12 06:39:47 +08:00
|
|
|
MCReturnStatement<ExynosCheckShift>>,
|
|
|
|
MCOpcodeSwitchCase<
|
|
|
|
IsArithUnshiftOp.ValidOpcodes,
|
|
|
|
MCReturnStatement<TruePred>>],
|
2019-01-09 06:29:58 +08:00
|
|
|
MCReturnStatement<FalsePred>>>;
|
|
|
|
def ExynosArithPred : MCSchedPredicate<ExynosArithFn>;
|
|
|
|
|
|
|
|
// Identify logic instructions with limited shift.
|
|
|
|
def ExynosLogicFn : TIIPredicate<
|
|
|
|
"isExynosLogicFast",
|
|
|
|
MCOpcodeSwitchStatement<
|
|
|
|
[MCOpcodeSwitchCase<
|
|
|
|
IsLogicShiftOp.ValidOpcodes,
|
2019-01-12 06:39:47 +08:00
|
|
|
MCReturnStatement<ExynosCheckShift>>,
|
|
|
|
MCOpcodeSwitchCase<
|
|
|
|
IsLogicUnshiftOp.ValidOpcodes,
|
|
|
|
MCReturnStatement<TruePred>>],
|
2019-01-09 06:29:58 +08:00
|
|
|
MCReturnStatement<FalsePred>>>;
|
|
|
|
def ExynosLogicPred : MCSchedPredicate<ExynosLogicFn>;
|
|
|
|
|
|
|
|
// Identify more logic instructions with limited shift.
|
|
|
|
def ExynosLogicExFn : TIIPredicate<
|
|
|
|
"isExynosLogicExFast",
|
|
|
|
MCOpcodeSwitchStatement<
|
|
|
|
[MCOpcodeSwitchCase<
|
|
|
|
IsLogicShiftOp.ValidOpcodes,
|
|
|
|
MCReturnStatement<
|
|
|
|
CheckAny<
|
|
|
|
[ExynosCheckShift,
|
|
|
|
CheckAll<
|
|
|
|
[CheckShiftLSL,
|
2019-01-12 06:39:47 +08:00
|
|
|
CheckShiftBy8]>]>>>,
|
|
|
|
MCOpcodeSwitchCase<
|
|
|
|
IsLogicUnshiftOp.ValidOpcodes,
|
|
|
|
MCReturnStatement<TruePred>>],
|
2019-01-09 06:29:58 +08:00
|
|
|
MCReturnStatement<FalsePred>>>;
|
|
|
|
def ExynosLogicExPred : MCSchedPredicate<ExynosLogicExFn>;
|
2018-12-11 01:17:26 +08:00
|
|
|
|
2018-12-15 04:04:58 +08:00
|
|
|
// Identify a load or store using the register offset addressing mode
|
|
|
|
// with a scaled non-extended register.
|
|
|
|
def ExynosScaledIdxFn : TIIPredicate<"isExynosScaledAddr",
|
|
|
|
MCOpcodeSwitchStatement<
|
|
|
|
[MCOpcodeSwitchCase<
|
|
|
|
IsLoadStoreRegOffsetOp.ValidOpcodes,
|
|
|
|
MCReturnStatement<
|
|
|
|
CheckAny<
|
|
|
|
[CheckMemExtSXTW,
|
|
|
|
CheckMemExtUXTW,
|
|
|
|
CheckMemScaled]>>>],
|
|
|
|
MCReturnStatement<FalsePred>>>;
|
|
|
|
def ExynosScaledIdxPred : MCSchedPredicate<ExynosScaledIdxFn>;
|
|
|
|
|
2018-12-11 01:17:26 +08:00
|
|
|
// Identify FP instructions.
|
|
|
|
def ExynosFPPred : MCSchedPredicate<CheckAny<[CheckDForm, CheckQForm]>>;
|
|
|
|
|
|
|
|
// Identify 128-bit NEON instructions.
|
|
|
|
def ExynosQFormPred : MCSchedPredicate<CheckQForm>;
|
|
|
|
|
|
|
|
// Identify instructions that reset a register efficiently.
|
|
|
|
def ExynosResetFn : TIIPredicate<
|
|
|
|
"isExynosResetFast",
|
|
|
|
MCOpcodeSwitchStatement<
|
|
|
|
[MCOpcodeSwitchCase<
|
|
|
|
[ADR, ADRP,
|
|
|
|
MOVNWi, MOVNXi,
|
|
|
|
MOVZWi, MOVZXi],
|
2018-12-20 06:24:36 +08:00
|
|
|
MCReturnStatement<TruePred>>,
|
|
|
|
MCOpcodeSwitchCase<
|
|
|
|
[ORRWri, ORRXri],
|
|
|
|
MCReturnStatement<
|
|
|
|
CheckAll<
|
|
|
|
[CheckIsRegOperand<1>,
|
|
|
|
CheckAny<
|
|
|
|
[CheckRegOperand<1, WZR>,
|
|
|
|
CheckRegOperand<1, XZR>]>]>>>],
|
2018-12-11 01:17:26 +08:00
|
|
|
MCReturnStatement<
|
|
|
|
CheckAny<
|
|
|
|
[IsCopyIdiomFn,
|
2018-12-20 06:24:36 +08:00
|
|
|
IsZeroFPIdiomFn]>>>>;
|
2018-12-11 01:17:26 +08:00
|
|
|
def ExynosResetPred : MCSchedPredicate<ExynosResetFn>;
|
|
|
|
|
|
|
|
// Identify EXTR as the alias for ROR (immediate).
|
|
|
|
def ExynosRotateRightImmPred : MCSchedPredicate<
|
|
|
|
CheckAll<[CheckOpcode<[EXTRWrri, EXTRXrri]>,
|
|
|
|
CheckSameRegOperand<1, 2>]>>;
|
|
|
|
|
2019-01-09 06:29:58 +08:00
|
|
|
// Identify cheap arithmetic and logic immediate instructions.
|
2018-12-11 01:17:26 +08:00
|
|
|
def ExynosCheapFn : TIIPredicate<
|
|
|
|
"isExynosCheapAsMove",
|
|
|
|
MCOpcodeSwitchStatement<
|
|
|
|
[MCOpcodeSwitchCase<
|
|
|
|
IsArithLogicImmOp.ValidOpcodes,
|
|
|
|
MCReturnStatement<TruePred>>],
|
|
|
|
MCReturnStatement<
|
|
|
|
CheckAny<
|
2019-01-09 06:29:58 +08:00
|
|
|
[ExynosArithFn, ExynosResetFn, ExynosLogicFn]>>>>;
|