Skip to content

Commit

Permalink
gccrs: ensure packed and aligned is applied properly
Browse files Browse the repository at this point in the history
We cannot apply aligned or packed after layout_type is called you need
to set this up first then call it.

Fixes #3260

gcc/rust/ChangeLog:

	* backend/rust-compile-type.cc (TyTyResolveCompile::visit): call lauout type directly
	* rust-backend.h (struct_type): add optional layout parameter
	(union_type): likewise
	(fill_in_fields): likewise
	* rust-gcc.cc (struct_type): likewise
	(union_type): likewise
	(fill_in_fields): only layout if we required

Signed-off-by: Philip Herron <[email protected]>
  • Loading branch information
philberty committed Nov 26, 2024
1 parent 898f2e8 commit 6eea7d7
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 17 deletions.
18 changes: 10 additions & 8 deletions gcc/rust/backend/rust-compile-type.cc
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
#include "rust-gcc.h"

#include "tree.h"
#include "stor-layout.h"

namespace Rust {
namespace Compile {
Expand Down Expand Up @@ -268,8 +269,8 @@ TyTyResolveCompile::visit (const TyTy::ADTType &type)
fields.push_back (std::move (f));
}

type_record = type.is_union () ? Backend::union_type (fields)
: Backend::struct_type (fields);
type_record = type.is_union () ? Backend::union_type (fields, false)
: Backend::struct_type (fields, false);
}
else
{
Expand Down Expand Up @@ -359,7 +360,7 @@ TyTyResolveCompile::visit (const TyTy::ADTType &type)
}

// finally make the union or the enum
type_record = Backend::union_type (enum_fields);
type_record = Backend::union_type (enum_fields, false);
}

// Handle repr options
Expand All @@ -370,17 +371,18 @@ TyTyResolveCompile::visit (const TyTy::ADTType &type)
if (repr.pack)
{
TYPE_PACKED (type_record) = 1;
if (repr.pack > 1)
{
SET_TYPE_ALIGN (type_record, repr.pack * 8);
TYPE_USER_ALIGN (type_record) = 1;
}
// if (repr.pack > 1)
// {
// SET_TYPE_ALIGN (type_record, repr.pack * 8);
// TYPE_USER_ALIGN (type_record) = 1;
// }
}
else if (repr.align)
{
SET_TYPE_ALIGN (type_record, repr.align * 8);
TYPE_USER_ALIGN (type_record) = 1;
}
layout_type (type_record);

std::string named_struct_str
= type.get_ident ().path.get () + type.subst_as_string ();
Expand Down
6 changes: 3 additions & 3 deletions gcc/rust/rust-backend.h
Original file line number Diff line number Diff line change
Expand Up @@ -133,11 +133,11 @@ function_ptr_type (tree result, const std::vector<tree> &praameters,

// Get a struct type.
tree
struct_type (const std::vector<typed_identifier> &fields);
struct_type (const std::vector<typed_identifier> &fields, bool layout = true);

// Get a union type.
tree
union_type (const std::vector<typed_identifier> &fields);
union_type (const std::vector<typed_identifier> &fields, bool layout = true);

// Get an array type.
tree
Expand Down Expand Up @@ -496,7 +496,7 @@ write_global_definitions (const std::vector<tree> &type_decls,
// TODO: make static

tree
fill_in_fields (tree, const std::vector<typed_identifier> &);
fill_in_fields (tree, const std::vector<typed_identifier> &, bool);

tree fill_in_array (tree, tree, tree);

Expand Down
15 changes: 9 additions & 6 deletions gcc/rust/rust-gcc.cc
Original file line number Diff line number Diff line change
Expand Up @@ -592,23 +592,24 @@ function_ptr_type (tree result_type, const std::vector<tree> &parameters,
// Make a struct type.

tree
struct_type (const std::vector<typed_identifier> &fields)
struct_type (const std::vector<typed_identifier> &fields, bool layout)
{
return fill_in_fields (make_node (RECORD_TYPE), fields);
return fill_in_fields (make_node (RECORD_TYPE), fields, layout);
}

// Make a union type.

tree
union_type (const std::vector<typed_identifier> &fields)
union_type (const std::vector<typed_identifier> &fields, bool layout)
{
return fill_in_fields (make_node (UNION_TYPE), fields);
return fill_in_fields (make_node (UNION_TYPE), fields, layout);
}

// Fill in the fields of a struct or union type.

tree
fill_in_fields (tree fill, const std::vector<typed_identifier> &fields)
fill_in_fields (tree fill, const std::vector<typed_identifier> &fields,
bool layout)
{
tree field_trees = NULL_TREE;
tree *pp = &field_trees;
Expand All @@ -625,7 +626,9 @@ fill_in_fields (tree fill, const std::vector<typed_identifier> &fields)
pp = &DECL_CHAIN (field);
}
TYPE_FIELDS (fill) = field_trees;
layout_type (fill);

if (layout)
layout_type (fill);

// Because Rust permits converting between named struct types and
// equivalent struct types, for which we use VIEW_CONVERT_EXPR, and
Expand Down

0 comments on commit 6eea7d7

Please sign in to comment.