[prev in list] [next in list] [prev in thread] [next in thread] 

List:       gcc-bugs
Subject:    [Bug c/97651] New: abs((int)fabs(0.0/0.0)) results negative
From:       olha5b at gmx dot net via Gcc-bugs <gcc-bugs () gcc ! gnu ! org>
Date:       2020-10-31 7:34:02
Message-ID: bug-97651-4 () http ! gcc ! gnu ! org/bugzilla/
[Download RAW message or body]

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

            Bug ID: 97651
           Summary: abs((int)fabs(0.0/0.0)) results negative
           Product: gcc
           Version: 10.2.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c
          Assignee: unassigned at gcc dot gnu.org
          Reporter: olha5b at gmx dot net
  Target Milestone: ---

Created attachment 49477
  --> https://gcc.gnu.org/bugzilla/attachment.cgi?id=49477&action=edit
Preprocessing of first sample program

First sample program: i negative after "if (i<0) i=0;" with -O1
===============================================================

In my software I have a combination of fabs, integer conversion, and an
additional check to avoid negative results. But it fails on nans. Here comes a
simplified example program:

  #include <math.h>
  #include <stdio.h>

  int main(int argc __attribute__((unused)), char * argv[]
__attribute__((unused)))
  {
    int i=(int)fabs(0.0/0.0);
    if (i<0) i=0;
    printf("RESULT: i=%d\n",i);
    return 0;
  }

When compiling with -O0 the program prints:

  RESULT: i=0

But when compiling with -O1 or higher it prints:

  RESULT: i=-2147483648

I don't know, either (int)fabs(0.0/0.0) should not be negative or the compiler
should not optimize out the "if (i<0) i=0;".

I saw the behavior with gcc (Debian 6.3.0-18+deb9u1) 6.3.0 20170516, and I
could reproduce it with gcc 10.2.0,


Second sample program: abs(...) results negative even with -O0
==============================================================

Another example with using abs(..) instead of if (..):

  #include <math.h>
  #include <stdio.h>
  #include <stdlib.h>

  int main(int argc __attribute__((unused)), char * argv[]
__attribute__((unused)))
  {
    int i=abs((int)fabs(0.0/0.0));
    printf("RESULT: i=%d\n",i);
    return 0;
  }

When compiling with -O0 or higher the program prints:

  RESULT: i=-2147483648

I think abs(..) should never result negative.


Commands + output
=================

+ gcc -v -save-temps -O1 -Wall -Wextra -fno-strict-aliasing -fwrapv
-fno-aggressive-loop-optimizations -fsanitize=undefined -lm test1.c -o test1
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/lto-wrapper
                
Target: x86_64-pc-linux-gnu
Configured with: ./configure --prefix=/extra/gcc-10.2.0 --disable-multilib
Thread model: posix
Supported LTO compression algorithms: zlib
gcc version 10.2.0 (GCC) 
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O1' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test1' '-mtune=generic' '-march=x86-64'
 /extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/cc1 -E -quiet -v
-imultiarch x86_64-linux-gnu test1.c -mtune=generic -march=x86-64 -Wall -Wextra
-fno-strict-aliasing -fwrapv -fno-aggressive-loop-optimizations
-fsanitize=undefined -O1 -fpch-preprocess -o test1.i
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
ignoring nonexistent directory
"/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../../x86_64-pc-linux-gnu/include"
 #include "..." search starts here:
#include <...> search starts here:
 /extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/include
 /usr/local/include
 /extra/gcc-10.2.0/include
 /extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/include-fixed
 /usr/include/x86_64-linux-gnu
 /usr/include
End of search list.
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O1' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test1' '-mtune=generic' '-march=x86-64'
 /extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/cc1 -fpreprocessed
test1.i -quiet -dumpbase test1.c -mtune=generic -march=x86-64 -auxbase test1
-O1 -Wall -Wextra -version -fno-strict-aliasing -fwrapv
-fno-aggressive-loop-optimizations -fsanitize=undefined -o test1.s
GNU C17 (GCC) version 10.2.0 (x86_64-pc-linux-gnu)
        compiled by GNU C version 10.2.0, GMP version 6.1.2, MPFR version
3.1.5, MPC version 1.0.3, isl version none
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
GNU C17 (GCC) version 10.2.0 (x86_64-pc-linux-gnu)
        compiled by GNU C version 10.2.0, GMP version 6.1.2, MPFR version
3.1.5, MPC version 1.0.3, isl version none
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 44d7e89f433c19bc66ff65a4297e4c94
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O1' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test1' '-mtune=generic' '-march=x86-64'
 as -v --64 -o test1.o test1.s
GNU assembler version 2.28 (x86_64-linux-gnu) using BFD version (GNU Binutils
for Debian) 2.28
COMPILER_PATH=/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10. \
2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-li \
nux-gnu/:/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/
 LIBRARY_PATH=/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10.2.0/ \
lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../../lib64/:/lib/x86_64-linux-gnu/:/lib/../l \
ib64/:/usr/lib/x86_64-linux-gnu/:/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../:/lib/:/usr/lib/
 COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O1' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test1' '-mtune=generic' '-march=x86-64'
 /extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/collect2 -plugin
