re PR debug/48967 (ICE during use_narrower_mode)
PR debug/48967 * var-tracking.c (use_narrower_mode_test) <case REG>: Return 1 if validate_subreg fails. * g++.dg/opt/pr48967.C: New test. From-SVN: r173701
This commit is contained in:
parent
35d828c58b
commit
2c703f3a6a
@ -1,4 +1,10 @@
|
|||||||
2011-05-12 Hariharan Sandanagobalane <hariharan@picochip.com>
|
2011-05-12 Jakub Jelinek <jakub@redhat.com>
|
||||||
|
|
||||||
|
PR debug/48967
|
||||||
|
* var-tracking.c (use_narrower_mode_test) <case REG>: Return 1
|
||||||
|
if validate_subreg fails.
|
||||||
|
|
||||||
|
2011-05-12 Hariharan Sandanagobalane <hariharan@picochip.com>
|
||||||
|
|
||||||
* ira.c (clarify_prohibited_class_mode_regs): Prevent the function from
|
* ira.c (clarify_prohibited_class_mode_regs): Prevent the function from
|
||||||
accessing beyond the end of REGNO_REG_CLASS array by stopping the loop
|
accessing beyond the end of REGNO_REG_CLASS array by stopping the loop
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
2011-05-12 Jakub Jelinek <jakub@redhat.com>
|
||||||
|
|
||||||
|
PR debug/48967
|
||||||
|
* g++.dg/opt/pr48967.C: New test.
|
||||||
|
|
||||||
2011-05-11 Jason Merrill <jason@redhat.com>
|
2011-05-11 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
* g++.dg/cpp0x/constexpr-friend.C: New.
|
* g++.dg/cpp0x/constexpr-friend.C: New.
|
||||||
|
98
gcc/testsuite/g++.dg/opt/pr48967.C
Normal file
98
gcc/testsuite/g++.dg/opt/pr48967.C
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
// PR debug/48967
|
||||||
|
// { dg-do compile }
|
||||||
|
// { dg-options "-g -O2" }
|
||||||
|
|
||||||
|
template <typename> struct A;
|
||||||
|
template <typename T> struct A <T *>
|
||||||
|
{
|
||||||
|
typedef T ref;
|
||||||
|
};
|
||||||
|
template <typename T, typename> struct B
|
||||||
|
{
|
||||||
|
typedef A <T> t;
|
||||||
|
typedef typename t::ref ref;
|
||||||
|
ref operator * () { return ref (); }
|
||||||
|
};
|
||||||
|
template <typename T> struct I
|
||||||
|
{
|
||||||
|
typedef T *cp;
|
||||||
|
template <typename T1> struct J
|
||||||
|
{
|
||||||
|
typedef I <T1> other;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
template <typename T> struct S : public I <T>
|
||||||
|
{
|
||||||
|
};
|
||||||
|
template <typename T, typename _A> struct E
|
||||||
|
{
|
||||||
|
typedef typename _A::template J <T>::other at;
|
||||||
|
};
|
||||||
|
template <typename T, typename _A = S <T> > struct D
|
||||||
|
{
|
||||||
|
typedef E <T, _A> _Base;
|
||||||
|
typedef typename _Base::at at;
|
||||||
|
typedef typename at::cp cp;
|
||||||
|
typedef B <cp, D> H;
|
||||||
|
};
|
||||||
|
template <class T> struct F
|
||||||
|
{
|
||||||
|
T *operator -> () { return __null; }
|
||||||
|
};
|
||||||
|
template <typename T> long
|
||||||
|
lfloor (T x)
|
||||||
|
{
|
||||||
|
return static_cast <long>(x) - (x && x != static_cast <long>(x));
|
||||||
|
}
|
||||||
|
template <typename T> long
|
||||||
|
lround (T x)
|
||||||
|
{
|
||||||
|
return lfloor (x - 0.5) + 1;
|
||||||
|
}
|
||||||
|
class M;
|
||||||
|
template <typename> class P;
|
||||||
|
typedef P <M> Q;
|
||||||
|
template <typename> struct P
|
||||||
|
{
|
||||||
|
float x ();
|
||||||
|
};
|
||||||
|
struct CV
|
||||||
|
{
|
||||||
|
Q c;
|
||||||
|
};
|
||||||
|
struct C
|
||||||
|
{
|
||||||
|
void foo (const CV &) const;
|
||||||
|
class O;
|
||||||
|
typedef D <F <O> > R;
|
||||||
|
R n;
|
||||||
|
};
|
||||||
|
struct S3
|
||||||
|
{
|
||||||
|
S3 (int, int);
|
||||||
|
};
|
||||||
|
struct S2
|
||||||
|
{
|
||||||
|
S3 sx, sy;
|
||||||
|
S2 (int x = 0, int y = 0, int s = 0, int t = 0) : sx (x, y), sy (s, t) {}
|
||||||
|
};
|
||||||
|
template <typename> struct N
|
||||||
|
{
|
||||||
|
int bar ();
|
||||||
|
};
|
||||||
|
struct C::O
|
||||||
|
{
|
||||||
|
N <float> o;
|
||||||
|
void foo (CV r, int)
|
||||||
|
{
|
||||||
|
Q c = r.c;
|
||||||
|
float t = 0.5 * (o.bar ());
|
||||||
|
S2 (lround (c.x ()), t);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
void
|
||||||
|
C::foo (const CV &w) const
|
||||||
|
{
|
||||||
|
R::H m;
|
||||||
|
(*m)->foo (w, 8);
|
||||||
|
}
|
@ -745,6 +745,10 @@ use_narrower_mode_test (rtx *loc, void *data)
|
|||||||
case REG:
|
case REG:
|
||||||
if (cselib_lookup (*loc, GET_MODE (SUBREG_REG (subreg)), 0, VOIDmode))
|
if (cselib_lookup (*loc, GET_MODE (SUBREG_REG (subreg)), 0, VOIDmode))
|
||||||
return 1;
|
return 1;
|
||||||
|
if (!validate_subreg (GET_MODE (subreg), GET_MODE (*loc),
|
||||||
|
*loc, subreg_lowpart_offset (GET_MODE (subreg),
|
||||||
|
GET_MODE (*loc))))
|
||||||
|
return 1;
|
||||||
return -1;
|
return -1;
|
||||||
case PLUS:
|
case PLUS:
|
||||||
case MINUS:
|
case MINUS:
|
||||||
|
Loading…
Reference in New Issue
Block a user