Fix bug with FP stur instructions.
authorJim Wilson <jim.wilson@linaro.org>
Thu, 1 Dec 2016 17:06:07 +0000 (09:06 -0800)
committerJim Wilson <jim.wilson@linaro.org>
Thu, 1 Dec 2016 17:06:07 +0000 (09:06 -0800)
sim/aarch64
* simulator.c (fsturs): Switch use of rn and st variables.
(fsturd, fsturq): Likewise

sim/aarch64/ChangeLog
sim/aarch64/simulator.c

index dcb4ac99282e777cca039ae9e76f7ac2de8daac7..a632bb4742d4c1efa8a6846ca18eb194c866ef98 100644 (file)
@@ -1,3 +1,8 @@
+2016-12-01  Jim Wilson  <jim.wilson@linaro.org>
+
+       * sim/aarch64/simulator.c (fsturs): Switch use of rn and st variables.
+       (fsturd, fsturq): Likewise
+
 2016-08-15  Mike Frysinger  <vapier@gentoo.org>
 
        * interp.c: Include bfd.h.
index e5ada18efee50be29c42a7758289ddea0a78eefa..4fa5dc1a5963d8bb9783a72870290584e28da8a6 100644 (file)
@@ -7497,8 +7497,8 @@ fsturs (sim_cpu *cpu, int32_t offset)
   unsigned int st = INSTR (4, 0);
 
   TRACE_DECODE (cpu, "emulated at line %d", __LINE__);
-  aarch64_set_mem_u32 (cpu, aarch64_get_reg_u64 (cpu, st, 1) + offset,
-                      aarch64_get_vec_u32 (cpu, rn, 0));
+  aarch64_set_mem_u32 (cpu, aarch64_get_reg_u64 (cpu, rn, 1) + offset,
+                      aarch64_get_vec_u32 (cpu, st, 0));
 }
 
 /* Store 64 bit unscaled signed 9 bit.  */
@@ -7509,8 +7509,8 @@ fsturd (sim_cpu *cpu, int32_t offset)
   unsigned int st = INSTR (4, 0);
 
   TRACE_DECODE (cpu, "emulated at line %d", __LINE__);
-  aarch64_set_mem_u64 (cpu, aarch64_get_reg_u64 (cpu, st, 1) + offset,
-                      aarch64_get_vec_u64 (cpu, rn, 0));
+  aarch64_set_mem_u64 (cpu, aarch64_get_reg_u64 (cpu, rn, 1) + offset,
+                      aarch64_get_vec_u64 (cpu, st, 0));
 }
 
 /* Store 128 bit unscaled signed 9 bit.  */
@@ -7522,9 +7522,9 @@ fsturq (sim_cpu *cpu, int32_t offset)
   FRegister a;
 
   TRACE_DECODE (cpu, "emulated at line %d", __LINE__);
-  aarch64_get_FP_long_double (cpu, rn, & a);
+  aarch64_get_FP_long_double (cpu, st, & a);
   aarch64_set_mem_long_double (cpu,
-                              aarch64_get_reg_u64 (cpu, st, 1)
+                              aarch64_get_reg_u64 (cpu, rn, 1)
                               + offset, a);
 }