]> git.alsa-project.org Git - alsa-lib.git/commitdiff
pcm: dmix: assembly: refactor the PIC mode
authorFrédéric Recoules <frederic.recoules@orange.fr>
Wed, 6 May 2020 17:19:23 +0000 (19:19 +0200)
committerTakashi Iwai <tiwai@suse.de>
Wed, 6 May 2020 20:27:11 +0000 (22:27 +0200)
Newer versions of GCC (> 5.0) accept that ebx is declared
in the clobber list even in PIC mode. Meanwhile, even
unlikely, the compiler may use ebx as base address of
one of the memory entry, making subsequent access to
them unreliable ('size', 'dst_step', 'src_step', 'sum_step').

Adding ebx in the clobber solves the problem.
By the way, the entry 'old_ebx' is no longer required.

Signed-off-by: Frédéric Recoules <frederic.recoules@orange.fr>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
src/pcm/pcm_dmix_i386.h
src/pcm/pcm_dmix_x86_64.h

index 5c900bf112334bb1ce61dc8764c28426d0301e5d..bd1d6644fcba9194869318c10914dcce6c571037 100644 (file)
  *
  */
 
+#if defined(__GNUC__) && __GNUC__ < 5 && defined(__PIC__)
+#  define BOUNDED_EBX
+#endif
+
 /*
  *  for plain i386
  */
