diff options
author | Jan Vorlicek <janvorli@microsoft.com> | 2018-08-23 02:42:43 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-08-23 02:42:43 +0200 |
commit | 8cd4b39a42c1c7cf37502357e6a4cb2888f5dfd7 (patch) | |
tree | a767facb00becfc9b6b9f0c3a8d731e566e3d1c3 /src/vm/stublink.h | |
parent | 8013a4b6786d9e6618f8ed36bd0a473aa17b72aa (diff) | |
download | coreclr-8cd4b39a42c1c7cf37502357e6a4cb2888f5dfd7.tar.gz coreclr-8cd4b39a42c1c7cf37502357e6a4cb2888f5dfd7.tar.bz2 coreclr-8cd4b39a42c1c7cf37502357e6a4cb2888f5dfd7.zip |
Enable unloading of AssemblyLoadContext (#18476)
Enable assembly unloading
* Allow PInvoke methods on collectible assemblies
* Fix test unloadability
Several hundreds of tests were using Helper class that created
GCHandle, but never freed it. That prevented unloading of those
tests. The change modifies the Helper class to keep the handle
in a finalizable object.
Several GCHandle related tests were not freeing the GCHandle they
allocated, so this change adds freeing them to enable the unloading.
* Add missing error messages to the resources
* Fix shuffle thunk cache for unloadability
* Add GetLoaderAllocator to ICLRPrivBinder
Diffstat (limited to 'src/vm/stublink.h')
-rw-r--r-- | src/vm/stublink.h | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/src/vm/stublink.h b/src/vm/stublink.h index d7f0034587..41c11ebb49 100644 --- a/src/vm/stublink.h +++ b/src/vm/stublink.h @@ -281,7 +281,6 @@ public: // // Throws exception on failure. //--------------------------------------------------------------- - Stub *Link(DWORD flags = 0) { WRAPPER_NO_CONTRACT; return Link(NULL, flags); } Stub *Link(LoaderHeap *heap, DWORD flags = 0); //--------------------------------------------------------------- @@ -411,11 +410,11 @@ private: // Writes out the code element into memory following the // stub object. - bool EmitStub(Stub* pStub, int globalsize); + bool EmitStub(Stub* pStub, int globalsize, LoaderHeap* pHeap); CodeRun *GetLastCodeRunIfAny(); - bool EmitUnwindInfo(Stub* pStub, int globalsize); + bool EmitUnwindInfo(Stub* pStub, int globalsize, LoaderHeap* pHeap); #if defined(_TARGET_AMD64_) && defined(STUBLINKER_GENERATES_UNWIND_INFO) UNWIND_CODE *AllocUnwindInfo (UCHAR Op, UCHAR nExtraSlots = 0); |