+2020-05-04 Marek Polacek <polacek@redhat.com>
+
+ Revert:
+ 2020-04-30 Marek Polacek <polacek@redhat.com>
+
+ PR c++/94775
+ * tree.c (check_base_type): Return true only if TYPE_USER_ALIGN match.
+ (check_aligned_type): Check if TYPE_USER_ALIGN match.
+
2020-05-04 Richard Biener <rguenther@suse.de>
PR tree-optimization/93891
+++ /dev/null
-// PR c++/94775
-// { dg-do compile { target c++14 } }
-// { dg-options "-O2 -Warray-bounds" }
-
-template <typename> using a = int;
-template <bool, typename, typename> using b = int;
-typedef char d;
-template <long> using e = int;
-template <int f, int q> struct h { using i = b<q, a<e<f>>, e<f>>; };
-template <long f, bool g> using j = typename h<f, g>::i;
-long ab, k, aj;
-const d l[]{};
-class m {
-public:
- m(int);
-};
-class n {
- void ad() const;
- template <class ae> void o(long) const {
- using c __attribute__((aligned(1))) = const ae;
- }
- long p;
- template <class, class>
- auto s(unsigned long, unsigned long, unsigned long, unsigned long) const;
- template <bool = false> auto q(unsigned long, unsigned long) const;
-};
-template <class, class>
-auto n::s(unsigned long, unsigned long, unsigned long, unsigned long t) const {
- o<d>(p);
- return t;
-}
-template <bool g> auto n::q(unsigned long p1, unsigned long p2) const {
- using r = j<4, false>;
- using ai = j<4, g>;
- return s<ai, r>(ab, k, p1, p2);
-}
-void n::ad() const {
- long f(l[aj]); // { dg-warning "outside array bounds" }
- m(q(8, f));
-}
TYPE_ATTRIBUTES (base)))
return false;
/* Check alignment. */
- if (TYPE_ALIGN (cand) == TYPE_ALIGN (base)
- && TYPE_USER_ALIGN (cand) == TYPE_USER_ALIGN (base))
+ if (TYPE_ALIGN (cand) == TYPE_ALIGN (base))
return true;
/* Atomic types increase minimal alignment. We must to do so as well
or we get duplicated canonical types. See PR88686. */
&& TYPE_CONTEXT (cand) == TYPE_CONTEXT (base)
/* Check alignment. */
&& TYPE_ALIGN (cand) == align
- && TYPE_USER_ALIGN (cand) == TYPE_USER_ALIGN (base)
&& attribute_list_equal (TYPE_ATTRIBUTES (cand),
TYPE_ATTRIBUTES (base))
&& check_lang_type (cand, base));