-
Notifications
You must be signed in to change notification settings - Fork 206
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
Add basic implementation of the ComWrappers #653
Merged
+758
−40
Merged
Changes from 1 commit
Commits
Show all changes
58 commits
Select commit
Hold shift + click to select a range
28bf64b
Add basic implementation of the ComWrappers
kant2002 d8daea1
Fixes after refactoring in dotnet/runtime
kant2002 3328c6d
Rough attempt to move forward. Attempt to create CCW
kant2002 b328e48
Slight push toward CCW.
kant2002 f8165c6
Move configuration for FeatureComWrappers outside of project file
kant2002 fb2233f
More implementation for the MOW
kant2002 e35695b
Slightly more changes based on feedback.
kant2002 868b1bf
Delagate IUnknown implementation to MOW
kant2002 017e907
Implement IUnknown interface for CCW
kant2002 d4e3188
Return proper pointer to IUnknown
kant2002 3d5867c
Update src/coreclr/nativeaot/System.Private.CoreLib/src/System/Runtim…
kant2002 dd7ebdd
Update src/coreclr/nativeaot/System.Private.CoreLib/src/System/Runtim…
kant2002 f03e3c8
Apply suggestions from code review
kant2002 b2b33ff
Apply suggestions from code review
kant2002 75145a8
Apply suggestions from code review
kant2002 ac4d949
Address PR feedback
kant2002 fa87e37
Cleanup code
kant2002 8c89b5a
Fix build
kant2002 3aafcd6
Apply suggestions from code review
kant2002 72da0c7
Fix compilation errrors
kant2002 3c93e34
Introduce InternalComInterfaceDispatch
kant2002 b1dfda4
Reuse variable
kant2002 c4dca94
Delegate conversion of runtime object to COM object to ComWrappers in…
kant2002 367e5f4
Change message when ComWrappers are required.
kant2002 7577418
Attempt to fix compilation error.
kant2002 2fead1d
Minimal amount of working COM
kant2002 c7a5d1e
Fix typo
kant2002 08d92c2
Update src/coreclr/tools/Common/TypeSystem/IL/Stubs/PInvokeILEmitter.cs
jkotas 3e8a8c2
Apply code review suggestions
kant2002 d9a65a0
Apply code review suggestions
kant2002 c06f5e2
Add tests for the CCW release process
kant2002 577f34a
Apply suggestions from code review
kant2002 ae0c824
Fix compilation errors
kant2002 a36de92
Remove Destroyed field from MOW
kant2002 7ee193a
Ignore COM related functions in native tests code
kant2002 70dd962
Fix random crash on debug builds.
kant2002 847a68e
Apply suggestions from code review
kant2002 0cf1003
Apply suggestions from code review
kant2002 479e306
Add validation of call for DoWork
kant2002 62acb0b
Fix PR feedback
kant2002 b021ef8
Switch to COM interface
kant2002 7abba2f
Pass type to which convert COM instance.
kant2002 3b2848a
Create separate tests for ComWrappers feature
kant2002 87213bb
Fix Pinvoke name of the DLL with test functions
kant2002 acfaca8
Fix code review comments
kant2002 ecbd14e
Remove incomplete PreserveSig implementation
kant2002 3dce725
Update src/tests/nativeaot/SmokeTests/ComWrappers/ComWrappers.cs
kant2002 359c53d
Update src/tests/nativeaot/SmokeTests/ComWrappers/ComWrappers.cs
kant2002 e761497
Update src/tests/nativeaot/SmokeTests/ComWrappers/ComWrappers.csproj
kant2002 5a6d6eb
Update src/tests/nativeaot/SmokeTests/ComWrappers/ComWrappers.cs
kant2002 716d585
Fix compilation errors
kant2002 218a300
Read GUID directly from metadata instead of relying on Reflection
kant2002 e7b0b59
Remove leftover
kant2002 bdba4ea
Improve GUID creation
kant2002 1db71ff
Fix stupid compilation error
kant2002 2f826ce
Add missing using
kant2002 0b90983
Another round of stupidity
kant2002 f9acd5c
One more try
kant2002 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -8,6 +8,8 @@ | |
|
||
using Debug = System.Diagnostics.Debug; | ||
using ILLocalVariable = Internal.IL.Stubs.ILLocalVariable; | ||
using Internal.TypeSystem.Ecma; | ||
using System.Reflection.Metadata; | ||
|
||
namespace Internal.TypeSystem.Interop | ||
{ | ||
|
@@ -873,10 +875,51 @@ protected override void AllocAndTransformManagedToNative(ILCodeStream codeStream | |
|
||
MethodDesc helper = Context.GetHelperEntryPoint("InteropHelpers", "ConvertManagedComInterfaceToNative"); | ||
LoadManagedValue(codeStream); | ||
codeStream.Emit(ILOpcode.ldtoken, emitter.NewToken(this.ManagedParameterType)); | ||
MethodDesc getTypeFromHandleMethod = | ||
Context.SystemModule.GetKnownType("System", "Type").GetKnownMethod("GetTypeFromHandle", null); | ||
codeStream.Emit(ILOpcode.call, emitter.NewToken(getTypeFromHandleMethod)); | ||
CustomAttributeValue<TypeDesc>? guidAttributeValue = (this.ManagedParameterType as EcmaType)? | ||
.GetDecodedCustomAttribute("System.Runtime.InteropServices", "GuidAttribute"); | ||
if (guidAttributeValue == null) | ||
{ | ||
throw new NotSupportedException(); | ||
} | ||
|
||
var guidValue = (string)guidAttributeValue.Value.FixedArguments[0].Value; | ||
var parts = guidValue.Split('-'); | ||
codeStream.Emit(ILOpcode.ldtoken, emitter.NewToken((EcmaType)this.ManagedParameterType)); | ||
MetadataType guidType = Context.SystemModule.GetKnownType("System", "Guid"); | ||
var int32Type = Context.GetWellKnownType(WellKnownType.Int32); | ||
var int16Type = Context.GetWellKnownType(WellKnownType.Int16); | ||
var byteType = Context.GetWellKnownType(WellKnownType.Byte); | ||
guidType.GetParameterlessConstructor(); | ||
int param1 = int.Parse(parts[0], System.Globalization.NumberStyles.HexNumber); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It would be simpler and faster to do:
|
||
short param2 = short.Parse(parts[1], System.Globalization.NumberStyles.HexNumber); | ||
short param3 = short.Parse(parts[2], System.Globalization.NumberStyles.HexNumber); | ||
byte param4 = byte.Parse(parts[3].Substring(0, 2), System.Globalization.NumberStyles.HexNumber); | ||
byte param5 = byte.Parse(parts[3].Substring(2), System.Globalization.NumberStyles.HexNumber); | ||
byte param6 = byte.Parse(parts[4].Substring(0, 2), System.Globalization.NumberStyles.HexNumber); | ||
byte param7 = byte.Parse(parts[4].Substring(2, 2), System.Globalization.NumberStyles.HexNumber); | ||
byte param8 = byte.Parse(parts[4].Substring(4, 2), System.Globalization.NumberStyles.HexNumber); | ||
byte param9 = byte.Parse(parts[4].Substring(6, 2), System.Globalization.NumberStyles.HexNumber); | ||
byte param10 = byte.Parse(parts[4].Substring(8, 2), System.Globalization.NumberStyles.HexNumber); | ||
byte param11 = byte.Parse(parts[4].Substring(10, 2), System.Globalization.NumberStyles.HexNumber); | ||
var sig = new MethodSignature( | ||
MethodSignatureFlags.None, | ||
genericParameterCount: 0, | ||
returnType: Context.GetWellKnownType(WellKnownType.Void), | ||
parameters: new TypeDesc[] { int32Type, int16Type, int16Type, byteType, byteType, byteType, byteType, byteType, byteType, byteType, byteType }); | ||
MethodDesc guidCtorHandleMethod = | ||
guidType.GetKnownMethod(".ctor", sig); | ||
codeStream.EmitLdc(param1); | ||
codeStream.EmitLdc(param2); | ||
codeStream.EmitLdc(param3); | ||
codeStream.EmitLdc(param4); | ||
codeStream.EmitLdc(param5); | ||
codeStream.EmitLdc(param6); | ||
codeStream.EmitLdc(param7); | ||
codeStream.EmitLdc(param8); | ||
codeStream.EmitLdc(param9); | ||
codeStream.EmitLdc(param10); | ||
codeStream.EmitLdc(param11); | ||
codeStream.Emit(ILOpcode.newobj, emitter.NewToken(guidCtorHandleMethod)); | ||
|
||
codeStream.Emit(ILOpcode.call, emitter.NewToken(helper)); | ||
|
||
|
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.