# HG changeset patch # User Bernhard Urban # Date 1417614616 -3600 # Node ID f6ca61099649cbd3d518113cf822004e22ff788e # Parent 68cab2726edb1962dd1ac67b1541bf05253afd02 arraycopy: don't use checkcast stub if the arrays overlap diff -r 68cab2726edb -r f6ca61099649 graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/replacements/arraycopy/ArrayCopySnippets.java --- a/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/replacements/arraycopy/ArrayCopySnippets.java Wed Dec 03 14:31:15 2014 +0100 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/replacements/arraycopy/ArrayCopySnippets.java Wed Dec 03 14:50:16 2014 +0100 @@ -190,8 +190,12 @@ Object nonNullSrc = guardingNonNull(src); Object nonNullDest = guardingNonNull(dest); checkLimits(nonNullSrc, srcPos, nonNullDest, destPos, length); - KlassPointer destElemKlass = loadHub(nonNullDest); - checkcastArraycopyHelper(srcPos, destPos, length, nonNullSrc, nonNullDest, destElemKlass); + if (probability(SLOW_PATH_PROBABILITY, nonNullSrc == nonNullDest)) { + System.arraycopy(nonNullSrc, srcPos, nonNullDest, destPos, length); + } else { + KlassPointer destElemKlass = loadHub(nonNullDest); + checkcastArraycopyHelper(srcPos, destPos, length, nonNullSrc, nonNullDest, destElemKlass); + } } private static void checkcastArraycopyHelper(int srcPos, int destPos, int length, Object nonNullSrc, Object nonNullDest, KlassPointer destElemKlass) {