https://gcc.gnu.org/bugzilla/show_bug.cgi?id=91547
            Bug ID: 91547
           Summary: std::string_view find_last_not_of can trigger unsigned
                    integer overflow
           Product: gcc
           Version: 9.1.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: libstdc++
          Assignee: unassigned at gcc dot gnu.org
          Reporter: mateusz.szychowski at blackstarsoftware dot com
  Target Milestone: ---

Created attachment 46752
  --> https://gcc.gnu.org/bugzilla/attachment.cgi?id=46752&action=edit
Preprocessed source

Problem, it's easier to explain with a code snippet (I attached .ii file)
explanation:
std::string_view text = "aaaa";
size_t const pos = text.find_last_not_of("a");

Using Undefined Behavior Sanitizer makes second line print a warning about
unsigned integer overflow. This happens only if std::string_view::npos is
returned.

I'm building with clang++ (I don't think that GCC has
'-fsanitizer=unsigned-integer-overflow' option) and using libstdc++.
This error doesn't print with libc++, so I've assumed it's related to
libstdc++.

OS: Manjaro Linux (reproduced on Ubuntu 18.04 too, with GCC 8.3.0 and Clang
7.0.0)
Compilers: GCC 9.1.0, Clang 8.0.1

$ gcc -v
Using built-in specs.
COLLECT_GCC=/usr/bin/gcc
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-pc-linux-gnu/9.1.0/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: /build/gcc/src/gcc/configure --prefix=/usr --libdir=/usr/lib
--libexecdir=/usr/lib --mandir=/usr/share/man --infodir=/usr/share/info
--with-bugurl=https://bugs.archlinux.org/
--enable-languages=c,c++,ada,fortran,go,lto,objc,obj-c++ --enable-shared
--enable-threads=posix --with-system-zlib --with-isl --enable-__cxa_atexit
--disable-libunwind-exceptions --enable-clocale=gnu --disable-libstdcxx-pch
--disable-libssp --enable-gnu-unique-object --enable-linker-build-id
--enable-lto --enable-plugin --enable-install-libiberty
--with-linker-hash-style=gnu --enable-gnu-indirect-function --enable-multilib
--disable-werror --enable-checking=release --enable-default-pie
--enable-default-ssp --enable-cet=auto
Thread model: posix
gcc version 9.1.0 (GCC)

$ clang++ -v
clang version 8.0.1 (tags/RELEASE_801/final)
Target: x86_64-pc-linux-gnu
Thread model: posix
InstalledDir: /usr/bin
Found candidate GCC installation: /usr/bin/../lib/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation: /usr/bin/../lib/gcc/x86_64-pc-linux-gnu/9.1.0
Found candidate GCC installation:
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation:
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0
Found candidate GCC installation: /usr/lib/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation: /usr/lib/gcc/x86_64-pc-linux-gnu/9.1.0
Found candidate GCC installation: /usr/lib64/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation: /usr/lib64/gcc/x86_64-pc-linux-gnu/9.1.0
Selected GCC installation: /usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0
Candidate multilib: .;@m64
Candidate multilib: 32;@m32
Selected multilib: .;@m64

Build command and output:
$ clang++ -v -save-temps -fsanitize=unsigned-integer-overflow -std=c++17
ubsan-string-view.cpp
clang version 8.0.1 (tags/RELEASE_801/final)
Target: x86_64-pc-linux-gnu
Thread model: posix
InstalledDir: /usr/bin
Found candidate GCC installation: /usr/bin/../lib/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation: /usr/bin/../lib/gcc/x86_64-pc-linux-gnu/9.1.0
Found candidate GCC installation:
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation:
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0
Found candidate GCC installation: /usr/lib/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation: /usr/lib/gcc/x86_64-pc-linux-gnu/9.1.0
Found candidate GCC installation: /usr/lib64/gcc/x86_64-pc-linux-gnu/8.3.0
Found candidate GCC installation: /usr/lib64/gcc/x86_64-pc-linux-gnu/9.1.0
Selected GCC installation: /usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0
Candidate multilib: .;@m64
Candidate multilib: 32;@m32
Selected multilib: .;@m64
 "/usr/bin/clang-8" -cc1 -triple x86_64-pc-linux-gnu -E -save-temps=cwd
-disable-free -disable-llvm-verifier -discard-value-names -main-file-name
ubsan-string-view.cpp -mrelocation-model pic -pic-level 2 -pic-is-pie
-mthread-model posix -mdisable-fp-elim -fmath-errno -masm-verbose
-mconstructor-aliases -munwind-tables -fuse-init-array -target-cpu x86-64
-dwarf-column-info -debugger-tuning=gdb -v -resource-dir /usr/lib/clang/8.0.1
-internal-isystem
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../include/c++/9.1.0
-internal-isystem
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../include/c++/9.1.0/x86_64-pc-linux-gnu
-internal-isystem
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../include/c++/9.1.0/backward
-internal-isystem /usr/local/include -internal-isystem
/usr/lib/clang/8.0.1/include -internal-externc-isystem /include
-internal-externc-isystem /usr/include -std=c++17 -fdeprecated-macro
-fdebug-compilation-dir /home/muttley/git/test/ubsan-string-view -ferror-limit
19 -fmessage-length 172 -fsanitize=unsigned-integer-overflow
-fsanitize-recover=unsigned-integer-overflow -stack-protector 2
-fobjc-runtime=gcc -fcxx-exceptions -fexceptions -fdiagnostics-show-option
-fcolor-diagnostics -o ubsan-string-view.ii -x c++ ubsan-string-view.cpp
-faddrsig
clang -cc1 version 8.0.1 based upon LLVM 8.0.1 default target
x86_64-pc-linux-gnu
ignoring nonexistent directory "/include"
#include "..." search starts here:
#include <...> search starts here:
 /usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../include/c++/9.1.0

