From: Jonathan Wakely Date: Tue, 16 Jun 2020 22:14:23 +0000 (+0100) Subject: middle-end: Add another testcase for PR 95493 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d4b0f996fc497fba8724960107c3b52d3011c117;p=gcc.git middle-end: Add another testcase for PR 95493 This was reported on the gcc-help mailing list. The regression started with r10-589 and was fixed by r11-963. gcc/testsuite/ChangeLog: * g++.dg/torture/pr95493-1.C: New test. --- diff --git a/gcc/testsuite/g++.dg/torture/pr95493-1.C b/gcc/testsuite/g++.dg/torture/pr95493-1.C new file mode 100644 index 00000000000..907d191ebfe --- /dev/null +++ b/gcc/testsuite/g++.dg/torture/pr95493-1.C @@ -0,0 +1,95 @@ +// { dg-do run { target c++11 } } +// PR rtl-optimization/95493 comment 8 + +#include +#include + +struct Point +{ + std::array array; + + Point(int x, int y, int z) : array{x, y, z} {} + + Point(const Point & other) : array{other.array} {} // OK if commented + //Point(const Point &) = default; // OK + + //Point(Point && other) = default; // OK + + int operator[] (std::size_t i) const { return array[i]; } + int& operator[] (std::size_t i) { return array[i]; } +}; + +//using Point = std::array; // OK + +struct Cell +{ + Point point; + Cell(Point const& pt) : point(pt) {} + int operator[] (std::size_t i) const { return point[i]; } + int& operator[] (std::size_t i) { return point[i]; } +}; + +//using Cell = Point; // OK + +std::ostream & operator<< (std::ostream & out, Cell const& object) +//std::ostream & operator<< (std::ostream & out, Cell object) // Fails with f2 too +{ + for ( std::size_t i = 0; i < 3; ++i ) + out << object[ i ] << " "; + return out; +} + + +struct DirIterator +{ + std::size_t dir; + Cell cell; + + DirIterator(Cell c) + : dir(0), cell(c) + { + find(); // OK if commented + } + + void find() + { + //while (dir < 3) // Fails with f2 too + while (dir < 3 && (cell[dir] % 2) == 0) + ++dir; + } +}; + +Cell uIncident(Cell c, std::size_t k) +//Cell uIncident(Cell& c, std::size_t k) // OK +{ + --c[k]; + return c; +} + +Cell uSpel(Point p) +{ + for (std::size_t i = 0; i < 3; ++i) + p[i] += p[i] + 1; + return Cell(p); +} + + +int main () +{ + Cell c = uSpel(Point{0, 0, 0}); // Fails + //Cell c( Point(1, 1, 1) ); // OK + + auto q = DirIterator( c ); + + Cell f1 = uIncident( c, q.dir ); // Fails + //Cell f1 = uIncident( c, 0 ); // OK + + Cell f2 = f1; // f2 is the right cell that f1 should be + + std::cout << "q.dir = " << q.dir << " ; f1 = " << f1 << " ; f2 = " << f2 << std::endl; + //std::cout << "q.dir = " << q.dir << " ; f1 = " << f1[0] << " " << f1[1] << " " << f1[2] << " ; f2 = " << f2[0] << " " << f2[1] << " " << f2[2] << std::endl; // OK + + for (int i = 0; i < 3; ++i) + if (f1[i] != f2[i]) + __builtin_abort(); +}