2012-02-18 20:03:15 +08:00
|
|
|
//===- HexagonSchedule.td - Hexagon Scheduling Definitions -*- tablegen -*-===//
|
2011-12-13 05:14:40 +08:00
|
|
|
//
|
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
|
2011-12-13 05:14:40 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2017-05-04 04:10:36 +08:00
|
|
|
def Hex_FWD : Bypass;
|
|
|
|
def HVX_FWD : Bypass;
|
|
|
|
|
|
|
|
// Functional Units.
|
|
|
|
def SLOT0 : FuncUnit;
|
|
|
|
def SLOT1 : FuncUnit;
|
|
|
|
def SLOT2 : FuncUnit;
|
|
|
|
def SLOT3 : FuncUnit;
|
|
|
|
// Endloop is a pseudo instruction that is encoded with 2 bits in a packet
|
|
|
|
// rather than taking an execution slot. This special unit is needed
|
|
|
|
// to schedule an ENDLOOP with 4 other instructions.
|
|
|
|
def SLOT_ENDLOOP: FuncUnit;
|
|
|
|
|
|
|
|
// CVI pipes from the "Hexagon Multimedia Co-Processor Extensions Arch Spec".
|
|
|
|
def CVI_ST : FuncUnit;
|
|
|
|
def CVI_XLANE : FuncUnit;
|
|
|
|
def CVI_SHIFT : FuncUnit;
|
|
|
|
def CVI_MPY0 : FuncUnit;
|
|
|
|
def CVI_MPY1 : FuncUnit;
|
|
|
|
def CVI_LD : FuncUnit;
|
2018-12-06 05:01:07 +08:00
|
|
|
def CVI_ZW : FuncUnit; // Z register write port
|
2017-05-04 04:10:36 +08:00
|
|
|
|
|
|
|
// Combined functional units.
|
|
|
|
def CVI_XLSHF : FuncUnit;
|
|
|
|
def CVI_MPY01 : FuncUnit;
|
|
|
|
def CVI_ALL : FuncUnit;
|
|
|
|
def CVI_ALL_NOMEM : FuncUnit;
|
|
|
|
|
|
|
|
// Combined functional unit data.
|
|
|
|
def HexagonComboFuncsV60 :
|
|
|
|
ComboFuncUnits<[
|
|
|
|
ComboFuncData<CVI_XLSHF , [CVI_XLANE, CVI_SHIFT]>,
|
|
|
|
ComboFuncData<CVI_MPY01 , [CVI_MPY0, CVI_MPY1]>,
|
|
|
|
ComboFuncData<CVI_ALL , [CVI_ST, CVI_XLANE, CVI_SHIFT,
|
|
|
|
CVI_MPY0, CVI_MPY1, CVI_LD]>,
|
|
|
|
ComboFuncData<CVI_ALL_NOMEM, [CVI_XLANE, CVI_SHIFT, CVI_MPY0, CVI_MPY1]>
|
|
|
|
]>;
|
|
|
|
|
|
|
|
// Itinerary classes.
|
|
|
|
def PSEUDO : InstrItinClass;
|
|
|
|
def PSEUDOM : InstrItinClass;
|
|
|
|
def DUPLEX : InstrItinClass;
|
|
|
|
def tc_ENDLOOP : InstrItinClass;
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Auto-generated itinerary classes
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
include "HexagonDepIICScalar.td"
|
|
|
|
include "HexagonDepIICHVX.td"
|
|
|
|
|
2018-10-20 01:31:11 +08:00
|
|
|
include "HexagonScheduleV5.td"
|
2015-10-17 09:33:04 +08:00
|
|
|
include "HexagonScheduleV55.td"
|
|
|
|
|
2017-02-11 07:46:45 +08:00
|
|
|
include "HexagonIICScalar.td"
|
|
|
|
include "HexagonIICHVX.td"
|
2017-05-04 04:10:36 +08:00
|
|
|
include "HexagonScheduleV60.td"
|
2017-02-11 07:46:45 +08:00
|
|
|
|
|
|
|
include "HexagonScheduleV62.td"
|
2017-12-12 02:57:54 +08:00
|
|
|
include "HexagonScheduleV65.td"
|
2018-12-06 05:01:07 +08:00
|
|
|
include "HexagonScheduleV66.td"
|
2020-01-18 06:29:40 +08:00
|
|
|
include "HexagonScheduleV67.td"
|
2020-01-14 06:07:30 +08:00
|
|
|
include "HexagonScheduleV67T.td"
|