Skip to content

Conversation

@radekdoulik
Copy link
Member

Fixes #122294

The default layout is now equal to the struct layout in C. The auto layout is updated in the same way.

Fixes dotnet#122294

The default layout is now equal to the C struct layout. The auto
layout is updated in the same way.
@radekdoulik radekdoulik added this to the 11.0.0 milestone Dec 22, 2025
@github-actions github-actions bot added the needs-area-label An area label is needed to ensure this gets routed to the appropriate area owners label Dec 22, 2025
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

This PR fixes struct layout alignment for WebAssembly (WASM) in CoreCLR to match C language struct layout rules. The changes ensure that when a type requires 8-byte alignment on WASM, the actual field alignment requirement is consulted rather than hardcoding the alignment to 8 bytes, which aligns the behavior with C struct layout semantics.

  • Updates auto layout handling to use actual field alignment requirements on WASM when types require 8-byte alignment
  • Updates default layout handling with the same WASM-specific logic for consistency

Reviewed changes

Copilot reviewed 2 out of 2 changed files in this pull request and generated no comments.

File Description
src/coreclr/vm/methodtablebuilder.cpp Adds TARGET_WASM-specific logic in auto layout to use max(8, GetFieldAlignmentRequirement()) instead of hardcoded 8-byte alignment
src/coreclr/vm/classlayoutinfo.cpp Adds TARGET_WASM-specific logic in default layout to use max(8, GetFieldAlignmentRequirement()) instead of hardcoded 8-byte alignment

@radekdoulik radekdoulik added area-VM-coreclr and removed needs-area-label An area label is needed to ensure this gets routed to the appropriate area owners labels Dec 22, 2025
@jkotas
Copy link
Member

jkotas commented Dec 22, 2025

cc @jkoritzinsky @davidwrighton - field layout algorithm change

@radekdoulik radekdoulik force-pushed the clr-wasm-fix-struct-layout branch from 3fff77a to e37117a Compare January 4, 2026 22:09
@radekdoulik radekdoulik force-pushed the clr-wasm-fix-struct-layout branch from e37117a to 9607a71 Compare January 4, 2026 22:12
This reverts commit d278c46.
@radekdoulik radekdoulik merged commit ee0d069 into dotnet:main Jan 9, 2026
95 of 98 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

arch-wasm WebAssembly architecture area-TypeSystem-coreclr

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[wasm][coreclr] global::StructPacking.TestEntryPoint fails

5 participants