• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1//===-- LeonFeatures.td - Describe the Leon Features -------*- tablegen -*-===//
2//
3//                     The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10//
11//===----------------------------------------------------------------------===//
12
13
14//===----------------------------------------------------------------------===//
15// UMAC and SMAC support for LEON3 and LEON4 processors.
16//===----------------------------------------------------------------------===//
17
18//support to casa instruction; for leon3 subtarget only
19def UMACSMACSupport : SubtargetFeature<
20  "hasumacsmac",
21  "HasUmacSmac",
22  "true",
23  "Enable UMAC and SMAC for LEON3 and LEON4 processors"
24>;
25
26
27//===----------------------------------------------------------------------===//
28// CASA Support differs between LEON3-FT GR712RC and LEON3-FT UT699
29// We need to have the option to switch this on and off.
30//===----------------------------------------------------------------------===//
31
32//support to casa instruction; for leon3 subtarget only
33def LeonCASA : SubtargetFeature<
34  "hasleoncasa",
35  "HasLeonCasa",
36  "true",
37  "Enable CASA instruction for LEON3 and LEON4 processors"
38>;
39
40def InsertNOPLoad: SubtargetFeature<
41  "insertnopload",
42  "InsertNOPLoad",
43  "true",
44  "LEON3 erratum fix: Insert a NOP instruction after every single-cycle load instruction when the next instruction is another load/store instruction"
45>;
46
47def DetectRoundChange : SubtargetFeature<
48  "detectroundchange",
49  "DetectRoundChange",
50  "true",
51  "LEON3 erratum detection: Detects any rounding mode change "
52  "request: use only the round-to-nearest rounding mode"
53>;
54
55def FixAllFDIVSQRT : SubtargetFeature<
56  "fixallfdivsqrt",
57  "FixAllFDIVSQRT",
58  "true",
59  "LEON erratum fix: Fix FDIVS/FDIVD/FSQRTS/FSQRTD instructions with NOPs and floating-point store"
60>;
61