Clang++ UBSAN сообщает о недопустимом значении типа 'std::_Ios_Fmtflags'

Следующие коды будут аварийно завершаться при компиляции clang UBSAN

#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <sstream>

template<class T>
inline std::string floatToString(T i){
    printf("in floatToString\n");
    std::stringstream ss;
    ss.precision(6);
    ss << std::noshowpoint << i;
    printf("exit floatToString\n");
    return ss.str();
}

int main() {
 std::cout << floatToString(1.0) << "\n";
 return 0;
}

Компилировать с Clang 3.6:

$> clang ++ - 3.6 -fsanitize = undefined -fno-sanitize = float-делить на ноль,vptr, функция -fno-sanitize-recovery -o test test.cpp

Затем программа потерпела крах:

$>./test in floatToString /usr/bin/../lib/gcc/x86_64-linux-gnu/4.8/../../../../include/c++/4.8/bits/ios_base.h: 96: 24: ошибка времени выполнения: загрузка значения 4294966271, которое не является допустимым значением для типа 'std::_Ios_Fmtflags'

Может кто-нибудь помочь, почему эта проблема происходит, когда я включаю лязг UBSAN?

1 ответ

Решение

Это ошибка в libstdC++ в соответствии с http://lists.cs.uiuc.edu/pipermail/cfe-dev/2013-January/027401.html.

Все еще присутствует в libstdC++ 5.1.

libC++ работает как положено:

$ clang++ -stdlib=libc++ -fsanitize=undefined -fno-sanitize=float-divide-by-zero,vptr,function -fno-sanitize-recover -o test test.cpp -lc++abi

$ ./test
in floatToString
exit floatToString
1
Другие вопросы по тегам