-
Notifications
You must be signed in to change notification settings - Fork 199
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
Investigate EETypePtr overhead #232
Labels
area-NativeAOT-coreclr
.NET runtime optimized for ahead of time compilation
Comments
jkotas
added
the
area-NativeAOT-coreclr
.NET runtime optimized for ahead of time compilation
label
Oct 15, 2020
Another factor to consider is code sharing with full CoreCLR. MethodTable and EEType are 80% the same between. We need a plan how to share the code that uses these. For example, the EEType is a better name. Unfortunately, MethodTable is too entrenched in CoreCLR in all code, documentation and user facing surface (e.g. DumpMT command in SOS). |
MichalStrehovsky
added a commit
to MichalStrehovsky/runtimelab
that referenced
this issue
Sep 3, 2021
Makes storing into arrays 40% faster if there's no covariance. I added `Object.MethodTableOf<T>` because `EETypePtrOf<T>` was causing a spill into a temporary and was messing up codegen and we'll want this for dotnet#232 anyway. I wanted to add `MethodTable.Of<T>`, but `Object` has a property named `MethodTable` and that was breaking the pattern. So it's on `Object`. Oh well.
jkotas
pushed a commit
that referenced
this issue
Sep 3, 2021
Makes storing into arrays 40% faster if there's no covariance. I added `Object.MethodTableOf<T>` because `EETypePtrOf<T>` was causing a spill into a temporary and was messing up codegen and we'll want this for #232 anyway. I wanted to add `MethodTable.Of<T>`, but `Object` has a property named `MethodTable` and that was breaking the pattern. So it's on `Object`. Oh well.
MichalStrehovsky
added a commit
to MichalStrehovsky/runtime
that referenced
this issue
Mar 13, 2023
I thought it might improve codegen, but the improvements are marginal. Still, contributes to dotnet/runtimelab#232.
MichalStrehovsky
added a commit
to dotnet/runtime
that referenced
this issue
Mar 13, 2023
I thought it might improve codegen, but the improvements are marginal. Still, contributes to dotnet/runtimelab#232.
MichalStrehovsky
added a commit
to MichalStrehovsky/runtime
that referenced
this issue
Jan 19, 2024
Resolves dotnet/runtimelab#232. This wrapper served two purposes over `MethodTable*`: * Make sure equality semantics were enforced at the time where we could have multiple `MethodTable*` representing the same type. This is no longer the case and we don't need it for this purpose. * Save us from typing `unsafe` Apart from this, it also pessimized codegen (see the linked issue). Bye `EETypePtr`. I didn't fully delete it because the `CorElementType` conversion is still there. We can deal with that later.
MichalStrehovsky
added a commit
to dotnet/runtime
that referenced
this issue
Jan 21, 2024
Resolves dotnet/runtimelab#232. This wrapper served two purposes over `MethodTable*`: * Make sure equality semantics were enforced at the time where we could have multiple `MethodTable*` representing the same type. This is no longer the case and we don't need it for this purpose. * Save us from typing `unsafe` Apart from this, it also pessimized codegen (see the linked issue). Bye `EETypePtr`. I didn't fully delete it because the `CorElementType` conversion is still there. We can deal with that later.
tmds
pushed a commit
to tmds/runtime
that referenced
this issue
Jan 23, 2024
Resolves dotnet/runtimelab#232. This wrapper served two purposes over `MethodTable*`: * Make sure equality semantics were enforced at the time where we could have multiple `MethodTable*` representing the same type. This is no longer the case and we don't need it for this purpose. * Save us from typing `unsafe` Apart from this, it also pessimized codegen (see the linked issue). Bye `EETypePtr`. I didn't fully delete it because the `CorElementType` conversion is still there. We can deal with that later.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Context: #225 (comment)
RuJIT is not able to optimize out the EETypePtr wrapper completely. In the example above the EETypePtr wrapper:
cmp [rcx], rdx
vs.mov rax, [rcx] cmp rax, rdx
)The text was updated successfully, but these errors were encountered: