github-actions[bot] [Mon, 30 Aug 2021 02:14:17 +0000 (22:14 -0400)]
[release/6.0] Remove two async state machines for typical HTTP/1.1 request path (#58252)
* Remove two async state machines for typical HTTP/1.1 request path
* Remove unused doRequestAuth parameter for HTTP/2 and HTTP/3
* Inline HTTP/1.x handling into SendWithRetryAsync
* Inline HTTP/2 as well
* Add back assert
Co-authored-by: Stephen Toub <stoub@microsoft.com>
dotnet-maestro[bot] [Mon, 30 Aug 2021 00:47:29 +0000 (20:47 -0400)]
Update dependencies from https://github.com/dotnet/icu build
20210828.1 (#58318)
Microsoft.NETCore.Runtime.ICU.Transport
From Version 6.0.0-rc.2.21425.1 -> To Version 6.0.0-rc.2.21428.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
github-actions[bot] [Sun, 29 Aug 2021 17:13:20 +0000 (19:13 +0200)]
[release/6.0] [mono] Allow RuntimeType arguments in CustomAttributeBuilder (#58317)
Co-authored-by: Ulrich Weigand <ulrich.weigand@de.ibm.com>
github-actions[bot] [Sat, 28 Aug 2021 08:08:08 +0000 (10:08 +0200)]
[release/6.0] [mono] Support RuntimeType.MakeGenericType with non-RuntimeType elements (#58275)
Co-authored-by: Ulrich Weigand <ulrich.weigand@de.ibm.com>
github-actions[bot] [Sat, 28 Aug 2021 08:07:53 +0000 (10:07 +0200)]
[release/6.0] [mono] Fix a few corner case overflow operations (#58265)
Co-authored-by: Vlad Brezae <brezaevlad@gmail.com>
Andrew Au [Fri, 27 Aug 2021 22:48:42 +0000 (15:48 -0700)]
Fix GetGenerationBounds under USE_REGIONS (#57101) (#58277)
github-actions[bot] [Fri, 27 Aug 2021 20:34:52 +0000 (13:34 -0700)]
[release/6.0] Fix VN incorrect optimizations with a new JitEEInterface function. (#58005)
* Add/return tests.
* improve the test naming.
* Add a new JitEE method.
with a naive implementation so far.
* Handle generically dissimilar type concerns as well as handle derived type case in the managed compiler
* Fix the field and Unsafe issues.
* fix some failures.
It appeared that we have many trees where we generate unique VN for rhs and don't inform `fgValueNumberBlockAssignment` about it.
For example, for
```
N005 ( 10, 8) [000033] -A--G---R--- * ASG struct (copy)
N004 ( 3, 2) [000031] D------N---- +--* LCL_VAR struct<eightByteStruct, 8> V01 loc1 d:2
N003 ( 6, 5) [000030] n---G------- \--* IND struct
N002 ( 3, 3) [000043] ------------ \--* ADDR byref
N001 ( 3, 2) [000044] -------N---- \--* LCL_VAR struct<largeStruct, 32> V00 loc0 u:6 (last use)
```
we will generate unique rhs but then `fgValueNumberBlockAssignment` will still try to work it as with a non-unique one.
* Fix an oooold bug in VN.
For a tree like:
```
N005 ( 11, 10) [001400] -A------R---- * ASG long
N004 ( 6, 5) [001401] *------N----- +--* IND long
N003 ( 3, 3) [001402] ------------- | \--* ADDR byref Zero Fseq[_00]
N002 ( 3, 2) [001403] U------N----- | \--* LCL_VAR struct<System.Runtime.Intrinsics.Vector128`1[Byte], 16> V45 tmp38 ud:3->4
N001 ( 1, 1) [001404] ------------- \--* LCL_VAR long V69 tmp62 u:2 (last use)
```
SSA was working correctly and printing that `001403` is using SSA-3 and defining SSA-4. However, this code, for some reason, was writing result as a define for SSA-3.
* Add new test cases and a fix for them.
* correct a test copy paste
* response review.
Co-authored-by: Sergey <seandree@microsoft.com>
Co-authored-by: David Wrighton <davidwr@microsoft.com>
github-actions[bot] [Fri, 27 Aug 2021 19:29:13 +0000 (21:29 +0200)]
[mono] Fix regression introduced by PR 55726 (#58255)
* Fix endless recursion in AssemblyBuilder.GetCustomAttributesData()
and ModuleBuilder.GetCustomAttributesData()
* Re-enable test cases that now pass on Mono
Co-authored-by: Ulrich Weigand <ulrich.weigand@de.ibm.com>
github-actions[bot] [Fri, 27 Aug 2021 17:02:03 +0000 (10:02 -0700)]
[release/6.0] Fix memory leak in enqueue/dequeue of EventPipe callback data. (#58244)
* Fix memory leak in enqueue/dequeue of EventPipe callback data.
https://github.com/dotnet/runtime/pull/56104 made sure provider
callback data gets its own copy of filter data. This created a couple
of memory leaks when queue/dequeue the callback data since callback data
was not correctly freed in these scenarios leading to leaks of the copied
filter data.
Was detected running the manual EventPipe native unit tests on Windows
using its build in use of _CrtMemCheckpoint (only available in debug
builds) automatically detecting memory leaks.
Fix makes sure callback data is moved into queue on enqueue and moved
out in dequeue and that caller of dequeue make sure to
free returned callback data using ep_provider_callback_data_fini
when done using it. Doing a move instead of copy will also reduce
the number of allocations when enqueue/dequeue callback data in
provider callback queue.
* Fix build error.
Co-authored-by: lateralusX <lateralusx.github@gmail.com>
github-actions[bot] [Fri, 27 Aug 2021 16:47:37 +0000 (18:47 +0200)]
[release/6.0] [mono] Use string.Empty for empty string custom arg values (#58113)
Co-authored-by: Ulrich Weigand <ulrich.weigand@de.ibm.com>
Co-authored-by: Aleksey Kliger <alklig@microsoft.com>
Alexander Köplinger [Fri, 27 Aug 2021 14:22:02 +0000 (16:22 +0200)]
Implement Environment.GetEnvironmentVariables for Apple platforms using official API (#58161) (#58254)
Move environment handling from Mono runtime to System.Native
Fixes #58156
Co-authored-by: Filip Navara <navara@emclient.com>
Co-authored-by: Adeel Mujahid <3840695+am11@users.noreply.github.com>
github-actions[bot] [Fri, 27 Aug 2021 13:52:40 +0000 (06:52 -0700)]
Handle shadowed property names in DiagnosticsSourceEventSource (#58212)
Co-authored-by: John Salem <josalem@microsoft.com>
github-actions[bot] [Fri, 27 Aug 2021 13:52:28 +0000 (06:52 -0700)]
Fix frequent FuncEval abort upon hitting a breakpoint in an ASP.NET Core web app (#58218)
- `AssemblySpecBindingCache` uses a cooperative-GC-mode data structure for the cache and operates on the cache from inside a lock taken in preemptive-GC-mode
- So when the cache is being used, cooperative-GC-mode is entered while holding the lock, which can in turn suspend for the debugger. Then a FuncEval that also happens to operate on the cache would deadlock on acquiring the lock and would have to be aborted.
- This seems to be happening very frequently when hitting an early breakpoint in a default new ASP.NET Core web app in .NET 6 when hot reload is enabled
- Fixed by using the same solution that was used for the slot backpatching lock. When cooperative-GC-mode would be entered inside the lock, a different lock holder based on `CrstAndForbidSuspendForDebuggerHolder` is used, which prevents the thread from suspending for the debugger while the lock is held. The thread would instead suspend for the debugger after leaving the forbid region after releasing the lock.
Co-authored-by: Koundinya Veluri <kouvel@microsoft.com>
github-actions[bot] [Fri, 27 Aug 2021 13:21:48 +0000 (09:21 -0400)]
[release/6.0] Prevent AV in processinfo2 while suspended on Mono. (#58158)
#55379 only fixed CoreCLR. This commit makes similar fix in Mono as well, making sure
src/tests/tracing/eventpipe/diagnosticport runtime test pass on Mono.
Co-authored-by: lateralusX <lateralusx.github@gmail.com>
Co-authored-by: Martin Costello <martin@martincostello.com>
dotnet-maestro[bot] [Fri, 27 Aug 2021 08:23:32 +0000 (10:23 +0200)]
Update dependencies from https://github.com/dotnet/runtime-assets build
20210825.1 (#58178)
Microsoft.DotNet.CilStrip.Sources , System.ComponentModel.TypeConverter.TestData , System.Drawing.Common.TestData , System.IO.Compression.TestData , System.IO.Packaging.TestData , System.Net.TestData , System.Private.Runtime.UnicodeData , System.Runtime.Numerics.TestData , System.Runtime.TimeZoneData , System.Security.Cryptography.X509Certificates.TestData , System.Windows.Extensions.TestData
From Version 6.0.0-beta.21423.1 -> To Version 6.0.0-beta.21425.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
Viktor Hofer [Fri, 27 Aug 2021 08:17:51 +0000 (10:17 +0200)]
Merge pull request #58194 from dotnet-maestro-bot/merge/release/6.0-rc1-to-release/6.0
[automated] Merge branch 'release/6.0-rc1' => 'release/6.0'
github-actions[bot] [Thu, 26 Aug 2021 19:52:43 +0000 (21:52 +0200)]
PhysicalFileProvider: Use active polling instead of FileSystemWatcher on iOS/tvOS (#58165)
In https://github.com/dotnet/runtime/issues/57931 we found out that the FSEventStream APIs which are used to implement System.IO.FileSystemWatcher aren't allowed on the App Store.
According to [Apple's docs](https://developer.apple.com/documentation/coreservices/
1443980-fseventstreamcreate) these APIs are only supported on macOS and Mac Catalyst.
Mark System.IO.FileSystemWatcher as unsupported on iOS/tvOS and throw PNSE.
Switch PhysicalFileProvider to use active polling instead, like we do for Browser.
Addresses https://github.com/dotnet/runtime/issues/57931
Co-authored-by: Alexander Köplinger <alex.koeplinger@outlook.com>
github-actions[bot] [Thu, 26 Aug 2021 18:21:57 +0000 (11:21 -0700)]
[release/6.0] Surface allocations per thread (#58123)
* Initial interface for GetBytesAllocated API
* Fix signature to be 64 bit
Co-authored-by: Tom McDonald <tommcdon@microsoft.com>
Co-authored-by: Juan Sebastian Hoyos Ayala <juhoyosa@microsoft.com>
github-actions[bot] [Thu, 26 Aug 2021 17:34:56 +0000 (10:34 -0700)]
X86 Debug Stack offsets are encoded divided by 4 - Fix the encoding (#58094)
Fixes #57951
Co-authored-by: David Wrighton <davidwr@microsoft.com>
github-actions[bot] [Thu, 26 Aug 2021 17:34:43 +0000 (10:34 -0700)]
[release/6.0-rc1] [wasm] spread WS based timers over next 6 minutes to prevent heavy throttling (#58160)
* spread WS based timers over next 6 minutes to prevent heavy throttling
* wip
* wip
* fix
* better assert description
* exclude test from CI, because helix is headless
* feedback
* more
Co-authored-by: Pavel Savara <pavelsavara@microsoft.com>
dotnet-maestro[bot] [Thu, 26 Aug 2021 16:31:16 +0000 (09:31 -0700)]
[release/6.0-rc1] Update dependencies from mono/linker (#58043)
* Update dependencies from https://github.com/mono/linker build
20210824.2
Microsoft.NET.ILLink.Tasks
From Version 6.0.100-preview.6.21419.1 -> To Version 6.0.100-preview.6.21424.2
* Update dependencies from https://github.com/mono/linker build
20210824.3
Microsoft.NET.ILLink.Tasks
From Version 6.0.100-preview.6.21419.1 -> To Version 6.0.100-preview.6.21424.3
* Update dependencies from https://github.com/mono/linker build
20210824.4
Microsoft.NET.ILLink.Tasks
From Version 6.0.100-preview.6.21424.3 -> To Version 6.0.100-preview.6.21424.4
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
Drew Scoggins [Thu, 26 Aug 2021 16:20:03 +0000 (09:20 -0700)]
Fix trigger paths for perf_slow.yml (#58079)
github-actions[bot] [Thu, 26 Aug 2021 14:03:33 +0000 (08:03 -0600)]
Don't consider classes that do not have any attributes or base classes (#58004)
Viktor Hofer [Thu, 26 Aug 2021 10:32:08 +0000 (12:32 +0200)]
Merge pull request #58034 from dotnet-maestro-bot/merge/release/6.0-rc1-to-release/6.0
[automated] Merge branch 'release/6.0-rc1' => 'release/6.0'
dotnet-maestro[bot] [Thu, 26 Aug 2021 10:27:41 +0000 (12:27 +0200)]
Update dependencies from https://github.com/dotnet/icu build
20210825.1 (#58138)
Microsoft.NETCore.Runtime.ICU.Transport
From Version 6.0.0-rc.2.21419.2 -> To Version 6.0.0-rc.2.21425.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
dotnet-maestro[bot] [Thu, 26 Aug 2021 10:25:14 +0000 (12:25 +0200)]
Update dependencies from https://github.com/dotnet/emsdk build
20210825.6 (#58149)
Microsoft.NET.Workload.Emscripten.Manifest-6.0.100
From Version 6.0.0-rc.2.21423.1 -> To Version 6.0.0-rc.2.21425.6
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
github-actions[bot] [Thu, 26 Aug 2021 04:35:10 +0000 (22:35 -0600)]
[release/6.0] Improve tracing of HTTP/2 PINGs (#57930)
* more HTTP/2 PING logging
* test unexpected PING response
Co-authored-by: Anton Firszov <antonfir@gmail.com>
github-actions[bot] [Wed, 25 Aug 2021 18:05:49 +0000 (12:05 -0600)]
Fix nullability bug (#58102)
Co-authored-by: Buyaa Namnan <bunamnan@microsoft.com>
Maryam Ariyan [Wed, 25 Aug 2021 18:05:16 +0000 (14:05 -0400)]
Allow configuration binder to bind single elements to array (#58060)
* Allow ConfigBinder to bind arrays to Singular elements (#57204)
* Apply feedback from PR #57204 (#57872)
Co-authored-by: vidommet <80355385+vidommet@users.noreply.github.com>
github-actions[bot] [Wed, 25 Aug 2021 17:38:03 +0000 (10:38 -0700)]
Support reference type custom converters (#57954)
Co-authored-by: Steve Harter <steveharter@users.noreply.github.com>
github-actions[bot] [Wed, 25 Aug 2021 17:37:52 +0000 (10:37 -0700)]
Fixing DebuggerDisplayAttribute when using utf16 characters. Fixes #58046 (#58087)
Co-authored-by: Thays <thaystg@gmail.com>
Drew Scoggins [Wed, 25 Aug 2021 16:20:09 +0000 (09:20 -0700)]
Fix trigger paths for perf_slow.yml (#58077)
github-actions[bot] [Wed, 25 Aug 2021 15:46:30 +0000 (08:46 -0700)]
[release/6.0-rc1] Support special characters in [JsonPropertyName] (#58075)
* Support special characters in [JsonPropertyName]
* Make gen'd property name readonly; other misc
Co-authored-by: Steve Harter <steveharter@users.noreply.github.com>
github-actions[bot] [Wed, 25 Aug 2021 15:45:46 +0000 (08:45 -0700)]
[release/6.0-rc1] Add event to RuntimeEventSource for AppContext switches (#57847)
* Add event to RuntimeEventSource for AppContext switches
Fixes https://github.com/dotnet/runtime/issues/56142
* Respond to PR comments
* Add preliminary tests
* Respond to PR comments
* Add keyword
* Fix tests
* Remove AppContext EventSource support on browser
* forgot using
* Fix error reporting, add comments
* Respond to PR comments
* Refactor tests
* Fix case where s_switches is null
* Fix bug
* Print more info for test failure
* Typo
* Fix lab failure
* Respond to PR comments
* Respond to PR comments
* Typo
* Respond to PR comments
* Skip RuntimeEventSource tests on wasm and android (#57890)
* Skip RuntimeEventSource tests on wasm and android
* Skip tests without using issues.targets
* Disable test for mono
(cherry picked from commit
454ac571fe489ab818c7727f11eee71d521c4366)
Co-authored-by: Andy Gocke <angocke@microsoft.com>
github-actions[bot] [Wed, 25 Aug 2021 15:26:12 +0000 (08:26 -0700)]
[release/6.0] Fix enum memory code paths (#58076)
* Fix enum memory code paths
* Fix wks enumeration
Co-authored-by: Andrew Au <andrewau@microsoft.com>
github-actions[bot] [Wed, 25 Aug 2021 02:07:14 +0000 (22:07 -0400)]
Fix Enum.Parse's parse failure exception to include value in error message (#57975)
Co-authored-by: Stephen Toub <stoub@microsoft.com>
github-actions[bot] [Tue, 24 Aug 2021 22:43:22 +0000 (16:43 -0600)]
Fix nullable annotations for AssociatedMetadataTypeTypeDescriptionProvider (#57979)
Co-authored-by: Stephen Toub <stoub@microsoft.com>
github-actions[bot] [Tue, 24 Aug 2021 20:50:27 +0000 (13:50 -0700)]
Additional statistics when a ServiceProvider is created (#58030)
* Number of open generics
* Number of closed generics
fix #52364
Co-authored-by: Allan Targino <13934447+allantargino@users.noreply.github.com>
github-actions[bot] [Tue, 24 Aug 2021 20:37:20 +0000 (16:37 -0400)]
[release/6.0-rc1] [wasm][debugger] Fixing assert while debugging. (#58032)
When trying to evaluate DebuggerProxyAttribute of a generic type <T, K>, it was working only for one parameter .
Fixes #58021
Co-authored-by: Thays <thaystg@gmail.com>
github-actions[bot] [Tue, 24 Aug 2021 19:27:13 +0000 (15:27 -0400)]
[interp] Use existing InterpMethod if allocation and lookup race (#57985)
If two threads both want to get an InterpMethod for the same MonoMethod, and
they both see null from the first hash table lookup, make sure that whichever
one comes into the jit_mm lock second re-uses the previously inserted
InterpMethod, instead of its own version.
Without this change, racing threads will overwrite
MonoJitInfo:seq_points (in mono_interp_transform_method) which sometimes leads
to deallocating the same sequence points multiple times.
Fixes https://github.com/dotnet/runtime/issues/57812
Co-authored-by: Aleksey Kliger <alklig@microsoft.com>
github-actions[bot] [Tue, 24 Aug 2021 19:25:36 +0000 (15:25 -0400)]
[wasm][debugger] Proxy but don't process events from worker sessions (#57990)
Backport of #57974
Should Fix #57949
Co-authored-by: Larry Ewing <lewing@microsoft.com>
Ankit Jain [Tue, 24 Aug 2021 19:23:45 +0000 (19:23 +0000)]
[release/6.0-rc1] MonoAOTCompiler: Check for proxy file's target only when the cache is being used. (#57867)
Backport of #57865
Fixes https://github.com/dotnet/runtime/issues/57800 .
github-actions[bot] [Tue, 24 Aug 2021 17:46:44 +0000 (19:46 +0200)]
Fix loading app local ICU (#57992)
Co-authored-by: Tarek Mahmoud Sayed <tarekms@microsoft.com>
github-actions[bot] [Tue, 24 Aug 2021 17:06:53 +0000 (11:06 -0600)]
[release/6.0] Move GreaterThan2GBFile_SendsAllBytes to a non-parallel test collection (#58002)
* Move GreaterThan2GBFile_SendsAllBytes to a non-parallel test collection
* Update SendFile.cs
Co-authored-by: Anton Firszov <antonfir@gmail.com>
Co-authored-by: Anton Firszov <Anton.Firszov@microsoft.com>
github-actions[bot] [Tue, 24 Aug 2021 17:02:08 +0000 (11:02 -0600)]
[release/6.0-rc1] [HTTP/3] Abort response stream on dispose if content not finished (#57999)
* Sends abort read/write if H/3 stream is disposed before respective contents are finsihed
* Minor tweaks in abort conditions
* Prevent reverting SendState from Aborted/ConnectionClosed back to sending state within Send* methods.
Co-authored-by: ManickaP <mapichov@microsoft.com>
Co-authored-by: Marie Píchová <11718369+ManickaP@users.noreply.github.com>
github-actions[bot] [Tue, 24 Aug 2021 16:58:49 +0000 (10:58 -0600)]
[release/6.0-rc1] Improve tracing of HTTP/2 PINGs (#57998)
* more HTTP/2 PING logging
* test unexpected PING response
Co-authored-by: Anton Firszov <antonfir@gmail.com>
github-actions[bot] [Tue, 24 Aug 2021 16:17:36 +0000 (10:17 -0600)]
[release/6.0-rc1] Fixed StreamPipeReader.CopyToAsync (#57966)
* Fixed StreamPipeReader.CopyToAsync - Take the segment index into account when copying buffered data. This handles the case where ReadAsync has consumed a partial segment and then the same PipeReader instance is used to copy to a Stream and PipeWriter. - Added tests
* Always slice
Co-authored-by: David Fowler <davidfowl@gmail.com>
Viktor Hofer [Tue, 24 Aug 2021 10:16:56 +0000 (12:16 +0200)]
Merge pull request #57969 from dotnet-maestro-bot/merge/release/6.0-rc1-to-release/6.0
[automated] Merge branch 'release/6.0-rc1' => 'release/6.0'
Steve Harter [Tue, 24 Aug 2021 06:42:48 +0000 (01:42 -0500)]
Disable S.T.J.Serialization.Tests.ConstructorTests.PathForChildDictionaryFails (#57834)
github-actions[bot] [Tue, 24 Aug 2021 06:35:54 +0000 (08:35 +0200)]
[release/6.0-rc1] Align DCJS with 4.8 implementation. (#57883)
* Align DCJS with 4.8 version. This work addresses #55270.
* Close() nits.
* Remove some extraneous trimmer attributes.
* Another trimmer nit.
Co-authored-by: Steve Molloy <smolloy@microsoft.com>
dotnet-maestro[bot] [Tue, 24 Aug 2021 06:34:39 +0000 (08:34 +0200)]
[release/6.0] Update dependencies from dotnet/emsdk dotnet/runtime-assets (#57925)
* Update dependencies from https://github.com/dotnet/emsdk build
20210823.1
Microsoft.NET.Workload.Emscripten.Manifest-6.0.100
From Version 6.0.0-rc.1.21419.1 -> To Version 6.0.0-rc.2.21423.1
* Update dependencies from https://github.com/dotnet/runtime-assets build
20210823.1
Microsoft.DotNet.CilStrip.Sources , System.ComponentModel.TypeConverter.TestData , System.Drawing.Common.TestData , System.IO.Compression.TestData , System.IO.Packaging.TestData , System.Net.TestData , System.Private.Runtime.UnicodeData , System.Runtime.Numerics.TestData , System.Runtime.TimeZoneData , System.Security.Cryptography.X509Certificates.TestData , System.Windows.Extensions.TestData
From Version 6.0.0-beta.21416.1 -> To Version 6.0.0-beta.21423.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
github-actions[bot] [Mon, 23 Aug 2021 22:55:48 +0000 (15:55 -0700)]
[release/6.0] Fix stress issues around multiple threads throwing the same exceptions (#57959)
* Fix stress issues around multiple threads throwing the same exceptions - The watson codebase manipulates the state of the following fields on Exception in a lock-free manner without locks if there are multiple threads throwing the same exception - _stackTrace - _stackTraceString - _remoteStackTraceString - _watsonBuckets - _ipForWatsonBuckets - The designed behavior is that these apis should "mostly" be correct, but as they are only used for fatal shutdown scenarios, exact correctness is not required for correct program execution - However, there are some race conditions that have been seen recently in testing 1. In some circumstances, the value will be explicitly read from multiple times, where the first read is to check for NULL, and then a second read is to read the actual value and use it in some way. In the presence of a race which sets the value to NULL, the runtime can crash. To fix this, the code is refactored in cases which could lead to crashes with a single read, and carrying around the read value to where it needs to go. 2. Since the C++ memory model generally allows a single read written in C++ to be converted into multiple reads if the compiler can prove that the read does not cross a lock/memory barrier, it is possible for the C++ compiler to inject multiple reads where the logic naturally only has 1. The fix for this is to utlilize the VolatileLoadWithoutBarrier api to specify that a read should happen once in cases where it might cause a problem.
Finally, the test45929 was tended to fail in GC stress as it would take a very long time to run under GC stress or on some hardware. Adjust it so that it shuts down after about 2.5 minutes.
- Do this instead of disabling running under gcstress as there is evidence that there may have been bugs seen during runs under gcstress.
Fixes #46803
* Rename as per suggestion
Co-authored-by: David Wrighton <davidwr@microsoft.com>
github-actions[bot] [Mon, 23 Aug 2021 19:57:39 +0000 (15:57 -0400)]
[release/6.0-rc1] Enable SocketHttpHandler to decompress zlib or deflate (#57940)
* Enable SocketHttpHandler to decompress zlib or deflate
Some servers incorrectly implement the deflate content-coding with the raw deflate algorithm rather than with deflate wrapped with a zlib header/footer. Auto-detect whether to use ZLibStream or DeflateStream in order to accomodate both kinds of responses.
* Fix test build for WinHttpHandler on .NET Framework
* Apply suggestions from code review
* Add decompression test for empty response body
* Add decompression tests for multiple source content lengths
Co-authored-by: Stephen Toub <stoub@microsoft.com>
Viktor Hofer [Mon, 23 Aug 2021 15:33:32 +0000 (17:33 +0200)]
Merge pull request #57854 from dotnet-maestro-bot/merge/release/6.0-rc1-to-release/6.0
[automated] Merge branch 'release/6.0-rc1' => 'release/6.0'
Viktor Hofer [Mon, 23 Aug 2021 15:11:01 +0000 (17:11 +0200)]
[release/6.0] Don't regress SkipLocalsInit optimization on < 6.0 .NETCoreApp assets (#57868)
* Don't regress SkipLocalsInit optimization on net5.0 assets
netcoreapp3.1 and net5.0 assets which are part of the Microsoft.NETCore.App shared framework and ship inside a package need to keep the SkipLocalsInit optimization to avoid regressing perf. This would happen when referencing one of the 6.0 packages but consuming either the netcoreapp3.1 or net5.0 asset in it. The higher assembly version of the netcoreapp3.1/net5.0 asset would win over the same asset in the shared framework and without this fix, the SkipLocalsInit optimization would be lost.
Contributes to https://github.com/dotnet/runtime/issues/54964
github-actions[bot] [Mon, 23 Aug 2021 15:09:17 +0000 (09:09 -0600)]
[release/6.0] Fix QUIC ConnectionState NRE in HandleEventConnectionClose (#57742)
* Fix QUIC ConnectionState NRE in HandleEventConnectionClose
* Remove unnecessary Dispose
Co-authored-by: Natalia Kondratyeva <knatalia@microsoft.com>
Viktor Hofer [Mon, 23 Aug 2021 13:32:15 +0000 (15:32 +0200)]
Merge branch 'release/6.0' into merge/release/6.0-rc1-to-release/6.0
Omair Majid [Mon, 23 Aug 2021 13:26:54 +0000 (09:26 -0400)]
Add Fedora 36 to the RID graph (#57833)
Backport of #57832
Fedora 36 is under development:
$ podman run -it registry.fedoraproject.org/fedora:rawhide /bin/cat /etc/os-release
NAME="Fedora Linux"
VERSION="36 (Container Image Prerelease)"
ID=fedora
VERSION_ID=36
VERSION_CODENAME=""
PLATFORM_ID="platform:f36"
PRETTY_NAME="Fedora Linux 36 (Container Image Prerelease)"
ANSI_COLOR="0;38;2;60;110;180"
LOGO=fedora-logo-icon
CPE_NAME="cpe:/o:fedoraproject:fedora:36"
HOME_URL="https://fedoraproject.org/"
DOCUMENTATION_URL="https://docs.fedoraproject.org/en-US/fedora/rawhide/system-administrators-guide/"
SUPPORT_URL="https://fedoraproject.org/wiki/Communicating_and_getting_help"
BUG_REPORT_URL="https://bugzilla.redhat.com/"
REDHAT_BUGZILLA_PRODUCT="Fedora"
REDHAT_BUGZILLA_PRODUCT_VERSION=rawhide
REDHAT_SUPPORT_PRODUCT="Fedora"
REDHAT_SUPPORT_PRODUCT_VERSION=rawhide
PRIVACY_POLICY_URL="https://fedoraproject.org/wiki/Legal:PrivacyPolicy"
VARIANT="Container Image"
VARIANT_ID=container
github-actions[bot] [Sat, 21 Aug 2021 12:04:29 +0000 (08:04 -0400)]
Disable TaskDropsExecutionContextUponCompletion test (#57864)
Co-authored-by: Stephen Toub <stoub@microsoft.com>
Anirudh Agnihotry [Sat, 21 Aug 2021 02:34:59 +0000 (19:34 -0700)]
update to compaitibility package (#57783)
Drew Scoggins [Fri, 20 Aug 2021 23:11:46 +0000 (16:11 -0700)]
Remove run trigger (#57850)
Co-authored-by: dotnet-maestro[bot] <42748379+dotnet-maestro[bot]@users.noreply.github.com>
Drew Scoggins [Fri, 20 Aug 2021 23:11:27 +0000 (16:11 -0700)]
Move to 6.0 only for release runs (#57848)
github-actions[bot] [Fri, 20 Aug 2021 22:16:32 +0000 (15:16 -0700)]
[release/6.0] Fix Culture creation regression when using invalid names on Windows (#57853)
* Fix Culture creation regression when using invalid names on Windows
* Address the feedback
Co-authored-by: Tarek Mahmoud Sayed <tarekms@microsoft.com>
github-actions[bot] [Fri, 20 Aug 2021 22:15:21 +0000 (15:15 -0700)]
Update toolset MicrosoftNETCoreApp version This package no longer exists. Replace with runtime package version and appropriate property. (#57829)
Co-authored-by: Matt Mitchell <mmitche@microsoft.com>
github-actions[bot] [Fri, 20 Aug 2021 20:35:14 +0000 (16:35 -0400)]
Re-disable AsyncMethodsDropsStateMachineAndExecutionContextUponCompletion test (#57761)
Co-authored-by: Stephen Toub <stoub@microsoft.com>
github-actions[bot] [Fri, 20 Aug 2021 20:22:03 +0000 (13:22 -0700)]
[release/6.0-rc1] [mono][debugger] Fix watch of local variable values (#57787)
* Fix xamarin-android 6161
* Fixing leak.
* Adding wasm debugger test. Fixing using protocol version.
* only get locals in older protocol versions.
Co-authored-by: Thays <thaystg@gmail.com>
github-actions[bot] [Fri, 20 Aug 2021 20:21:55 +0000 (13:21 -0700)]
[release/6.0-rc1] [hot_reload] Don't look at delta method table rows (#57799)
* Add test case
Call a method for the first time after an update has been applied to it.
This will check that the interpreter or JIT does not have to rely on cached
information from the baseline (about the method signature, for example) and
that it can compute it from the delta.
* [hot_reload] Don't look at delta method table rows
The issue is that the ParamList column in EnC deltas is a "suppressed column"
that has the value 0. So when a method is updated if we use the value
directly, we will break, for example - `mono_metadata_get_param_attrs` which
expects a non-zero index in that column.
CoreCLR solves this by having a set of suppressed columns that are never
updated by deltas. (CoreCLR's model is to directly mutate the tables of the
baseline image). In Mono we can eventually do the same thing by writing the
value from the previous generation into the current delta's row. But right now
since we don't allow parameter modifications, and the only column on a Method
table that we allow to be modified is the RVA - which we look up specially - we
can just always return the baseline image row for the method table.
Fixes https://github.com/dotnet/runtime/issues/57643
Co-authored-by: Aleksey Kliger <alklig@microsoft.com>
github-actions[bot] [Fri, 20 Aug 2021 17:53:29 +0000 (10:53 -0700)]
Update toolset MicrosoftNETCoreApp version This package no longer exists. Replace with runtime package version and appropriate property. (#57828)
Co-authored-by: Matt Mitchell <mmitche@microsoft.com>
Viktor Hofer [Fri, 20 Aug 2021 11:03:09 +0000 (13:03 +0200)]
Merge pull request #57740 from dotnet-maestro-bot/merge/release/6.0-rc1-to-release/6.0
[automated] Merge branch 'release/6.0-rc1' => 'release/6.0'
Viktor Hofer [Fri, 20 Aug 2021 08:36:39 +0000 (10:36 +0200)]
Merge branch 'release/6.0' into merge/release/6.0-rc1-to-release/6.0
dotnet-maestro[bot] [Fri, 20 Aug 2021 08:29:28 +0000 (10:29 +0200)]
Update dependencies from https://github.com/mono/linker build
20210819.1 (#57765)
Microsoft.NET.ILLink.Tasks
From Version 6.0.100-preview.6.21418.3 -> To Version 6.0.100-preview.6.21419.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
dotnet-maestro[bot] [Fri, 20 Aug 2021 08:23:11 +0000 (10:23 +0200)]
Update dependencies from https://github.com/dotnet/icu build
20210819.2 (#57764)
Microsoft.NETCore.Runtime.ICU.Transport
From Version 6.0.0-rc.1.21416.1 -> To Version 6.0.0-rc.2.21419.2
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
dotnet-maestro[bot] [Fri, 20 Aug 2021 08:21:26 +0000 (10:21 +0200)]
Update dependencies from https://github.com/dotnet/icu build
20210819.1 (#57763)
Microsoft.NETCore.Runtime.ICU.Transport
From Version 6.0.0-rc.1.21416.1 -> To Version 6.0.0-rc.1.21419.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
dotnet-maestro[bot] [Fri, 20 Aug 2021 08:17:35 +0000 (10:17 +0200)]
Update dependencies from https://github.com/mono/linker build
20210819.1 (#57777)
Microsoft.NET.ILLink.Tasks
From Version 6.0.100-preview.6.21416.1 -> To Version 6.0.100-preview.6.21419.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
github-actions[bot] [Fri, 20 Aug 2021 07:08:46 +0000 (09:08 +0200)]
Pack windows implementation assemblies in windowsdesktop transport package (#57796)
Co-authored-by: Eric StJohn <ericstj@microsoft.com>
github-actions[bot] [Thu, 19 Aug 2021 23:26:51 +0000 (19:26 -0400)]
Re-disable AsyncMethodsDropsStateMachineAndExecutionContextUponCompletion test (#57762)
Co-authored-by: Stephen Toub <stoub@microsoft.com>
dotnet-maestro[bot] [Thu, 19 Aug 2021 22:52:04 +0000 (00:52 +0200)]
Update dependencies from https://github.com/dotnet/emsdk build
20210819.1 (#57759)
Microsoft.NET.Workload.Emscripten.Manifest-6.0.100
From Version 6.0.0-rc.1.21416.1 -> To Version 6.0.0-rc.1.21419.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
github-actions[bot] [Thu, 19 Aug 2021 22:50:46 +0000 (00:50 +0200)]
Fix Microsoft.NETCore.Platforms builds on Unix (#57757)
The casing of the SDK imported via the Sdk attribute was wrong which lead to:
Microsoft.NETCore.Platforms.csproj : error MSB4236: The SDK 'Microsoft.NET.SDK' specified could not be found.
Co-authored-by: Viktor Hofer <viktor.hofer@microsoft.com>
dotnet-maestro[bot] [Thu, 19 Aug 2021 22:37:56 +0000 (00:37 +0200)]
[release/6.0-rc1] Update dependencies from dotnet/arcade (#57628)
* Update dependencies from https://github.com/dotnet/arcade build
20210817.1
Microsoft.DotNet.XUnitExtensions , Microsoft.DotNet.VersionTools.Tasks , Microsoft.DotNet.Build.Tasks.Workloads , Microsoft.DotNet.Build.Tasks.TargetFramework.Sdk , Microsoft.DotNet.Build.Tasks.Packaging , Microsoft.DotNet.Build.Tasks.Installers , Microsoft.DotNet.Build.Tasks.Feed , Microsoft.DotNet.Build.Tasks.Archives , Microsoft.DotNet.Arcade.Sdk , Microsoft.DotNet.ApiCompat , Microsoft.DotNet.CodeAnalysis , Microsoft.DotNet.XUnitConsoleRunner , Microsoft.DotNet.GenFacades , Microsoft.DotNet.GenAPI , Microsoft.DotNet.RemoteExecutor , Microsoft.DotNet.PackageTesting , Microsoft.DotNet.Helix.Sdk , Microsoft.DotNet.SharedFramework.Sdk
From Version 6.0.0-beta.21413.4 -> To Version 6.0.0-beta.21417.1
* Unpin compiler version
* Update source-index-stage1.yml
* Update dependencies from https://github.com/dotnet/arcade build
20210818.12
Microsoft.DotNet.XUnitExtensions , Microsoft.DotNet.VersionTools.Tasks , Microsoft.DotNet.Build.Tasks.Workloads , Microsoft.DotNet.Build.Tasks.TargetFramework.Sdk , Microsoft.DotNet.Build.Tasks.Packaging , Microsoft.DotNet.Build.Tasks.Installers , Microsoft.DotNet.Build.Tasks.Feed , Microsoft.DotNet.Build.Tasks.Archives , Microsoft.DotNet.Arcade.Sdk , Microsoft.DotNet.ApiCompat , Microsoft.DotNet.CodeAnalysis , Microsoft.DotNet.XUnitConsoleRunner , Microsoft.DotNet.GenFacades , Microsoft.DotNet.GenAPI , Microsoft.DotNet.RemoteExecutor , Microsoft.DotNet.PackageTesting , Microsoft.DotNet.Helix.Sdk , Microsoft.DotNet.SharedFramework.Sdk
From Version 6.0.0-beta.21413.4 -> To Version 6.0.0-beta.21418.12
* Partial cherry pick from
a169ca9da716a710a576667206b4d8cdf40a7f79
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
Co-authored-by: Viktor Hofer <viktor.hofer@microsoft.com>
github-actions[bot] [Thu, 19 Aug 2021 18:51:37 +0000 (11:51 -0700)]
[mono] Fix crash in common_call_trampoline due to inconsistent rgctx mode (#57677)
* Assume MRGCTX mode if mini_method_is_default_method is true
* Fixes https://github.com/dotnet/runtime/issues/57664
Co-authored-by: Ulrich Weigand <ulrich.weigand@de.ibm.com>
github-actions[bot] [Thu, 19 Aug 2021 17:02:58 +0000 (19:02 +0200)]
[release/6.0] Adding null check to avoid abort when invalid IL is encountered (#57731)
When a callvirt instruction is encountered on a static method, there is
a hard abort/crash. This commit avoids the problem.
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Bill Holmes <bill.holmes@unity3d.com>
dotnet-maestro[bot] [Thu, 19 Aug 2021 16:13:31 +0000 (18:13 +0200)]
Update dependencies from https://github.com/mono/linker build
20210818.3 (#57700)
Microsoft.NET.ILLink.Tasks
From Version 6.0.100-preview.6.21416.1 -> To Version 6.0.100-preview.6.21418.3
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
github-actions[bot] [Thu, 19 Aug 2021 16:09:14 +0000 (09:09 -0700)]
[release/6.0] Fix incorrect VN when folding GT_NEG(GT_MUL(A, C)) (#57686)
* Fix incorrect VN when folding GT_NEG(GT_MUL(A, C))
Fixes #57640
* Fix test name
Co-authored-by: Jakob Botsch Nielsen <jakob.botsch.nielsen@gmail.com>
github-actions[bot] [Thu, 19 Aug 2021 16:06:29 +0000 (18:06 +0200)]
[release/6.0-rc1] Update pinned compiler version (#57730)
* Update pinned compiler version
The version that flows in automatically appears to still be old. We need to fix that, but in the meantime, we're a month out of date on the compiler.
* Suppress CS8969 warnings
* Change several dynamic tests to use typeof(object[])
Co-authored-by: Stephen Toub <stoub@microsoft.com>
github-actions[bot] [Thu, 19 Aug 2021 14:20:47 +0000 (07:20 -0700)]
[release/6.0-rc1] JIT: don't clone loops where init or limit is a cast local (#57690)
* JIT: don't clone loops where init or limit is a cast local
The loop cloner assumes all computations it introduces are compatible
with TYP_INT, so don't allow cloning when the initial or final value
are variables with incompatible types.
Fixes #57535.
* Apply suggestions from code review
Co-authored-by: SingleAccretion <62474226+SingleAccretion@users.noreply.github.com>
Co-authored-by: Andy Ayers <andya@microsoft.com>
Co-authored-by: SingleAccretion <62474226+SingleAccretion@users.noreply.github.com>
github-actions[bot] [Thu, 19 Aug 2021 14:20:23 +0000 (07:20 -0700)]
[release/6.0] JIT: don't clone loops where init or limit is a cast local (#57685)
* JIT: don't clone loops where init or limit is a cast local
The loop cloner assumes all computations it introduces are compatible
with TYP_INT, so don't allow cloning when the initial or final value
are variables with incompatible types.
Fixes #57535.
* Apply suggestions from code review
Co-authored-by: SingleAccretion <62474226+SingleAccretion@users.noreply.github.com>
Co-authored-by: Andy Ayers <andya@microsoft.com>
Co-authored-by: SingleAccretion <62474226+SingleAccretion@users.noreply.github.com>
github-actions[bot] [Thu, 19 Aug 2021 14:13:11 +0000 (16:13 +0200)]
Bump timeout for workloads build job (#57721)
We're seeing it sometimes timing out on official builds.
Co-authored-by: Alexander Köplinger <alex.koeplinger@outlook.com>
github-actions[bot] [Wed, 18 Aug 2021 19:43:58 +0000 (12:43 -0700)]
Throw on invalid payload length in WebSockets (#57635)
Co-authored-by: Natalia Kondratyeva <knatalia@microsoft.com>
github-actions[bot] [Wed, 18 Aug 2021 19:43:47 +0000 (12:43 -0700)]
Throw on invalid payload length in WebSockets (#57636)
Co-authored-by: Natalia Kondratyeva <knatalia@microsoft.com>
github-actions[bot] [Wed, 18 Aug 2021 19:37:06 +0000 (15:37 -0400)]
Fix Debug.Assert use of string interpolation (#57667)
Co-authored-by: Stephen Toub <stoub@microsoft.com>
github-actions[bot] [Wed, 18 Aug 2021 19:36:43 +0000 (15:36 -0400)]
Fix Debug.Assert use of string interpolation (#57668)
Co-authored-by: Stephen Toub <stoub@microsoft.com>
Anipik [Tue, 17 Aug 2021 21:33:53 +0000 (14:33 -0700)]
update branding to rc2
Larry Ewing [Tue, 17 Aug 2021 21:28:09 +0000 (16:28 -0500)]
[wasm] Enable tests blocked by IL2105 (#57457)
* Disable ReflectionCachesUpdateHandler_CachesCleared with aggressive trimming
* Enable more tests stopped by 2105
* Create tests.mobile.targets
Suppress IL2025
* Remove comment enabling trim warnings
* Mark more active issues
Adam Sitnik [Tue, 17 Aug 2021 20:48:02 +0000 (22:48 +0200)]
don't try to test module path if we can't load the module (#57590)
Tarek Mahmoud Sayed [Tue, 17 Aug 2021 20:41:34 +0000 (13:41 -0700)]
Fix the string search behavior when using ICU (#57078)
Mike McLaughlin [Tue, 17 Aug 2021 20:02:14 +0000 (13:02 -0700)]
Fix crashreport for stack overflow (#57428)
* Fix crashreport for stack overflow
Issue: https://github.com/dotnet/runtime/issues/57032
The stack overflow managed exception wasn't been set/written out.
Changed the "unmanaged_frames" value to "stack_frames" because it includes both native and managed frames.
Aggregated the repeated stack frames adding a "repeated"/repeated_frames value/array for the time of times the sequence was repeated.
Looks like this:
{
"repeated" : "0x1542",
"repeated_frames" : [
{
"is_managed" : "true",
"module_address" : "0x10e402000",
"stack_pointer" : "0x7000045ce020",
"native_address" : "0x11b9ee8c9",
"native_offset" : "0x29",
"token" : "0x600006f",
"il_offset" : "0x0",
"method_name" : "Macson.Client.Diagnostics.CrashyClass.Foo2()",
"timestamp" : "0xa8561820",
"sizeofimage" : "0xe000",
"filename" : "Macson.Client.dll",
"guid" : "
49cd869a682942bc95c0c34ca206c61d"
},
{
"is_managed" : "true",
"module_address" : "0x10e402000",
"stack_pointer" : "0x7000045ce040",
"native_address" : "0x11b9ee879",
"native_offset" : "0x29",
"token" : "0x6000070",
"il_offset" : "0x0",
"method_name" : "Macson.Client.Diagnostics.CrashyClass.Foo1()",
...
},
]
}
* Update createdump doc
* Fix Windows triage dump flags
* Code review feedback
David Wrighton [Tue, 17 Aug 2021 19:42:07 +0000 (12:42 -0700)]
Add --make-repro-path option to crossgen2 (#57543)
- This is used to create repro packages for customer discovered issues with CrossGen2
- Customers will use this by setting the PublishCrossGen2ExtraArgs property to something like `--make-repro-path:c:\repro\crossgen2repro`
- Then the build will run, and produce zip files in the specified directory, one for each crossgen2 run that occurs during that build.
- Hopefully, then it is straightforward to package the failure up and send it in.
In addition, this tech can be used to transfer a full set of repro details from a Unix to Windows machine for easier debugging.
dotnet-maestro[bot] [Tue, 17 Aug 2021 19:37:43 +0000 (12:37 -0700)]
Update dependencies from https://github.com/dotnet/msquic build
20210817.1 (#57581)
System.Net.MsQuic.Transport
From Version 6.0.0-preview.7.21416.1 -> To Version 6.0.0-preview.7.21417.1
Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
Feng Gao [Tue, 17 Aug 2021 19:35:04 +0000 (03:35 +0800)]
The FilterLoggingBuilderExtensions public API's (#57485)
document doesn't reflect the acutal type. Change
it from the ILoggingBuilder to LoggerFilterOptions.
Fix #57482
Geoff Kizer [Tue, 17 Aug 2021 19:31:26 +0000 (12:31 -0700)]
don't dispose client control stream before closing connection (#57223)
* don't dispose client control stream before closing connection
Co-authored-by: Geoffrey Kizer <geoffrek@windows.microsoft.com>