aboutsummaryrefslogtreecommitdiffstats
path: root/lib/CodeGen/ScheduleDAGInstrs.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-12-23 21:37:04 +0000
committerDan Gohman <gohman@apple.com>2008-12-23 21:37:04 +0000
commitbebba8d5cc675a8b9d7695c6105cff81b2e73fbd (patch)
treeb3edf8b330ceaee6b098e99f138410a59887cbc9 /lib/CodeGen/ScheduleDAGInstrs.cpp
parentb36ace903a32e0e8b24481294748799ee5d1b42e (diff)
downloadexternal_llvm-bebba8d5cc675a8b9d7695c6105cff81b2e73fbd.zip
external_llvm-bebba8d5cc675a8b9d7695c6105cff81b2e73fbd.tar.gz
external_llvm-bebba8d5cc675a8b9d7695c6105cff81b2e73fbd.tar.bz2
Clean up the atomic opcodes in SelectionDAG.
This removes all the _8, _16, _32, and _64 opcodes and replaces each group with an unsuffixed opcode. The MemoryVT field of the AtomicSDNode is now used to carry the size information. In tablegen, the size-specific opcodes are replaced by size-independent opcodes that utilize the ability to compose them with predicates. This shrinks the per-opcode tables and makes the code that handles atomics much more concise. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@61389 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/ScheduleDAGInstrs.cpp')
-rw-r--r--lib/CodeGen/ScheduleDAGInstrs.cpp1
1 files changed, 1 insertions, 0 deletions
diff --git a/lib/CodeGen/ScheduleDAGInstrs.cpp b/lib/CodeGen/ScheduleDAGInstrs.cpp
index 8cff5b5..c162d0e 100644
--- a/lib/CodeGen/ScheduleDAGInstrs.cpp
+++ b/lib/CodeGen/ScheduleDAGInstrs.cpp
@@ -413,6 +413,7 @@ MachineBasicBlock *ScheduleDAGInstrs::EmitSchedule() {
while (!BB->empty())
BB->remove(BB->begin());
+ // Then re-insert them according to the given schedule.
for (unsigned i = 0, e = Sequence.size(); i != e; i++) {
SUnit *SU = Sequence[i];
if (!SU) {