mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-05 20:07:48 +00:00
396941b5b3
...and the two followup commits: Revert "[Sparc][Leon] Missed resetting option flags from check-in 278489." Revert "[Sparc][Leon] Errata fixes for various errata in different versions of the Leon variants of the Sparc 32 bit processor." This reverts commit r274856, r278489, and r278492. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@278511 91177308-0d34-0410-b5e6-96231b3b80d8
67 lines
2.0 KiB
TableGen
Executable File
67 lines
2.0 KiB
TableGen
Executable File
//===-- LeonFeatures.td - Describe the Leon Features -------*- tablegen -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// UMAC and SMAC support for LEON3 and LEON4 processors.
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//support to casa instruction; for leon3 subtarget only
|
|
def UMACSMACSupport : SubtargetFeature<
|
|
"hasumacsmac",
|
|
"HasUmacSmac",
|
|
"true",
|
|
"Enable UMAC and SMAC for LEON3 and LEON4 processors"
|
|
>;
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// CASA Support differs between LEON3-FT GR712RC and LEON3-FT UT699
|
|
// We need to have the option to switch this on and off.
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//support to casa instruction; for leon3 subtarget only
|
|
def LeonCASA : SubtargetFeature<
|
|
"hasleoncasa",
|
|
"HasLeonCasa",
|
|
"true",
|
|
"Enable CASA instruction for LEON3 and LEON4 processors"
|
|
>;
|
|
|
|
def InsertNOPLoad: SubtargetFeature<
|
|
"insertnopload",
|
|
"InsertNOPLoad",
|
|
"true",
|
|
"LEON3 erratum fix: Insert a NOP instruction after every single-cycle load instruction when the next instruction is another load/store instruction"
|
|
>;
|
|
|
|
def FixFSMULD : SubtargetFeature<
|
|
"fixfsmuld",
|
|
"FixFSMULD",
|
|
"true",
|
|
"LEON erratum fix: Do not use FSMULD"
|
|
>;
|
|
|
|
def ReplaceFMULS : SubtargetFeature<
|
|
"replacefmuls",
|
|
"ReplaceFMULS",
|
|
"true",
|
|
"LEON erratum fix: Replace FMULS instruction with FMULD and relevant conversion instructions"
|
|
>;
|
|
|
|
def FixAllFDIVSQRT : SubtargetFeature<
|
|
"fixallfdivsqrt",
|
|
"FixAllFDIVSQRT",
|
|
"true",
|
|
"LEON erratum fix: Fix FDIVS/FDIVD/FSQRTS/FSQRTD instructions with NOPs and floating-point store"
|
|
>;
|