Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[SwiftBindings] Implement algorithm deciding whether a struct should be projected as class or struct #2886

Open
Tracked by #2822
jkurdek opened this issue Dec 17, 2024 · 4 comments
Assignees
Labels
area-SwiftBindings Swift bindings for .NET

Comments

@jkurdek
Copy link
Member

jkurdek commented Dec 17, 2024

Struct should be projected as a struct if:

  • Struct needs to be marked as frozen, every member of this struct has to be either trivial or marked as frozen (recursively)
  • Structs needs to be POD/Trivial / Bitwise Movable
@jkurdek jkurdek changed the title Frozen structs with non-frozen members [SwiftBindings] Implement algorithm deciding whether a struct should be projected as class or struct Dec 17, 2024
@jkurdek jkurdek added the area-SwiftBindings Swift bindings for .NET label Dec 17, 2024
@jkurdek
Copy link
Member Author

jkurdek commented Jan 7, 2025

I did look into swift code - tried to find a better way to determine whether to project something as a struct or as class. There is a field on ValueWitnessTable called IsNotInline which seems to be true whenever the struct will be passes as a pointer. Link. However this value will also be true for frozen structs which exceed the lowering threshold (4 machine words). Have we looked into that before?

An alternative is to recursively traverse struct children - this however means that all of struct children have to processed before a projection involving a struct can be made - which means building up the type database of multiple modules before a single projection can be made.

cc: @jkoritzinsky @stephen-hawley @kotlarmilos @matouskozak

@stephen-hawley
Copy link

Having a complete type database seems more reliable to me.

@kotlarmilos
Copy link
Member

kotlarmilos commented Jan 8, 2025

Having a complete type database seems more reliable to me.

+1. We can assume that projection tooling will process modules in a correct order.

We might not be able to read ValueWitnessTable if target is not macOS. I suggest that the projection tooling emits a Debug.Assert for IsNotInline flag to ensures that the projections match the expected lowering, but the ABI file should be treated as the source of truth.

@jkurdek
Copy link
Member Author

jkurdek commented Jan 8, 2025

Great! I then propose the following design:

Assumption: Tooling will process modules in correct order. Processing each module will result in a type database file.

When processing a new module the tooling will first parse the ABI and build a graph of dependencies for each type. Dependencies will go into two categories (same module / other modules).

Then in a post-processing step the tooling will process the graph and compute the necessary information. Doing this in correct order will ensure that when processing a node either its dependencies reside in one of the type databases for previous modules or have been processed earlier. After the processing is finished the tooling will lock the type database and save it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area-SwiftBindings Swift bindings for .NET
Projects
None yet
Development

No branches or pull requests

3 participants