https://gcc.gnu.org/bugzilla/show_bug.cgi?id=87678

            Bug ID: 87678
           Summary: Redundant vmovss with -fPIC
           Product: gcc
           Version: 9.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: target
          Assignee: unassigned at gcc dot gnu.org
          Reporter: hjl.tools at gmail dot com
                CC: ubizjak at gmail dot com
  Target Milestone: ---
            Target: i386

[hjl@gnu-efi-2 broadcast-1]$ cat y.c
#include <immintrin.h>

float
foo (__m128 x)
{
  return ((__v4sf) x)[0] * 2.387f;
}
[hjl@gnu-efi-2 broadcast-1]$ gcc -O2 y.c -mfpmath=sse -fpic -m32 -S -mavx
c[hjl@gnu-efi-2 broadcast-1]$ cat y.s
        .file   "y.c"
        .text
        .p2align 4,,15
        .globl  foo
        .type   foo, @function
foo:
.LFB5086:
        .cfi_startproc
        call    __x86.get_pc_thunk.ax
        addl    $_GLOBAL_OFFSET_TABLE_, %eax
        subl    $28, %esp
        .cfi_def_cfa_offset 32
        vmovss  .LC0@GOTOFF(%eax), %xmm1
        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  This isn't needed.

        vmulss  %xmm1, %xmm0, %xmm0
        vmovss  %xmm0, 12(%esp)
        flds    12(%esp)
        addl    $28, %esp
        .cfi_def_cfa_offset 4
        ret
        .cfi_endproc
.LFE5086:
        .size   foo, .-foo

We should replace

        vmovss  .LC0@GOTOFF(%eax), %xmm1
        vmulss  %xmm1, %xmm0, %xmm0

with

        vmulss  .LC0@GOTOFF(%eax), %xmm0, %xmm0

Reply via email to