From: Ian Lance Taylor Date: Wed, 9 Jan 2019 23:38:55 +0000 (+0000) Subject: re PR go/86343 (types built by GO share TYPE_FIELDS in unsupported way) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=eea11d66bcc0a549fa95f71a7a6bfb97a8dbc7e1;p=gcc.git re PR go/86343 (types built by GO share TYPE_FIELDS in unsupported way) PR go/86343 * go-gcc.cc (Gcc_backend::set_placeholder_struct_type): Go back to build_distinct_type_copy, but copy the fields so that they have the right DECL_CONTEXT. From-SVN: r267789 --- diff --git a/gcc/go/ChangeLog b/gcc/go/ChangeLog index 64e20cd128a..0a579bd9417 100644 --- a/gcc/go/ChangeLog +++ b/gcc/go/ChangeLog @@ -1,3 +1,10 @@ +2019-01-09 Ian Lance Taylor + + PR go/86343 + * go-gcc.cc (Gcc_backend::set_placeholder_struct_type): Go back to + build_distinct_type_copy, but copy the fields so that they have + the right DECL_CONTEXT. + 2019-01-09 Sandra Loosemore PR other/16615 diff --git a/gcc/go/go-gcc.cc b/gcc/go/go-gcc.cc index afdc7f8c5b2..7fbdd074119 100644 --- a/gcc/go/go-gcc.cc +++ b/gcc/go/go-gcc.cc @@ -1098,9 +1098,13 @@ Gcc_backend::set_placeholder_struct_type( if (TYPE_NAME(t) != NULL_TREE) { // Build the data structure gcc wants to see for a typedef. - tree copy = build_variant_type_copy(t); + tree copy = build_distinct_type_copy(t); TYPE_NAME(copy) = NULL_TREE; DECL_ORIGINAL_TYPE(TYPE_NAME(t)) = copy; + TYPE_SIZE(copy) = NULL_TREE; + Btype* bc = this->make_type(copy); + this->fill_in_struct(bc, fields); + delete bc; } return r->get_tree() != error_mark_node;