]> sourceware.org Git - newlib-cygwin.git/commitdiff
Fix issue with dst bias in memset
authorWilco Dijkstra <Wilco.Dijkstra@arm.com>
Thu, 8 Nov 2018 15:50:42 +0000 (15:50 +0000)
committerRichard Earnshaw <Richard.Earnshaw@arm.com>
Thu, 8 Nov 2018 16:45:19 +0000 (16:45 +0000)
This patch fixes an issue in the previous memset loop change. If the
zva size is >= 256 and there are more than 64 bytes left in the
tail, we could enter the loop and thus need to rebias dst by 32 as
well.

Since no known CPUs use this size this can't be tested natively, so I've
tested it on a simulator initialized with a large zva size.

--

newlib/libc/machine/aarch64/memset.S

index 7c8fe583bf88722d73b90ec470c72b509e5be137..103e3f8bb0f20a5d02578f2379620687eae10a52 100644 (file)
@@ -233,6 +233,7 @@ L(zva_other):
        subs    count, count, zva_len
        b.hs    3b
 4:     add     count, count, zva_len
+       sub     dst, dst, 32            /* Bias dst for tail loop.  */
        b       L(tail64)
 
        .size   memset, . - memset
This page took 0.032677 seconds and 5 git commands to generate.