blob: f43a4431d61e8d1c19b0f0521d9bca1ac07b5c6c [file] [log] [blame]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00001//===- SubtargetEmitter.h - Generate subtarget enumerations -----*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattnerfd6c2f02007-12-29 20:37:13 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Dan Gohmanf17a25c2007-07-18 16:29:46 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This tablegen backend emits subtarget enumerations.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef SUBTARGET_EMITTER_H
15#define SUBTARGET_EMITTER_H
16
17#include "TableGenBackend.h"
18#include "llvm/Target/TargetInstrItineraries.h"
19#include <vector>
20#include <map>
21#include <string>
22
23
24namespace llvm {
25
26class SubtargetEmitter : public TableGenBackend {
27
28 RecordKeeper &Records;
29 std::string Target;
30 bool HasItineraries;
31
Daniel Dunbard4287062009-07-03 00:10:29 +000032 void Enumeration(raw_ostream &OS, const char *ClassName, bool isBits);
33 void FeatureKeyValues(raw_ostream &OS);
34 void CPUKeyValues(raw_ostream &OS);
35 unsigned CollectAllItinClasses(raw_ostream &OS,
Dan Gohmanf17a25c2007-07-18 16:29:46 +000036 std::map<std::string, unsigned> &ItinClassesMap);
Anton Korobeynikov00540072010-04-18 20:31:01 +000037 void FormItineraryStageString(const std::string &Names,
38 Record *ItinData, std::string &ItinString,
David Goodwine0106972009-08-17 16:02:57 +000039 unsigned &NStages);
40 void FormItineraryOperandCycleString(Record *ItinData, std::string &ItinString,
41 unsigned &NOperandCycles);
42 void EmitStageAndOperandCycleData(raw_ostream &OS, unsigned NItinClasses,
Dan Gohmanf17a25c2007-07-18 16:29:46 +000043 std::map<std::string, unsigned> &ItinClassesMap,
44 std::vector<std::vector<InstrItinerary> > &ProcList);
Daniel Dunbard4287062009-07-03 00:10:29 +000045 void EmitProcessorData(raw_ostream &OS,
Dan Gohmanf17a25c2007-07-18 16:29:46 +000046 std::vector<std::vector<InstrItinerary> > &ProcList);
Daniel Dunbard4287062009-07-03 00:10:29 +000047 void EmitProcessorLookup(raw_ostream &OS);
48 void EmitData(raw_ostream &OS);
49 void ParseFeaturesFunction(raw_ostream &OS);
Dan Gohmanf17a25c2007-07-18 16:29:46 +000050
51public:
52 SubtargetEmitter(RecordKeeper &R) : Records(R), HasItineraries(false) {}
53
54 // run - Output the subtarget enumerations, returning true on failure.
Daniel Dunbard4287062009-07-03 00:10:29 +000055 void run(raw_ostream &o);
Dan Gohmanf17a25c2007-07-18 16:29:46 +000056
57};
58
59
60} // End llvm namespace
61
62#endif
63
64
65