https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105322

Jiu Fu Guo <guojiufu at gcc dot gnu.org> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |guojiufu at gcc dot gnu.org

--- Comment #3 from Jiu Fu Guo <guojiufu at gcc dot gnu.org> ---
One finding:
In trees_out::decl_node, there are code lines:

    case FIELD_DECL:
      {
        if (streaming_p ())
          i (tt_data_member);

        tree ctx = DECL_CONTEXT (decl);
        tree_node (ctx); //The context, is the struct "S" inside foo, "S" is
handled in 'tree_node', and "insert" is called for member "d".

        tree name = NULL_TREE;

        if (TREE_CODE (decl) == USING_DECL)
          ;
        else
          {
            name = DECL_NAME (decl);
            if (name && IDENTIFIER_ANON_P (name))
              name = NULL_TREE;
          }

        tree_node (name);
        if (!name && streaming_p ())
          {
            unsigned ix = get_field_ident (ctx, decl);
            u (ix);
          }

        int tag = insert (decl); //HERE, "insert" is called again member "d". 

It may be a direct cause that "insert" is called twice for "d", and then a
crash occurs.

While I do not know much about the code and do not found a fix.

Reply via email to