summaryrefslogtreecommitdiff
path: root/compiler/optimizing/graph_checker.cc
diff options
context:
space:
mode:
author Roland Levillain <rpl@google.com> 2016-03-30 19:09:03 +0100
committer Roland Levillain <rpl@google.com> 2016-03-30 19:09:03 +0100
commitf355c3ff08710ac2eba3aac2aacc5e65caa06b4c (patch)
tree1d9f9487897fabc539f748be881f9c8140c16cef /compiler/optimizing/graph_checker.cc
parent6f51d7756a9c66007fe7666b19399e1f60ff6092 (diff)
Fix Boolean to integral types conversions.
Bug: 27616343 Change-Id: I050f92045bca1b8b5d6da53547cc617f17be84b1
Diffstat (limited to 'compiler/optimizing/graph_checker.cc')
-rw-r--r--compiler/optimizing/graph_checker.cc15
1 files changed, 15 insertions, 0 deletions
diff --git a/compiler/optimizing/graph_checker.cc b/compiler/optimizing/graph_checker.cc
index f2e77e28a6..c790d013b5 100644
--- a/compiler/optimizing/graph_checker.cc
+++ b/compiler/optimizing/graph_checker.cc
@@ -1005,4 +1005,19 @@ void GraphChecker::VisitBoundType(HBoundType* instruction) {
}
}
+void GraphChecker::VisitTypeConversion(HTypeConversion* instruction) {
+ VisitInstruction(instruction);
+ Primitive::Type result_type = instruction->GetResultType();
+ Primitive::Type input_type = instruction->GetInputType();
+ // Invariant: We should never generate a conversion to a Boolean value.
+ if (result_type == Primitive::kPrimBoolean) {
+ AddError(StringPrintf(
+ "%s %d converts to a %s (from a %s).",
+ instruction->DebugName(),
+ instruction->GetId(),
+ Primitive::PrettyDescriptor(result_type),
+ Primitive::PrettyDescriptor(input_type)));
+ }
+}
+
} // namespace art