@@ -34,8 +38,9 @@ static void MIX_AREAS_16(unsigned int size,
                         volatile signed int *sum, size_t dst_step,
                         size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_EBX
        unsigned int old_ebx;
-
+#endif
        /*
         *  ESI - src
         *  EDI - dst
@@ -46,8 +51,9 @@ static void MIX_AREAS_16(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_EBX
                "\tmovl %%ebx, %[old_ebx]\n"    /* ebx is GOT pointer (-fPIC) */
+#endif
                /*
                 *  initialization, load ESI, EDI, EBX registers
                 */
@@ -140,13 +146,20 @@ static void MIX_AREAS_16(unsigned int size,
                "\tjnz 1b\n"
 
                "7:"
+#ifdef BOUNDED_EBX
                "\tmovl %[old_ebx], %%ebx\n"    /* ebx is GOT pointer (-fPIC) */
-
-               : [size] "+m" (size), [old_ebx] "=m" (old_ebx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_EBX
+                 , [old_ebx] "=m" (old_ebx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "esi", "edi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_EBX
+                 , "ebx"
+#endif
        );
 }
 
@@ -158,8 +171,9 @@ static void MIX_AREAS_16_MMX(unsigned int size,
                             volatile signed int *sum, size_t dst_step,
                             size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_EBX
        unsigned int old_ebx;
-
+#endif
        /*
         *  ESI - src
         *  EDI - dst
@@ -170,8 +184,9 @@ static void MIX_AREAS_16_MMX(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_EBX
                "\tmovl %%ebx, %[old_ebx]\n"    /* ebx is GOT pointer (-fPIC) */
+#endif
                /*
                 *  initialization, load ESI, EDI, EBX registers
                 */
@@ -230,13 +245,20 @@ static void MIX_AREAS_16_MMX(unsigned int size,
                "\tjnz 1b\n"
                "\temms\n"
                 "5:"
+#ifdef BOUNDED_EBX
                "\tmovl %[old_ebx], %%ebx\n"    /* ebx is GOT pointer (-fPIC) */
-
-               : [size] "+m" (size), [old_ebx] "=m" (old_ebx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_EBX
+                 , [old_ebx] "=m" (old_ebx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "esi", "edi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_EBX
+                 , "ebx"
+#endif
 #ifdef HAVE_MMX
                  , "mm0"
 #else
@@ -254,8 +276,9 @@ static void MIX_AREAS_32(unsigned int size,
                         volatile signed int *sum, size_t dst_step,
                         size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_EBX
        unsigned int old_ebx;
-
+#endif
        /*
         *  ESI - src
         *  EDI - dst
@@ -266,8 +289,9 @@ static void MIX_AREAS_32(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_EBX
                "\tmovl %%ebx, %[old_ebx]\n"    /* ebx is GOT pointer (-fPIC) */
+#endif
                /*
                 *  initialization, load ESI, EDI, EBX registers
                 */
@@ -349,13 +373,20 @@ static void MIX_AREAS_32(unsigned int size,
                "\tjmp 1b\n"
 
                "6:"
+#ifdef BOUNDED_EBX
                "\tmovl %[old_ebx], %%ebx\n"    /* ebx is GOT pointer (-fPIC) */
-
-               : [size] "+m" (size), [old_ebx] "=m" (old_ebx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_EBX
+                 , [old_ebx] "=m" (old_ebx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "esi", "edi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_EBX
+                 , "ebx"
+#endif
        );
 }
 
@@ -367,8 +398,9 @@ static void MIX_AREAS_24(unsigned int size,
                         volatile signed int *sum, size_t dst_step,
                         size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_EBX
        unsigned int old_ebx;
-
+#endif
        /*
         *  ESI - src
         *  EDI - dst
@@ -379,8 +411,9 @@ static void MIX_AREAS_24(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_EBX
                "\tmovl %%ebx, %[old_ebx]\n"    /* ebx is GOT pointer (-fPIC) */
+#endif
                /*
                 *  initialization, load ESI, EDI, EBX registers
                 */
@@ -455,13 +488,20 @@ static void MIX_AREAS_24(unsigned int size,
                "\tjmp 1b\n"
 
                "6:"
+#ifdef BOUNDED_EBX
                "\tmovl %[old_ebx], %%ebx\n"    /* ebx is GOT pointer (-fPIC) */
-
-               : [size] "+m" (size), [old_ebx] "=m" (old_ebx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_EBX
+                 , [old_ebx] "=m" (old_ebx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "esi", "edi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_EBX
+                 , "ebx"
+#endif
        );
 }
 
@@ -473,8 +513,9 @@ static void MIX_AREAS_24_CMOV(unsigned int size,
                              volatile signed int *sum, size_t dst_step,
                              size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_EBX
        unsigned int old_ebx;
-
+#endif
        /*
         *  ESI - src
         *  EDI - dst
@@ -485,8 +526,9 @@ static void MIX_AREAS_24_CMOV(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_EBX
                "\tmovl %%ebx, %[old_ebx]\n"    /* ebx is GOT pointer (-fPIC) */
+#endif
                /*
                 *  initialization, load ESI, EDI, EBX registers
                 */
@@ -554,12 +596,23 @@ static void MIX_AREAS_24_CMOV(unsigned int size,
                "\tjnz 1b\n"
 
                "6:"
+#ifdef BOUNDED_EBX
                "\tmovl %[old_ebx], %%ebx\n"    /* ebx is GOT pointer (-fPIC) */
-
-               : [size] "+m" (size), [old_ebx] "=m" (old_ebx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_EBX
+                 , [old_ebx] "=m" (old_ebx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "esi", "edi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_EBX
+                 , "ebx"
+#endif
        );
 }
+
+#ifdef BOUNDED_EBX
+#  undef BOUNDED_EBX
+#endif
index 803d3b2409f6108620283cc232e2419369533729..fff07529e0042b58c0e726c8e9ca1acaca61a462 100644 (file)
  *
  */
 
+#if defined(__GNUC__) && __GNUC__ < 5 && defined(__PIC__)
+#  define BOUNDED_RBX
+#endif
+
 /*
  *  MMX optimized
  */
@@ -35,8 +39,9 @@ static void MIX_AREAS_16(unsigned int size,
                         volatile signed int *sum, size_t dst_step,
                         size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_RBX
        unsigned long long old_rbx;
-
+#endif
        /*
         *  RSI - src
         *  RDI - dst
@@ -47,8 +52,9 @@ static void MIX_AREAS_16(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_RBX
                "\tmovq %%rbx, %[old_rbx]\n"
+#endif
                /*
                 *  initialization, load RSI, RDI, RBX registers
                 */
@@ -112,13 +118,20 @@ static void MIX_AREAS_16(unsigned int size,
                "6:"
 
                "\temms\n"
+#ifdef BOUNDED_RBX
                "\tmovq %[old_rbx], %%rbx\n"
-
-               : [size] "+m" (size), [old_rbx] "=m" (old_rbx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_RBX
+                 , [old_rbx] "=m" (old_rbx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "rsi", "rdi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_RBX
+                 , "rbx"
+#endif
 #ifdef HAVE_MMX
                  , "mm0"
 #else
@@ -136,8 +149,9 @@ static void MIX_AREAS_32(unsigned int size,
                         volatile signed int *sum, size_t dst_step,
                         size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_RBX
        unsigned long long old_rbx;
-
+#endif
        /*
         *  RSI - src
         *  RDI - dst
@@ -148,8 +162,9 @@ static void MIX_AREAS_32(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_RBX
                "\tmovq %%rbx, %[old_rbx]\n"
+#endif
                /*
                 *  initialization, load RSI, RDI, RBX registers
                 */
@@ -233,13 +248,20 @@ static void MIX_AREAS_32(unsigned int size,
                "\tjnz 1b\n"
 
                "6:"
+#ifdef BOUNDED_RBX
                "\tmovq %[old_rbx], %%rbx\n"
-
-               : [size] "+m" (size), [old_rbx] "=m" (old_rbx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_RBX
+                 , [old_rbx] "=m" (old_rbx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "rsi", "rdi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_RBX
+                 , "rbx"
+#endif
        );
 }
 
@@ -251,8 +273,9 @@ static void MIX_AREAS_24(unsigned int size,
                         volatile signed int *sum, size_t dst_step,
                         size_t src_step, size_t sum_step)
 {
+#ifdef BOUNDED_RBX
        unsigned long long old_rbx;
-
+#endif
        /*
         *  RSI - src
         *  RDI - dst
@@ -263,8 +286,9 @@ static void MIX_AREAS_24(unsigned int size,
         */
        __asm__ __volatile__ (
                "\n"
-
+#ifdef BOUNDED_RBX
                "\tmovq %%rbx, %[old_rbx]\n"
+#endif
                /*
                 *  initialization, load RSI, RDI, RBX registers
                 */
@@ -336,12 +360,23 @@ static void MIX_AREAS_24(unsigned int size,
                "\tjnz 1b\n"
 
                "6:"
+#ifdef BOUNDED_RBX
                "\tmovq %[old_rbx], %%rbx\n"
-
-               : [size] "+m" (size), [old_rbx] "=m" (old_rbx)
+#endif
+               : [size] "+m" (size)
+#ifdef BOUNDED_RBX
+                 , [old_rbx] "=m" (old_rbx)
+#endif
                : [dst] "m" (dst), [src] "m" (src), [sum] "m" (sum),
                  [dst_step] "m" (dst_step),  [src_step] "m" (src_step),
                  [sum_step] "m" (sum_step)
                : "rsi", "rdi", "edx", "ecx", "eax", "memory", "cc"
+#ifndef BOUNDED_RBX
+                 , "rbx"
+#endif
        );
 }
+
+#ifdef BOUNDED_RBX
+#  undef BOUNDED_RBX
+#endif