/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../include/c++/9.1.0/x86_64-pc-linux-gnu

/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../include/c++/9.1.0/backward
 /usr/local/include
 /usr/lib/clang/8.0.1/include
 /usr/include
End of search list.
 "/usr/bin/clang-8" -cc1 -triple x86_64-pc-linux-gnu -emit-llvm-bc
-emit-llvm-uselists -save-temps=cwd -disable-free -disable-llvm-verifier
-discard-value-names -main-file-name ubsan-string-view.cpp -mrelocation-model
pic -pic-level 2 -pic-is-pie -mthread-model posix -mdisable-fp-elim
-fmath-errno -masm-verbose -mconstructor-aliases -munwind-tables
-fuse-init-array -target-cpu x86-64 -dwarf-column-info -debugger-tuning=gdb -v
-resource-dir /usr/lib/clang/8.0.1 -std=c++17 -fdeprecated-macro
-fdebug-compilation-dir /home/muttley/git/test/ubsan-string-view -ferror-limit
19 -fmessage-length 172 -fsanitize=unsigned-integer-overflow
-fsanitize-recover=unsigned-integer-overflow -stack-protector 2
-fobjc-runtime=gcc -fcxx-exceptions -fexceptions -fdiagnostics-show-option
-fcolor-diagnostics -disable-llvm-passes -o ubsan-string-view.bc -x
c++-cpp-output ubsan-string-view.ii -faddrsig
clang -cc1 version 8.0.1 based upon LLVM 8.0.1 default target
x86_64-pc-linux-gnu
#include "..." search starts here:
End of search list.
 "/usr/bin/clang-8" -cc1 -triple x86_64-pc-linux-gnu -S -save-temps=cwd
-disable-free -disable-llvm-verifier -discard-value-names -main-file-name
ubsan-string-view.cpp -mrelocation-model pic -pic-level 2 -pic-is-pie
-mthread-model posix -mdisable-fp-elim -fmath-errno -masm-verbose
-mconstructor-aliases -munwind-tables -fuse-init-array -target-cpu x86-64
-dwarf-column-info -debugger-tuning=gdb -v -resource-dir /usr/lib/clang/8.0.1
-std=c++17 -fdebug-compilation-dir /home/muttley/git/test/ubsan-string-view
-ferror-limit 19 -fmessage-length 172 -fsanitize=unsigned-integer-overflow
-fsanitize-recover=unsigned-integer-overflow -stack-protector 2
-fobjc-runtime=gcc -fdiagnostics-show-option -fcolor-diagnostics -o
ubsan-string-view.s -x ir ubsan-string-view.bc -faddrsig
clang -cc1 version 8.0.1 based upon LLVM 8.0.1 default target
x86_64-pc-linux-gnu
 "/usr/bin/clang-8" -cc1as -triple x86_64-pc-linux-gnu -filetype obj
-main-file-name ubsan-string-view.cpp -target-cpu x86-64 -dwarf-version=4
-mrelocation-model pic -mrelax-all -o ubsan-string-view.o ubsan-string-view.s
 "/usr/bin/ld" -pie --eh-frame-hdr -m elf_x86_64 -dynamic-linker
/lib64/ld-linux-x86-64.so.2 -o a.out
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../lib64/Scrt1.o
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../lib64/crti.o
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/crtbeginS.o
-L/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0
-L/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../lib64
-L/usr/bin/../lib64 -L/lib/../lib64 -L/usr/lib/../lib64
-L/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../.. -L/usr/bin/../lib
-L/lib -L/usr/lib --whole-archive
/usr/lib/clang/8.0.1/lib/linux/libclang_rt.ubsan_standalone-x86_64.a
--no-whole-archive
--dynamic-list=/usr/lib/clang/8.0.1/lib/linux/libclang_rt.ubsan_standalone-x86_64.a.syms
--whole-archive
/usr/lib/clang/8.0.1/lib/linux/libclang_rt.ubsan_standalone_cxx-x86_64.a
--no-whole-archive
--dynamic-list=/usr/lib/clang/8.0.1/lib/linux/libclang_rt.ubsan_standalone_cxx-x86_64.a.syms
ubsan-string-view.o -lstdc++ -lm --no-as-needed -lpthread -lrt -lm -ldl -lgcc_s
-lgcc -lc -lgcc_s -lgcc
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/crtendS.o
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../lib64/crtn.o

Runtime output:
$ ./a.out
/usr/bin/../lib64/gcc/x86_64-pc-linux-gnu/9.1.0/../../../../include/c++/9.1.0/bits/string_view.tcc:199:17:
runtime error: unsigned integer overflow: 0 - 1 cannot be represented in type
'std::basic_string_view::size_type' (aka 'unsigned long')

Reply via email to