shithub: dav1d

Download patch

ref: 801966ca946661881755a8078661e1c880995e46
parent: f481d69b0ffac087504036375d505f4323d7ef5e
author: Martin Storsjö <martin@martin.st>
date: Mon Mar 23 19:59:41 EDT 2020

arm64: ipred: Use rounded shifts instead of a separate addition

--- a/src/arm/64/ipred.S
+++ b/src/arm/64/ipred.S
@@ -1962,14 +1962,11 @@
         clz             w9,  w9              // ctz(width)
         clz             w10, w10             // ctz(height)
         add             w9,  w9,  w10        // log2sz
-        movi            v16.4s,  #1
         add             x10, x1,  x2
         lsl             x2,  x2,  #1
-        dup             v17.4s,  w9
-        sshl            v16.4s,  v16.4s,  v17.4s // 1 << log2sz
-        neg             v17.4s,  v17.4s          // -log2sz
-        ushr            v16.4s,  v16.4s,  #1     // 1 << (log2sz - 1)
+        dup             v31.4s,  w9
         mov             w9,  w6
+        neg             v31.4s,  v31.4s      // -log2sz
         br              x7
 
 L(ipred_cfl_ac_420_w4):
@@ -2009,8 +2006,7 @@
         add             v0.8h,   v0.8h,   v1.8h
         uaddlv          s0,  v0.8h                // sum
         sub             x0,  x0,  w9, uxtw #3
-        add             v0.2s,   v0.2s,   v16.2s  // sum += 1 << (log2sz - 1)
-        ushl            v4.2s,   v0.2s,   v17.2s  // sum >>= log2sz
+        urshl           v4.2s,   v0.2s,   v31.2s  // (sum + (1 << (log2sz - 1))) >>= log2sz
         dup             v4.8h,   v4.h[0]
 6:      // Subtract dc from ac
         ld1             {v0.8h, v1.8h}, [x0]
@@ -2092,8 +2088,7 @@
         add             v0.4s,   v0.4s,   v2.4s
         addv            s0,  v0.4s                // sum
         sub             x0,  x0,  w9, uxtw #4
-        add             v0.2s,   v0.2s,   v16.2s  // sum += 1 << (log2sz - 1)
-        ushl            v4.2s,   v0.2s,   v17.2s  // sum >>= log2sz
+        urshl           v4.2s,   v0.2s,   v31.2s  // (sum + (1 << (log2sz - 1))) >>= log2sz
         dup             v4.8h,   v4.h[0]
 6:      // Subtract dc from ac
         ld1             {v0.8h, v1.8h, v2.8h, v3.8h}, [x0]
@@ -2269,14 +2264,11 @@
         clz             w9,  w9              // ctz(width)
         clz             w10, w10             // ctz(height)
         add             w9,  w9,  w10        // log2sz
-        movi            v16.4s,  #1
         add             x10, x1,  x2
         lsl             x2,  x2,  #1
-        dup             v17.4s,  w9
-        sshl            v16.4s,  v16.4s,  v17.4s // 1 << log2sz
-        neg             v17.4s,  v17.4s          // -log2sz
-        ushr            v16.4s,  v16.4s,  #1     // 1 << (log2sz - 1)
+        dup             v31.4s,  w9
         mov             w9,  w6
+        neg             v31.4s,  v31.4s      // -log2sz
         br              x7
 
 L(ipred_cfl_ac_422_w4):