|
|
  |
GCC 5 оптимизация, полная багов |
|
|
|
Oct 19 2016, 08:46
|

Местный
  
Группа: Участник
Сообщений: 319
Регистрация: 31-01-12
Пользователь №: 69 978

|
Цитата(scifi @ Oct 19 2016, 11:31)  При выходе за границу массива компилятор генерирует код, который не то, чтобы просто за границу массива выходит, а лезет в совершенно левые адреса. Вот как раз что то подобное в паре проектов у себя наблюдаю... только вот выходы за границу массивов не наблюдаю...
|
|
|
|
|
Oct 19 2016, 09:12
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
QUOTE (Kabdim @ Oct 19 2016, 10:40)  Прочитал. Долго втыкал в код CODE int main() { P = (float*)&P; // cast causes TBAA violation in zero_array. zero_array(); } Так и не понял, где тут ошибка. QUOTE This behavior enables an analysis known as "Type-Based Alias Analysis" (TBAA) which is used by a broad range of memory access optimizations in the compiler, and can significantly improve performance of the generated code. For example, this rule allows clang to optimize this function: CODE float *P; void zero_array() { int i; for (i = 0; i < 10000; ++i) P[i] = 0.0f; } into "memset(P, 0, 40000)". This optimization also allows many loads to be hoisted out of loops, common subexpressions to be eliminated, etc. This class of undefined behavior can be disabled by passing the -fno-strict-aliasing flag, which disallows this analysis. When this flag is passed, Clang is required to compile this loop into 10000 4-byte stores (which is several times slower), because it has to assume that it is possible for any of the stores to change the value of P, as in something like this: CODE int main() { P = (float*)&P; // cast causes TBAA violation in zero_array. zero_array(); } Кто-то может объяснить? Про переполнение знаковых целых как аргументов для функций выделения памяти - сами себе злобные Буратины: нафига размер передавать знаковой переменной? К тому же есть беззнаковый тип size_t. Но в целом да, раскрыты некоторые неочевидные вещи.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|