-
Notifications
You must be signed in to change notification settings - Fork 15.5k
Open
Labels
bugzillaIssues migrated from bugzillaIssues migrated from bugzillaclang:codegenIR generation bugs: mangling, exceptions, etc.IR generation bugs: mangling, exceptions, etc.
Description
| Bugzilla Link | 41029 |
| Version | trunk |
| OS | Linux |
| Depends On | #41664 |
| Reporter | LLVM Bugzilla Contributor |
| CC | @topperc,@hjl-tools,@jyknight,@RKSimon,@zygoloid |
Extended Description
$ cat m64.c
#include <immintrin.h>
void callee(__m64 __m1, __m64 __m2);
__m64 caller(__m64 __m1, __m64 __m2)
{
__m64 a = _mm_set_pi16(1, 2, 3, 4);
callee(__m2, __m1);
return a;
}
$ gcc -m32 -O2 -S -o - m64.c
.file "m64.c"
.text
.p2align 4
.globl caller
.type caller, @function
caller:
.LFB5121:
.cfi_startproc
subl $12, %esp
.cfi_def_cfa_offset 16
movq %mm0, %mm2
movq %mm1, %mm0
movq %mm2, %mm1
call callee
movq .LC0, %mm0
addl $12, %esp
.cfi_def_cfa_offset 4
ret
.cfi_endproc
.LFE5121:
.size caller, .-caller
.section .rodata.cst8,"aM",@progbits,8
.align 8
.LC0:
.value 4
.value 3
.value 2
.value 1
.ident "GCC: (GNU) 9.0.1 20190131 (experimental)"
.section .note.GNU-stack,"",@progbits
$ clang -m32 -O2 -S -o - m64.c
.text
.file "m64.c"
.globl caller # -- Begin function caller
.p2align 4, 0x90
.type caller,@function
caller: # @caller
# %bb.0: # %entry
subl $12, %esp
pushl 20(%esp)
pushl 20(%esp)
pushl 36(%esp)
pushl 36(%esp)
calll callee
addl $16, %esp
movl $196612, %eax # imm = 0x30004
movl $65538, %edx # imm = 0x10002
addl $12, %esp
retl
.Lfunc_end0:
.size caller, .Lfunc_end0-caller
# -- End function
.ident "clang version 9.0.0 (http://llvm.org/git/clang.git 59f2009cd157fc96a0d558125405b98586cd83d2) (http://llvm.org/git/llvm.git 6a7719c7965af52f904e16588c1754f65bcb8ff0)"
.section ".note.GNU-stack","",@progbits
.addrsig
According to i386 ABI, __m64 values should be passed by mmx registers.
Metadata
Metadata
Assignees
Labels
bugzillaIssues migrated from bugzillaIssues migrated from bugzillaclang:codegenIR generation bugs: mangling, exceptions, etc.IR generation bugs: mangling, exceptions, etc.