/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/liblto_plugin.so
-plugin-opt=/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/lto-wrapper
-plugin-opt=-fresolution=test1.res -plugin-opt=-pass-through=-lgcc
-plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lc
-plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s
--eh-frame-hdr -m elf_x86_64 -dynamic-linker /lib64/ld-linux-x86-64.so.2 -o
test1 /usr/lib/x86_64-linux-gnu/crt1.o /usr/lib/x86_64-linux-gnu/crti.o
/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/crtbegin.o
-L/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0
-L/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../../lib64
-L/lib/x86_64-linux-gnu -L/lib/../lib64 -L/usr/lib/x86_64-linux-gnu
-L/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../.. -lm test1.o
-lubsan -lgcc --push-state --as-needed -lgcc_s --pop-state -lc -lgcc
--push-state --as-needed -lgcc_s --pop-state
/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/crtend.o
/usr/lib/x86_64-linux-gnu/crtn.o
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O1' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test1' '-mtune=generic' '-march=x86-64'
+ ./test1
RESULT: i=-2147483648


+ gcc -v -save-temps -O0 -Wall -Wextra -fno-strict-aliasing -fwrapv
-fno-aggressive-loop-optimizations -fsanitize=undefined -lm test2.c -o test2
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/lto-wrapper
                
Target: x86_64-pc-linux-gnu
Configured with: ./configure --prefix=/extra/gcc-10.2.0 --disable-multilib
Thread model: posix
Supported LTO compression algorithms: zlib
gcc version 10.2.0 (GCC) 
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O0' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test2' '-mtune=generic' '-march=x86-64'
 /extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/cc1 -E -quiet -v
-imultiarch x86_64-linux-gnu test2.c -mtune=generic -march=x86-64 -Wall -Wextra
-fno-strict-aliasing -fwrapv -fno-aggressive-loop-optimizations
-fsanitize=undefined -O0 -fpch-preprocess -o test2.i
ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu"
ignoring nonexistent directory
"/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../../x86_64-pc-linux-gnu/include"
 #include "..." search starts here:
#include <...> search starts here:
 /extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/include
 /usr/local/include
 /extra/gcc-10.2.0/include
 /extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/include-fixed
 /usr/include/x86_64-linux-gnu
 /usr/include
End of search list.
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O0' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test2' '-mtune=generic' '-march=x86-64'
 /extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/cc1 -fpreprocessed
test2.i -quiet -dumpbase test2.c -mtune=generic -march=x86-64 -auxbase test2
-O0 -Wall -Wextra -version -fno-strict-aliasing -fwrapv
-fno-aggressive-loop-optimizations -fsanitize=undefined -o test2.s
GNU C17 (GCC) version 10.2.0 (x86_64-pc-linux-gnu)
        compiled by GNU C version 10.2.0, GMP version 6.1.2, MPFR version
3.1.5, MPC version 1.0.3, isl version none
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
GNU C17 (GCC) version 10.2.0 (x86_64-pc-linux-gnu)
        compiled by GNU C version 10.2.0, GMP version 6.1.2, MPFR version
3.1.5, MPC version 1.0.3, isl version none
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 44d7e89f433c19bc66ff65a4297e4c94
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O0' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test2' '-mtune=generic' '-march=x86-64'
 as -v --64 -o test2.o test2.s
GNU assembler version 2.28 (x86_64-linux-gnu) using BFD version (GNU Binutils
for Debian) 2.28
COMPILER_PATH=/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10. \
2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-li \
nux-gnu/:/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/
 LIBRARY_PATH=/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/:/extra/gcc-10.2.0/ \
lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../../lib64/:/lib/x86_64-linux-gnu/:/lib/../l \
ib64/:/usr/lib/x86_64-linux-gnu/:/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../:/lib/:/usr/lib/
 COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O0' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test2' '-mtune=generic' '-march=x86-64'
 /extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/collect2 -plugin
/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/liblto_plugin.so
-plugin-opt=/extra/gcc-10.2.0/libexec/gcc/x86_64-pc-linux-gnu/10.2.0/lto-wrapper
-plugin-opt=-fresolution=test2.res -plugin-opt=-pass-through=-lgcc
-plugin-opt=-pass-through=-lgcc_s -plugin-opt=-pass-through=-lc
-plugin-opt=-pass-through=-lgcc -plugin-opt=-pass-through=-lgcc_s
--eh-frame-hdr -m elf_x86_64 -dynamic-linker /lib64/ld-linux-x86-64.so.2 -o
test2 /usr/lib/x86_64-linux-gnu/crt1.o /usr/lib/x86_64-linux-gnu/crti.o
/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/crtbegin.o
-L/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0
-L/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../../../lib64
-L/lib/x86_64-linux-gnu -L/lib/../lib64 -L/usr/lib/x86_64-linux-gnu
-L/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/../../.. -lm test2.o
-lubsan -lgcc --push-state --as-needed -lgcc_s --pop-state -lc -lgcc
--push-state --as-needed -lgcc_s --pop-state
/extra/gcc-10.2.0/lib/gcc/x86_64-pc-linux-gnu/10.2.0/crtend.o
/usr/lib/x86_64-linux-gnu/crtn.o
COLLECT_GCC_OPTIONS='-v' '-save-temps' '-O0' '-Wall' '-Wextra'
'-fno-strict-aliasing' '-fwrapv' '-fno-aggressive-loop-optimizations'
'-fsanitize=undefined' '-o' 'test2' '-mtune=generic' '-march=x86-64'
+ ./test2
RESULT: i=-2147483648=


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic