summaryrefslogtreecommitdiffstats
path: root/test/etc/default-build
diff options
context:
space:
mode:
authorStephen Kyle <stephen.kyle@arm.com>2014-10-03 13:47:56 +0100
committerStephen Kyle <stephen.kyle@arm.com>2014-11-07 12:51:33 +0000
commit40d3518414202f33c9569ddd8daceabb30208fc2 (patch)
treea28dd757a6a9d212a8d2feb3dfdbcfe584e18c6d /test/etc/default-build
parent88af00a788002196e6f98acd3748f3f4956032bf (diff)
downloadart-40d3518414202f33c9569ddd8daceabb30208fc2.zip
art-40d3518414202f33c9569ddd8daceabb30208fc2.tar.gz
art-40d3518414202f33c9569ddd8daceabb30208fc2.tar.bz2
ART: Fix crash with unreachable void check-cast
return-void check-cast v0, V return-void The above code sequence will not be rejected for the check-cast of a void type because the check-cast is not reachable. However, when GenerateSafeCastSet() is called from the compiler, this will cause IsAssignableFrom(Conflict, Undefined) to be called, as it scans for all check-casts across the code, regardless of its reachableness. RegType::AssignableFrom() has been changed to handle a Conflict type, whereas previously this would break the check that the lhs type is a ReferenceType. Additionally, GenerateSafeCastSet has been changed to never assess instructions that weren't visited during verification. Included is a new test DEX file, 801-VoidCheckCast, that uses this code sequence. Change-Id: I600055ab670ee48a075ffa867b46d2e74f5aa9c0 Signed-off-by: Stephen Kyle <stephen.kyle@arm.com>
Diffstat (limited to 'test/etc/default-build')
-rwxr-xr-xtest/etc/default-build5
1 files changed, 5 insertions, 0 deletions
diff --git a/test/etc/default-build b/test/etc/default-build
index ab859ec..6731ad3 100755
--- a/test/etc/default-build
+++ b/test/etc/default-build
@@ -17,6 +17,11 @@
# Stop if something fails.
set -e
+if [ -e classes.dex ]; then
+ zip $TEST_NAME.jar classes.dex
+ exit 0
+fi
+
mkdir classes
${JAVAC} -d classes `find src -name '*.java'`