------- Comment #4 from rguenth at gcc dot gnu dot org  2008-02-14 13:43 -------
Reduced testcase, which shows this is inlining related and not related to
PR34989.  Honza, can you have a look?  After inlining we have:

<bb 2>:
  # iter_6 = PHI <iter_7(ab)(4), iter_2(ab)(5)>

where clearly iter_6 should be marked abnormal?  But I also don't see who
messes up between sdse2 and apply_inline (we don't seem to inline anything
after all).


struct __shared_count {
    __shared_count() { _M_pi = new int; }
    int * _M_pi;
};
template<typename _Tp>
class __shared_ptr {
public:
    __shared_ptr(_Tp* __p);
    void reset(int * __p) {
        __shared_ptr(__p).swap(*this);
    }
    void swap(__shared_ptr<_Tp>& __other) {
        __other._M_refcount._M_pi = _M_refcount._M_pi;
    }
    __shared_count _M_refcount;
};
template<typename _Tp> class shared_ptr : public __shared_ptr<_Tp> {};
int main() {
    for (shared_ptr<int> *iter;;)
    {
        try {
            (iter++)->reset(new int);
        }
        catch (...) {
        }
    }
}


-- 

rguenth at gcc dot gnu dot org changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |hubicka at gcc dot gnu dot
                   |                            |org
           Priority|P3                          |P1


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35182

Reply via email to