diff options
| author | Andreas Neustifter <astifter-llvm@gmx.at> | 2009-12-02 15:57:15 +0000 |
|---|---|---|
| committer | Andreas Neustifter <astifter-llvm@gmx.at> | 2009-12-02 15:57:15 +0000 |
| commit | 3d207290fefe6d1983bd46d22724a971b96a587e (patch) | |
| tree | 13b45d00296b10e41358308849637ba7a5cc204d /llvm | |
| parent | eee88bc5d2c660dd087a8d32f37e606e1297c429 (diff) | |
| download | bcm5719-llvm-3d207290fefe6d1983bd46d22724a971b96a587e.tar.gz bcm5719-llvm-3d207290fefe6d1983bd46d22724a971b96a587e.zip | |
Cheap, mostly strict, stable sorting.
This is necessary for tests so the results are comparable.
llvm-svn: 90320
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Transforms/Instrumentation/MaximumSpanningTree.h | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Instrumentation/MaximumSpanningTree.h b/llvm/lib/Transforms/Instrumentation/MaximumSpanningTree.h index 2951dbcea9a..829da6b295d 100644 --- a/llvm/lib/Transforms/Instrumentation/MaximumSpanningTree.h +++ b/llvm/lib/Transforms/Instrumentation/MaximumSpanningTree.h @@ -15,6 +15,7 @@ #ifndef LLVM_ANALYSIS_MAXIMUMSPANNINGTREE_H #define LLVM_ANALYSIS_MAXIMUMSPANNINGTREE_H +#include "llvm/BasicBlock.h" #include "llvm/ADT/EquivalenceClasses.h" #include <vector> #include <algorithm> @@ -33,6 +34,18 @@ namespace llvm { typename MaximumSpanningTree<CT>::EdgeWeight Y) const { if (X.second > Y.second) return true; if (X.second < Y.second) return false; + if (const BasicBlock *BBX = dyn_cast<BasicBlock>(X.first.first)) { + if (const BasicBlock *BBY = dyn_cast<BasicBlock>(Y.first.first)) { + if (BBX->size() > BBY->size()) return true; + if (BBX->size() < BBY->size()) return false; + } + } + if (const BasicBlock *BBX = dyn_cast<BasicBlock>(X.first.second)) { + if (const BasicBlock *BBY = dyn_cast<BasicBlock>(Y.first.second)) { + if (BBX->size() > BBY->size()) return true; + if (BBX->size() < BBY->size()) return false; + } + } return false; } }; |

