📄 pr22026.c
字号:
/* PR tree-optimization/22026 VRP used think that ~[0,0] + ~[0,0] = ~[0,0], which is wrong. The same applies to subtraction and unsigned multiplication. *//* { dg-do compile } *//* { dg-options "-O2 -fdump-tree-vrp" } */intplus (int x, int y){ if (x != 0) if (y != 0) { int z = x + y; if (z != 0) return 1; } return 0;}intminus (int x, int y){ if (x != 0) if (y != 0) { int z = x - y; if (z != 0) return 1; } return 0;}intmult (unsigned x, unsigned y){ if (x != 0) if (y != 0) { unsigned z = x * y; if (z != 0) return 1; } return 0;}/* None of the predicates can be folded in these functions. *//* { dg-final { scan-tree-dump-times "Folding predicate" 0 "vrp" } } *//* { dg-final { cleanup-tree-dump "vrp" } } */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -