majiang31312 added a comment.

Thanks for the information. 
Well, the key problem is x64 abi. But we can do better here for sure. 
First of all, we can fallback to use fpu instructions. I can get the following 
binary which should work correctly(after this fix, of course)

  0000000000000000 <test>:
     0:   55                      push   %rbp
     1:   48 89 e5                mov    %rsp,%rbp
     4:   d9 ee                   fldz
     6:   5d                      pop    %rbp
     7:   c3                      retq
     8:   0f 1f 84 00 00 00 00    nopl   0x0(%rax,%rax,1)
     f:   00
  
  0000000000000010 <main>:
    10:   55                      push   %rbp
    11:   48 89 e5                mov    %rsp,%rbp
    14:   48 83 ec 20             sub    $0x20,%rsp
    18:   31 c0                   xor    %eax,%eax
    1a:   c7 45 fc 00 00 00 00    movl   $0x0,-0x4(%rbp)
    21:   89 45 ec                mov    %eax,-0x14(%rbp)
    24:   e8 00 00 00 00          callq  29 <main+0x19>
                          25: R_X86_64_PLT32      test-0x4
    29:   dd 5d f0                fstpl  -0x10(%rbp)

Although it might be incompatible with other libraries because of ABI problems, 
it is the responsibility of the linker to prevent possible errors. The compiler 
should just produce the binary as requested.  
There have been similar situations in https://reviews.llvm.org/D70465.

Second,  even if we decided not to support the fallback feature for the moment, 
we certainly could give a more clear message (maybe  something like 
"float/double arguments under -mno-sse are not supported yet").
In all, using float/double is not a error in code(even with -mno-sse) in my 
opinion.

However, to make -mno-sse(with float/double) working gracefully need quite a 
work, so I agree it's reasonable to keep current state as there are no serious 
users yet. Thanks again for the clarification!


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D102995/new/

https://reviews.llvm.org/D102995

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to