https://gcc.gnu.org/bugzilla/show_bug.cgi?id=66824
Bug ID: 66824 Summary: -miamcu doesn't load FP constant into register directly Product: gcc Version: 6.0 Status: UNCONFIRMED Severity: normal Priority: P3 Component: target Assignee: unassigned at gcc dot gnu.org Reporter: hjl.tools at gmail dot com CC: izamyatin at gmail dot com, julia.koval at intel dot com, zinovy.nis at gmail dot com Target Milestone: --- [hjl@gnu-6 gcc]$ cat x.i void bar (float); void foo (void) { bar (3.0); } [hjl@gnu-6 gcc]$ ./xgcc -B./ -S -m32 -miamcu -O2 x.i [hjl@gnu-6 gcc]$ cat x.s .file "x.i" .section .text.unlikely,"ax",@progbits .LCOLDB1: .text .LHOTB1: .p2align 4,,15 .globl foo .type foo, @function foo: .LFB0: .cfi_startproc movl .LC0, %eax jmp bar .cfi_endproc .LFE0: .size foo, .-foo .section .text.unlikely .LCOLDE1: .text .LHOTE1: .section .rodata.cst4,"aM",@progbits,4 .align 4 .LC0: .long 1077936128 .ident "GCC: (GNU) 6.0.0 20150709 (experimental)" .section .note.GNU-stack,"",@progbits [hjl@gnu-6 gcc]$ We should generate "mov $1077936128 %eax".