blob: ff01274bd1a7f33e897034885b9f7eb29414a0f7 [file] [log] [blame]
Jim Laskey4bb9cbb2005-10-21 19:00:04 +00001//===- SubtargetEmitter.h - Generate subtarget enumerations -----*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner30609102007-12-29 20:37:13 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Jim Laskey4bb9cbb2005-10-21 19:00:04 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This tablegen backend emits subtarget enumerations.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef SUBTARGET_EMITTER_H
15#define SUBTARGET_EMITTER_H
16
Peter Collingbourne7c788882011-10-01 16:41:13 +000017#include "llvm/TableGen/TableGenBackend.h"
Evan Chengab8be962011-06-29 01:14:12 +000018#include "llvm/MC/MCInstrItineraries.h"
Jim Laskey0d841e02005-10-27 19:47:21 +000019#include <vector>
20#include <map>
21#include <string>
22
Jim Laskey4bb9cbb2005-10-21 19:00:04 +000023
24namespace llvm {
25
26class SubtargetEmitter : public TableGenBackend {
Andrew Trickda96cf22011-04-01 01:56:55 +000027
Jim Laskey4bb9cbb2005-10-21 19:00:04 +000028 RecordKeeper &Records;
Jim Laskey581a8f72005-10-26 17:30:34 +000029 std::string Target;
Jim Laskey6cee6302005-11-01 20:06:59 +000030 bool HasItineraries;
Andrew Trickda96cf22011-04-01 01:56:55 +000031
Daniel Dunbar1a551802009-07-03 00:10:29 +000032 void Enumeration(raw_ostream &OS, const char *ClassName, bool isBits);
Evan Cheng94214702011-07-01 20:45:01 +000033 unsigned FeatureKeyValues(raw_ostream &OS);
34 unsigned CPUKeyValues(raw_ostream &OS);
Daniel Dunbar1a551802009-07-03 00:10:29 +000035 unsigned CollectAllItinClasses(raw_ostream &OS,
Evan Cheng5f54ce32010-09-09 18:18:55 +000036 std::map<std::string,unsigned> &ItinClassesMap,
37 std::vector<Record*> &ItinClassList);
Anton Korobeynikov928eb492010-04-18 20:31:01 +000038 void FormItineraryStageString(const std::string &Names,
39 Record *ItinData, std::string &ItinString,
David Goodwinfac85412009-08-17 16:02:57 +000040 unsigned &NStages);
41 void FormItineraryOperandCycleString(Record *ItinData, std::string &ItinString,
42 unsigned &NOperandCycles);
Evan Cheng63d66ee2010-09-28 23:50:49 +000043 void FormItineraryBypassString(const std::string &Names,
44 Record *ItinData,
45 std::string &ItinString, unsigned NOperandCycles);
David Goodwinfac85412009-08-17 16:02:57 +000046 void EmitStageAndOperandCycleData(raw_ostream &OS, unsigned NItinClasses,
Jim Laskeyf7bcde02005-10-28 21:47:29 +000047 std::map<std::string, unsigned> &ItinClassesMap,
Evan Cheng5f54ce32010-09-09 18:18:55 +000048 std::vector<Record*> &ItinClassList,
Jim Laskeyf7bcde02005-10-28 21:47:29 +000049 std::vector<std::vector<InstrItinerary> > &ProcList);
Daniel Dunbar1a551802009-07-03 00:10:29 +000050 void EmitProcessorData(raw_ostream &OS,
Andrew Trick23482322011-04-01 02:22:47 +000051 std::vector<Record*> &ItinClassList,
52 std::vector<std::vector<InstrItinerary> > &ProcList);
Daniel Dunbar1a551802009-07-03 00:10:29 +000053 void EmitProcessorLookup(raw_ostream &OS);
54 void EmitData(raw_ostream &OS);
Evan Cheng94214702011-07-01 20:45:01 +000055 void ParseFeaturesFunction(raw_ostream &OS, unsigned NumFeatures,
56 unsigned NumProcs);
Andrew Trickda96cf22011-04-01 01:56:55 +000057
Jim Laskey4bb9cbb2005-10-21 19:00:04 +000058public:
Jim Laskey6cee6302005-11-01 20:06:59 +000059 SubtargetEmitter(RecordKeeper &R) : Records(R), HasItineraries(false) {}
Jim Laskey4bb9cbb2005-10-21 19:00:04 +000060
61 // run - Output the subtarget enumerations, returning true on failure.
Daniel Dunbar1a551802009-07-03 00:10:29 +000062 void run(raw_ostream &o);
Jim Laskey4bb9cbb2005-10-21 19:00:04 +000063
64};
65
66
67} // End llvm namespace
68
69#endif
70
71
72