Don't touch carry flag in ASR <reg> with zero <reg>, submitted by Aurelien Jarno.
authorbalrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162>
Mon, 21 May 2007 17:48:01 +0000 (17:48 +0000)
committerbalrog <balrog@c046a42c-6fe2-441c-8c8c-71466251a162>
Mon, 21 May 2007 17:48:01 +0000 (17:48 +0000)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2843 c046a42c-6fe2-441c-8c8c-71466251a162

target-arm/op.c

index fd44a40..d7ac6de 100644 (file)
@@ -667,7 +667,7 @@ void OPPROTO op_sarl_T1_T0_cc(void)
     if (shift >= 32) {
         env->CF = (T1 >> 31) & 1;
         T1 = (int32_t)T1 >> 31;
-    } else {
+    } else if (shift != 0) {
         env->CF = (T1 >> (shift - 1)) & 1;
         T1 = (int32_t)T1 >> shift;
     }