diff options
author | Andrew Trick <atrick@apple.com> | 2013-03-01 23:31:26 +0000 |
---|---|---|
committer | Andrew Trick <atrick@apple.com> | 2013-03-01 23:31:26 +0000 |
commit | c812110023c714f773cd176f4e4d63b4e9fbdbef (patch) | |
tree | 1f679992369e41448bfa6ce851a76b95ddb81300 /utils/TableGen | |
parent | 3b05d9f4db3399f524fdf206a22771a87fa321b2 (diff) | |
download | external_llvm-c812110023c714f773cd176f4e4d63b4e9fbdbef.zip external_llvm-c812110023c714f773cd176f4e4d63b4e9fbdbef.tar.gz external_llvm-c812110023c714f773cd176f4e4d63b4e9fbdbef.tar.bz2 |
MIsched machine model: tablegen subtarget emitter improvement.
Fix the way resources are counted. I'm taking some time to cleanup the
way MachineScheduler handles in-order machine resources. Eventually
we'll need more PPC/Atom test cases in tree.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@176390 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen')
-rw-r--r-- | utils/TableGen/SubtargetEmitter.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/utils/TableGen/SubtargetEmitter.cpp b/utils/TableGen/SubtargetEmitter.cpp index fc8d00d..93eef86 100644 --- a/utils/TableGen/SubtargetEmitter.cpp +++ b/utils/TableGen/SubtargetEmitter.cpp @@ -893,7 +893,20 @@ void SubtargetEmitter::GenSchedClassTables(const CodeGenProcModel &ProcModel, WPREntry.Cycles = Cycles[PRIdx]; else WPREntry.Cycles = 1; - WriteProcResources.push_back(WPREntry); + // If this resource is already used in this sequence, add the current + // entry's cycles so that the same resource appears to be used + // serially, rather than multiple parallel uses. This is important for + // in-order machine where the resource consumption is a hazard. + unsigned WPRIdx = 0, WPREnd = WriteProcResources.size(); + for( ; WPRIdx != WPREnd; ++WPRIdx) { + if (WriteProcResources[WPRIdx].ProcResourceIdx + == WPREntry.ProcResourceIdx) { + WriteProcResources[WPRIdx].Cycles += WPREntry.Cycles; + break; + } + } + if (WPRIdx == WPREnd) + WriteProcResources.push_back(WPREntry); } } WriteLatencies.push_back(WLEntry); |