From b8a11bbcf139087b7487dee78af275bd87c5d39d Mon Sep 17 00:00:00 2001 From: Mandeep Singh Grang Date: Tue, 14 Nov 2017 18:22:50 +0000 Subject: [PredicateInfo] Stable sort ValueDFS to remove non-deterministic ordering Summary: This fixes failure in Transforms/Util/PredicateInfo/testandor.ll uncovered by D39245. Reviewers: dberlin Reviewed By: dberlin Subscribers: llvm-commits Differential Revision: https://reviews.llvm.org/D39630 llvm-svn: 318165 --- llvm/lib/Transforms/Utils/PredicateInfo.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'llvm/lib/Transforms/Utils/PredicateInfo.cpp') diff --git a/llvm/lib/Transforms/Utils/PredicateInfo.cpp b/llvm/lib/Transforms/Utils/PredicateInfo.cpp index 16b80923bf5..7751b6e1340 100644 --- a/llvm/lib/Transforms/Utils/PredicateInfo.cpp +++ b/llvm/lib/Transforms/Utils/PredicateInfo.cpp @@ -611,7 +611,7 @@ void PredicateInfo::renameUses(SmallPtrSetImpl &OpSet) { } convertUsesToDFSOrdered(Op, OrderedUses); - std::sort(OrderedUses.begin(), OrderedUses.end(), Compare); + std::stable_sort(OrderedUses.begin(), OrderedUses.end(), Compare); SmallVector RenameStack; // For each use, sorted into dfs order, push values and replaces uses with // top of stack, which will represent the reaching def. -- cgit v1.2.3