platform/upstream/dotnet/runtime.git
3 years agoClient side logging for HTTP stress. (#41444)
Marie Píchová [Fri, 28 Aug 2020 13:31:29 +0000 (15:31 +0200)]
Client side logging for HTTP stress. (#41444)

3 years agoFixes Windows docker debug prints. (#41443)
Marie Píchová [Fri, 28 Aug 2020 11:56:31 +0000 (13:56 +0200)]
Fixes Windows docker debug prints. (#41443)

3 years agoBump the local emscripten version to 2.0.1. (#41504)
Zoltan Varga [Fri, 28 Aug 2020 11:53:08 +0000 (07:53 -0400)]
Bump the local emscripten version to 2.0.1. (#41504)

3 years agomono.proj: properly pass -mmacosx-version-min to CFLAGS for OSX (#41433)
Alexander Köplinger [Fri, 28 Aug 2020 11:51:20 +0000 (13:51 +0200)]
mono.proj: properly pass -mmacosx-version-min to CFLAGS for OSX (#41433)

Noticed we were missing this while looking at another PR.

3 years agoPort nullability annotations from System.Private.Xml.Linq to contracts (#41086)
David Cantú [Fri, 28 Aug 2020 10:15:15 +0000 (03:15 -0700)]
Port nullability annotations from System.Private.Xml.Linq to contracts (#41086)

* Enable nullability on System.Xml.XPath.XDocument src

* Port nullability annotations to System.Xml.XPath.XDocument

* Port nullability annotations to System.Xml.XDocument

* Add ? to XmlAttribute argument in int? explicit operator

3 years agoPort nullability annotations to refs XmlDocument and XmlSerializer (#41474)
David Cantú [Fri, 28 Aug 2020 09:58:46 +0000 (02:58 -0700)]
Port nullability annotations to refs XmlDocument and XmlSerializer (#41474)

* Port nullability annotations to refs XmlDocument and XmlSerializer

* Fix new System.Data.Common nullability related errors

* Switch nullability of parameter in SoapElementAttribute ctor

3 years ago[wasm][debugger] Make sure `System.Private.CoreLib.dll` is in sync with (#41469)
Ankit Jain [Fri, 28 Aug 2020 08:08:00 +0000 (04:08 -0400)]
[wasm][debugger] Make sure `System.Private.CoreLib.dll` is in sync with (#41469)

.. it's pdb. Running debugger-tests, I saw lot of messages like:

`CWL: : /Users/radical/dev/runtime/src/mono/mono/metadata/debug-mono-ppdb.c:230 <disabled>`

.. which is trying to print:
`CWL: Symbol file data-0x1c38008 doesn't match image System.Private.CoreLib.dll`

And indeed the dll is out of sync with it's pdb. We need to copy the pdb
too.

3 years agoSwitch Markup property to XmlNode?[]? to reflect it can contain null elements (#41488)
David Cantú [Fri, 28 Aug 2020 06:47:24 +0000 (23:47 -0700)]
Switch Markup property to XmlNode?[]? to reflect it can contain null elements (#41488)

* Switch Markup property to XmlNode?[]? to reflect it can contain null elements

* Update ref

3 years agoRemove if-def from JSON ref file previously used to support linker attributes (#41484)
Layomi Akinrinade [Fri, 28 Aug 2020 01:14:55 +0000 (18:14 -0700)]
Remove if-def from JSON ref file previously used to support linker attributes (#41484)

* Remove if-def from JSON ref file previously used to support linker attributes

* Run GenerateReferenceSource target on ref project

3 years agoimprove InitializeCurrentThread (#41440)
Egor Bogatov [Fri, 28 Aug 2020 00:26:06 +0000 (03:26 +0300)]
improve InitializeCurrentThread (#41440)

3 years agoFix perf token (#41345)
Olivia Chen [Fri, 28 Aug 2020 00:22:43 +0000 (17:22 -0700)]
Fix perf token (#41345)

* remove semicolon from upload token

* will revert - test private commands

* remove condition

* add debug code

* add dump task

* comment out internal param

* rename helixprecommands to sharedhelixprecommands

* update and revert for check-in

3 years agoSwitch text param to nullable in WriteProcessingInstructionAsync (#41481)
David Cantú [Thu, 27 Aug 2020 23:54:03 +0000 (16:54 -0700)]
Switch text param to nullable in WriteProcessingInstructionAsync (#41481)

3 years agoClean up changes in #40914 (#41427)
Layomi Akinrinade [Thu, 27 Aug 2020 22:55:23 +0000 (15:55 -0700)]
Clean up changes in #40914 (#41427)

* Fixup JSON equality checks in polymorphic converter tests

* Limit deserialization value validation to custom _polymorphic_ converters

3 years agoUpdate SYSLIB0012 obsoletion messages to be clear and consistent (#41467)
Jeff Handley [Thu, 27 Aug 2020 22:25:49 +0000 (15:25 -0700)]
Update SYSLIB0012 obsoletion messages to be clear and consistent (#41467)

3 years agoadd tracing to Decryp to complement tracing in Encrypt (#40998)
Tomas Weinfurt [Thu, 27 Aug 2020 20:17:14 +0000 (13:17 -0700)]
add tracing to Decryp to complement tracing in Encrypt (#40998)

* add tracing to Decryp to complement tracing in Encrypt

* feedback from review

* revert encrypt

3 years agoPort nullability annotations to System.Xml.ReaderWriter contract (#41083)
David Cantú [Thu, 27 Aug 2020 20:03:46 +0000 (13:03 -0700)]
Port nullability annotations to System.Xml.ReaderWriter contract (#41083)

* Port nullability annotations to System.Xml.ReaderWriter contract assembly

* Port annotations of recently updated members in Xml/Serialization

* Fix anontations on XmlElement discovered while updating System.Data.Common Xml related annotations

* Fix Xml related annotations on System.Data.Common

* address feedback

Co-authored-by: Krzysztof Wicher <kwicher@microsoft.com>
3 years agoFix SPMI to handle replays of BBINSTR jit method contexts (#41386)
Andy Ayers [Thu, 27 Aug 2020 19:26:33 +0000 (12:26 -0700)]
Fix SPMI to handle replays of BBINSTR jit method contexts (#41386)

Move the handling of allocMethodBlockCounts to the method context.
While this data is both an input and an output, we're more interested
in the input side.

We could also treat it as an output, if we say wanted to verify that
the replay jit wrote the same sequence of IL offsets into the BlockCount
records, but that doesn't seem crucial as changes here would also lead
to code diffs.

Fix the code that checks the AddressMap for reloc hints so it doesn't
fail if the exact lookup fails, but instead falls back to a search.
This is needed because the base of the replay count buffer is recorded
as the map key, but the instrumentation probes in jitted code refer
to offsets from this value.

Fixes #37270.

3 years agoMake minimal OSX version consistent between build-native.sh and configurecompiler...
Alexander Köplinger [Thu, 27 Aug 2020 18:38:25 +0000 (20:38 +0200)]
Make minimal OSX version consistent between build-native.sh and configurecompiler.cmake (#41435)

The latter still specified 10.12 but .NET Core 3+ actually only supports macOS 10.13 or later.

3 years agoFix null check in S.Diagnostics.Contract regressed by nullability annotations (#41382)
Krzysztof Wicher [Thu, 27 Aug 2020 18:00:42 +0000 (20:00 +0200)]
Fix null check in S.Diagnostics.Contract regressed by nullability annotations (#41382)

* Fix null check in S.Diagnostics.Contract regressed by nullability annotations

* fix product per Jan's recommendation

3 years agoConsole.Unix: fix window size not always being invalidated (#41317)
Tom Deseyn [Thu, 27 Aug 2020 17:53:49 +0000 (19:53 +0200)]
Console.Unix: fix window size not always being invalidated (#41317)

Ensure signal handlers are setup to invalidate cached values
for window size.

3 years agoFix ArgumentNullException when using minimum json file (#41428)
Maryam Ariyan [Thu, 27 Aug 2020 17:33:18 +0000 (10:33 -0700)]
Fix ArgumentNullException when using minimum json file (#41428)

3 years agoAllow return null from ConnectionListener.AcceptAsync (#41442)
Natalia Kondratyeva [Thu, 27 Aug 2020 16:20:54 +0000 (19:20 +0300)]
Allow return null from ConnectionListener.AcceptAsync (#41442)

Changed API as it was proposed and approved in #41304

Closes #41304

3 years agoIssue18826 fix (#35137)
monojenkins [Thu, 27 Aug 2020 15:38:44 +0000 (11:38 -0400)]
Issue18826 fix (#35137)

<!--
Thank you for your Pull Request!

If you are new to contributing to Mono, please try to do your best at conforming to our coding guidelines http://www.mono-project.com/community/contributing/coding-guidelines/ but don't worry if you get something wrong. One of the project members will help you to get things landed.

Does your pull request fix any of the existing issues? Please use the following format: Fixes #issue-number
-->

Fixes mono/mono#18826

Co-authored-by: HinTak <HinTak@users.noreply.github.com>
3 years ago[mono] ALC function restructuring for unloadability (#41344)
Ryan Lucia [Thu, 27 Aug 2020 14:56:30 +0000 (10:56 -0400)]
[mono] ALC function restructuring for unloadability (#41344)

We previously had a weird split between the domain and loader headers/files. This makes fewer things public, moves the useful ALC functions to loader-internals.h with the implementation in assembly-load-context.c, and cleans up the flow for some unloading behavior.

3 years agoAdd support for using cmake in the mono runtime build. (#41316)
Zoltan Varga [Thu, 27 Aug 2020 14:13:41 +0000 (10:13 -0400)]
Add support for using cmake in the mono runtime build. (#41316)

* Add support for using cmake in the mono runtime build.

Not enabled by default. Ninja is used for building if available, else we fall
back to make.

* Build and install libmonosgen-2.0.dylib.

* Address review comments.

* Add a few more MONO_EMPTY_SOURCE_FILE defines to silence ranlib warnings on osx.

* Pass -mmacosx-version-min=10.12 on osx.

* Add eventpipe support.

* Quiet the OSX build a bit.

* Address review comments.

3 years agoGlobally enable nullability in XML (#41438)
Krzysztof Wicher [Thu, 27 Aug 2020 12:57:29 +0000 (14:57 +0200)]
Globally enable nullability in XML (#41438)

* Globally enable nullability in XML

* remove double #nullable enable in the file

3 years agoBrowserDebugProxy: bump package versions to latest stable (#41436)
Alexander Köplinger [Thu, 27 Aug 2020 12:51:19 +0000 (14:51 +0200)]
BrowserDebugProxy: bump package versions to latest stable (#41436)

Fixes https://github.com/dotnet/runtime/issues/41356

3 years agoNullable: System.Xml, part 7 (Serialization) (#41261)
Krzysztof Wicher [Thu, 27 Aug 2020 06:29:11 +0000 (08:29 +0200)]
Nullable: System.Xml, part 7 (Serialization) (#41261)

* Nullable: System.Xml, part 7 (Serialization)

* Fix build errors on Release (ifdef-ed code)

* fix incidental product bug

* address PR feedback

* Make XmlSerializer._rootType nullable

3 years agoThree fixes for R2RDump bugs I discovered while investigating #38290 (#41303)
Tomáš Rylek [Wed, 26 Aug 2020 23:33:45 +0000 (01:33 +0200)]
Three fixes for R2RDump bugs I discovered while investigating #38290 (#41303)

1) As ReadyToRunMethod newly looks at method bodies, in the
composite case we need to pass around per-module IL info, not only
the metadata reader. I have replaced such usages of MetadataReader
with the new interface IAssemblyMetadata and I implemented the
standalone variant StandaloneAssemblyMetadata.

2) I hit an UnwindInfo decoding issue and I found out that the
UnwindCode decoder is weirdly split between the UnwindCode ctor
and a separate method ParseUnwindCode that weren't completely
consistent in whether the UnwindInfoArray refers to the raw 16-bit
entries in the UnwindInfo or to the parsed UnwindCode instances.
I have basically migrated ParseUnwindCode into the UnwindCode ctor
and I simplified the related logic.

3) We shouldn't block method dump on header dump, otherwise there's
no way to dump both headers and methods in one R2RDump execution.

Thanks

Tomas

3 years ago[VisualBasic] Fix tests for Android (#41378)
Edison Henrique Andreassy [Wed, 26 Aug 2020 21:57:05 +0000 (22:57 +0100)]
[VisualBasic] Fix tests for Android (#41378)

Remove some empty tests and add data for others. Resolves #37066

3 years agoAdded VersionConverter (#41384)
devsko [Wed, 26 Aug 2020 21:04:52 +0000 (23:04 +0200)]
Added VersionConverter (#41384)

* Added VersionConverter

* Nullable annotation

3 years agoselect Debian10 over Debian9 for PR validation (#41015)
Tomas Weinfurt [Wed, 26 Aug 2020 20:34:20 +0000 (13:34 -0700)]
select Debian10 over Debian9 for PR validation (#41015)

3 years agoExclude Fannkuch_9 test on ARM (#41380)
Drew Scoggins [Wed, 26 Aug 2020 18:08:16 +0000 (11:08 -0700)]
Exclude Fannkuch_9 test on ARM (#41380)

3 years agoNullability annotations for HttpListener (#41189)
Prashanth Govindarajan [Wed, 26 Aug 2020 17:29:19 +0000 (10:29 -0700)]
Nullability annotations for HttpListener (#41189)

* src files annotated

* ref file

* Address feedback

3 years agoHTTP stress docker fix (#41397)
Marie Píchová [Wed, 26 Aug 2020 16:41:38 +0000 (18:41 +0200)]
HTTP stress docker fix (#41397)

Fixed docker files not using currently built runtime for http stress test.

3 years agoRetry up to three times for X509Chain timeout tests
Kevin Jones [Wed, 26 Aug 2020 16:30:07 +0000 (12:30 -0400)]
Retry up to three times for X509Chain timeout tests

3 years agoAdd netcoreapp build of System.Formats.Asn1
Jeremy Barton [Wed, 26 Aug 2020 16:27:01 +0000 (09:27 -0700)]
Add netcoreapp build of System.Formats.Asn1

This avoids the library causing a cyclic dependency in generating netstandard.dll.
The netcoreapp version is not included in the NuGet package,
following the pattern of
  * System.Text.Json
  * System.Collections.Immutable
  * System.Reflection.Metadata

3 years ago[wasm][browser] Fix System.IO.FileSystem failing tests requiring nanosecond/milliseco...
Tammy Qiu [Wed, 26 Aug 2020 16:06:14 +0000 (12:06 -0400)]
[wasm][browser] Fix System.IO.FileSystem failing tests requiring nanosecond/millisecond granularity (#41288)

* Emscripten lacks ns/ms granularity which I included a switch for and added a browser platform check
* Emscripten takes maximum of utime and atime so I set utime and atime together for Browser

3 years ago[mono] Add mono_assembly_decref, return value on both decref and addref (#41342)
Ryan Lucia [Wed, 26 Aug 2020 13:59:58 +0000 (09:59 -0400)]
[mono] Add mono_assembly_decref, return value on both decref and addref (#41342)

3 years agoReset all Uri fields when reusing an instance (#41324)
Miha Zupan [Wed, 26 Aug 2020 13:08:29 +0000 (15:08 +0200)]
Reset all Uri fields when reusing an instance (#41324)

* Reset all Uri fields when reusing an instance

* Test combined Uri's AbsoluteUri

3 years agoChange Environment.CurrentManagedThreadId back to FCall (#41360)
Jan Kotas [Wed, 26 Aug 2020 12:00:20 +0000 (05:00 -0700)]
Change Environment.CurrentManagedThreadId back to FCall (#41360)

3 years ago[HeapVerify=2] Fix Assert failure "Pointer updated without using write barrier" ...
Leslie Zhai [Wed, 26 Aug 2020 09:53:17 +0000 (17:53 +0800)]
[HeapVerify=2] Fix Assert failure "Pointer updated without using write barrier" (#41375)

* [HeapVerify=2] Fix Assert failure "Pointer updated without using write barrier"

3 years agoupdate macOS 11 rid (#41044)
Tomas Weinfurt [Wed, 26 Aug 2020 09:30:26 +0000 (02:30 -0700)]
update macOS 11 rid (#41044)

* update macOS 11 rid

* add compat 10.16 as well

3 years agoDisable the Platform Compat Analyzer until #41354 is fixed (#41367)
Jeff Handley [Wed, 26 Aug 2020 04:14:29 +0000 (21:14 -0700)]
Disable the Platform Compat Analyzer until #41354 is fixed (#41367)

3 years agoRestrict generational aware analysis to processes that matches the command line confi...
Andrew Au [Wed, 26 Aug 2020 03:02:28 +0000 (20:02 -0700)]
Restrict generational aware analysis to processes that matches the command line configuration (#41052)

3 years agoadd extra padding for icmp6stat to support macOS 11 (#41179)
Tomas Weinfurt [Wed, 26 Aug 2020 02:58:17 +0000 (19:58 -0700)]
add extra padding for icmp6stat to support macOS 11 (#41179)

* add extra padding for icmp6stat to support macOS 11

* update SystemNative_GetIcmpv6GlobalStatistics to use variable size

* add cast

* avoid realloc

3 years agoset TLS versions explicitly to prevent SNI test failure on Deb10 (#41014)
Tomas Weinfurt [Wed, 26 Aug 2020 01:31:30 +0000 (18:31 -0700)]
set TLS versions explicitly to prevent SNI test failure on Deb10 (#41014)

3 years agoWebassembly Runtime Tests (#38556)
Nathan Ricci [Wed, 26 Aug 2020 00:58:02 +0000 (20:58 -0400)]
Webassembly Runtime Tests (#38556)

Enable runtime tests for the Wasm Architecture on Mono runtime.

Co-authored-by: Jan Kotas <jkotas@microsoft.com>
Co-authored-by: Fan Yang <yangfan@microsoft.com>
Co-authored-by: jashook <jashoo@microsoft.com>
Co-authored-by: Tomas Rylek <trylek@microsoft.com>
3 years agoSupport polymorphic value-type converters and add validation on values returned by...
devsko [Tue, 25 Aug 2020 23:39:57 +0000 (01:39 +0200)]
Support polymorphic value-type converters and add validation on values returned by custom converters (#40914)

* IL emit Box/Unbox in member access

* Test case for object converter

* Test case for class with primitive members and object converter

* Address feedback

* Fixed issues with JsonConverter<object>and nullable value-types

* Address feedback

* Fix test for .NETStandard version

* Fix #41146

* Accidentally commited the local test hack

* Throw JsonException when a deserialized value cannot be assigned to the property/field

* Fix merge

* Fix merge again

* Undo Fix #41146

* Consolidate nullable annotations

* Addressed feedback

* Addressed feedback

3 years agoThrow from CodeBase if assembly is in the bundle (#40974)
Andy Gocke [Tue, 25 Aug 2020 22:51:06 +0000 (15:51 -0700)]
Throw from CodeBase if assembly is in the bundle (#40974)

Also adds test for Module.FullyQualifiedName

3 years agoAdd sleep in hijacking test (#41340)
Jakob Botsch Nielsen [Tue, 25 Aug 2020 22:34:19 +0000 (00:34 +0200)]
Add sleep in hijacking test (#41340)

Calling GC.Collect in a tight loop is unnecessary for the test and
causing timeouts in CI.

Fixes #40916

3 years agoFix \u00A7 char Unicode category (#41343)
Tarek Mahmoud Sayed [Tue, 25 Aug 2020 22:26:41 +0000 (15:26 -0700)]
Fix \u00A7 char Unicode category (#41343)

3 years ago[mono] Pass -Wc++-compat on all platforms, -Werror on OSX, fix errors (#41233)
Ryan Lucia [Tue, 25 Aug 2020 21:55:00 +0000 (17:55 -0400)]
[mono] Pass -Wc++-compat on all platforms, -Werror on OSX, fix errors (#41233)

This PR:
* Enables `-Wc++-compat` on all platforms: we support building the runtime as C++, so this helps catch errors before they're found in CI and will help keep the netcore build C++-compatible
* Sets `-Werror` on netcore CI for OSX

It also fixes various warnings currently present in the build.

`-Werror` should probably be extended to cover all CI platforms eventually. Adding a new platform is as simple as adding to the line in mono.proj whitelisting platforms and fixing the warnings.

Not sure if there's a better way to handle the cpuidex function, but if we're using that from mini it should definitely be in a header somewhere.

3 years agoAdd tests mapping invalid JSON to objects with parameterized ctors (#41121)
Layomi Akinrinade [Tue, 25 Aug 2020 20:22:21 +0000 (13:22 -0700)]
Add tests mapping invalid JSON to objects with parameterized ctors (#41121)

* Move invalid JSON tests to dedicated file

* Add tests mapping invalid JSON to objects with parameterized ctors

3 years agoFix signing in official build with 3rd party libraries (#41346)
Santiago Fernandez Madero [Tue, 25 Aug 2020 20:04:25 +0000 (13:04 -0700)]
Fix signing in official build with 3rd party libraries (#41346)

* Fix signing in official build with 3rd party libraries

* Update eng/Signing.props

Co-authored-by: Alexander Köplinger <alex.koeplinger@outlook.com>
3 years ago[runtime] Catch attempts to create enum types with an underlying type that is itself...
monojenkins [Tue, 25 Aug 2020 18:17:25 +0000 (14:17 -0400)]
[runtime] Catch attempts to create enum types with an underlying type that is itself an incomplete enum type. (#41165)

* Catch attempts to create enum types with an underlying type that is itself an incomplete enum type.

Previously, only non-enum types containing fields with incomplete enum
types were forbidden.

* Permit static constant fields with incomplete types if the incomplete type is the type currently being defined

Co-authored-by: Alexis Christoforides <alexis@thenull.net>
Co-authored-by: imhameed <imhameed@users.noreply.github.com>
3 years agoFix NRE introduced in FileSystemWatcher during nullability annotations (#41315)
Krzysztof Wicher [Tue, 25 Aug 2020 17:35:31 +0000 (19:35 +0200)]
Fix NRE introduced in FileSystemWatcher during nullability annotations (#41315)

* Fix NRE introduced during nullability annotations

* Apply Jeff's suggestions from code review

Co-authored-by: Jeff Handley <jeffhandley@users.noreply.github.com>
Co-authored-by: Jeff Handley <jeffhandley@users.noreply.github.com>
3 years agoHTTP/3 interop fixes (#41298)
Cory Nelson [Tue, 25 Aug 2020 17:00:47 +0000 (10:00 -0700)]
HTTP/3 interop fixes (#41298)

Support DNS-based quic connections for SNI.
Support multiple ALPN values.
Update H3 ALPN from "h3" to "h3-29".

3 years agoPrevent invoking property 'init' method (#41293)
Charles Stoner [Tue, 25 Aug 2020 16:45:25 +0000 (09:45 -0700)]
Prevent invoking property 'init' method (#41293)

3 years agoFix tailcall regression with compiled F# (#41206)
Jan Kotas [Tue, 25 Aug 2020 14:17:41 +0000 (07:17 -0700)]
Fix tailcall regression with compiled F# (#41206)

* Fix tailcall regression with compiled F#

This change skips instantiating stubs for direct tailcalls and instead passes the inst argument directly to the target method.

Fixes #40864

* Add regression test

Co-authored-by: Jakob Botsch Nielsen <Jakob.botsch.nielsen@gmail.com>
3 years agoExclude Mono.Cecil assemblies from signing (#41325)
Alexander Köplinger [Tue, 25 Aug 2020 13:53:28 +0000 (15:53 +0200)]
Exclude Mono.Cecil assemblies from signing (#41325)

We're just shipping them in the Microsoft.NETCore.BrowserDebugHost.Transport package.

3 years agoMark System.Diagnostics.FileVersionInfo as unsupported on Browser (#41271)
Mitchell Hwang [Tue, 25 Aug 2020 13:40:13 +0000 (09:40 -0400)]
Mark System.Diagnostics.FileVersionInfo as unsupported on Browser (#41271)

Co-authored-by: Mitchell Hwang <mitchell.hwang@microsoft.com>
3 years ago[master] Update dependencies from dotnet/xharness mono/linker (#41257)
dotnet-maestro[bot] [Tue, 25 Aug 2020 11:23:50 +0000 (11:23 +0000)]
[master] Update dependencies from dotnet/xharness mono/linker (#41257)

[master] Update dependencies from dotnet/xharness mono/linker
- Updates:
  - Microsoft.DotNet.XHarness.CLI: from 1.0.0-prerelease.20420.1 to 1.0.0-prerelease.20424.1
  - Microsoft.DotNet.XHarness.TestRunners.Xunit: from 1.0.0-prerelease.20420.1 to 1.0.0-prerelease.20424.1

- Updates:
  - Microsoft.NET.ILLink.Tasks: from 6.0.0-alpha.1.20422.1 to 6.0.0-alpha.1.20424.3

3 years agoMissed cases not discovered during first phase (#40382)
Jan Jahoda [Tue, 25 Aug 2020 09:13:41 +0000 (11:13 +0200)]
Missed cases not discovered during first phase (#40382)

Co-authored-by: Jan Jahoda <jajahoda@.microsoft.com>
3 years agoPort EventPipe CoreCLR changes to Mono. (#41152)
Johan Lorensson [Tue, 25 Aug 2020 06:42:48 +0000 (08:42 +0200)]
Port EventPipe CoreCLR changes to Mono. (#41152)

* [MonoVM] Enable startup events over EventPipe.

Mono port of CoreCLR PR: https://github.com/dotnet/runtime/pull/36720.

* [MonoVM] Add the ability for profilers to listen to EventPipe events.

Mono port of CoreCLR PR: https://github.com/dotnet/runtime/pull/37002.

* [MonoVM] Add ProcessInfo command to Diagnostics Server.

Mono port of CoreCLR PR: https://github.com/dotnet/runtime/pull/38967.

* [MonoVM] Unregister callback when setting a provider for deferred delete.

Mono port of CoreCLR PR: https://github.com/dotnet/runtime/pull/40191.

* [MonoVM] Generational aware analysis based on environment variable.

Mono port of CoreCLR PR: https://github.com/dotnet/runtime/pull/40332.

NOTE, the ability to pause a session was not ported since it
currently have no use in Mono and looks like a temporary
solution in CoreCLR.

* [MonoVM] Rebrand Diagnostics Server to DiagnosticPort.

Mono port of CoreCLR PR: https://github.com/dotnet/runtime/pull/40499.

3 years agoModified #41008 without GetOverlappedResultEx (#41236)
John Salem [Tue, 25 Aug 2020 02:32:35 +0000 (19:32 -0700)]
Modified #41008 without GetOverlappedResultEx (#41236)

* Revert "Revert "Improve Windows error handling in Diagnostics IPC (#41008)" (#41220)"

This reverts commit 15839c0294b51d8bb9b7f689669da86ebe64546d.

* don't use win8+ API

3 years agoEnable Crossgen2 and Blazor Perf Tests on Linux (#41270)
Olivia Chen [Tue, 25 Aug 2020 01:32:43 +0000 (18:32 -0700)]
Enable Crossgen2 and Blazor Perf Tests on Linux (#41270)

* copy changes from blazor PR

* add crossgen2 job on linux

* fix helixprecommands issue

* fix internal param

* will revert: add back PR trigger

* fix category exclusion

* reset PR trigger

3 years agoCorrect a few mistakes in the ComInterop code (#40234)
Dongbo Wang [Mon, 24 Aug 2020 23:33:04 +0000 (16:33 -0700)]
Correct a few mistakes in the ComInterop code (#40234)

3 years agoAvoid following invalid pointers in mono_w32process_get_modules on Darwin. (#41115)
monojenkins [Mon, 24 Aug 2020 23:06:26 +0000 (19:06 -0400)]
Avoid following invalid pointers in mono_w32process_get_modules on Darwin. (#41115)

`_dyld_get_image_name` and `_dyld_get_image_header` can return pointers
to data that will be freed or unmapped by concurrent calls to `dlclose`.
Avoid this by using `_dyld_register_func_for_add_image` and
`_dyld_register_func_for_remove_image` to install callbacks that
maintain a runtime-internal set of loaded dynamic libraries.

Some notes:

- dyld doesn't provide a public "app store friendly" API (like
`dl_iterate_phdr`) to traverse a snapshot of all loaded dynamic
libraries in a process. There are two alternative private APIs that do
this: one uses `_dyld_process_info_create` and friends and is present in
macOS 10.12 and above, and the other depends on
`_dyld_get_all_image_infos`, which is documented by Apple (... in a WWDC
video) to "go away" at some point in dyld3.

- `dladdr` linearly scans the dyld loaded image array (and each image's
segment set) for a matching address, so `image_added` will get slower as
more dynamic libraries are loaded in the process. But dyld3's
implementation of dlopen already scales linearly in time with the number
of loaded libraries. The use of `dladdr` can be avoided by using
`_dyld_register_for_image_loads` or
`_dyld_register_for_bulk_image_loads`, but those are both private APIs.

- The callbacks registered with `_dyld_register_func_for_add_image` and
`_dyld_register_func_for_remove_image` can never be unregistered, so
this is yet another thing that makes it impossible to safely unload an
embedded mono.

- `MonoW32ProcessModule::inode` only seems to be used to avoid dupicates
in other implementations of w32process; sorting the returned module list
in `mono_w32process_get_modules` wouldn't be necessary if the
`mono_dyld_image_info`s were also kept in an intrusive circular doubly
linked list.

- It looks like `mono_w32process_get_modules` in `w32process-unix-bsd.c`
has a similar race condition.

Also see: https://github.com/mono/mono/issues/20107

Co-authored-by: imhameed <imhameed@users.noreply.github.com>
3 years agoImprove tailcallstress testing (#41059)
Eugene Rozenfeld [Mon, 24 Aug 2020 22:06:06 +0000 (15:06 -0700)]
Improve tailcallstress testing (#41059)

1. Dispatch all tail calls under TailCallStress via helpers. That
increases our coverage since valid non-tail-prefixed calls are
dispatched as fast calls in normal non-stress mode.

2. Don't attempt to tail call from methods that have a localloc
unless there is an explicit tail prefix. Note that we already disallowed
fast tail calls from such methods so this change only affects
tailcallstress mode.

3. Fix a bug in TestInvokeDOPAndCancel. As the test was written
this assert was firing under tailcallstress:
https://github.com/dotnet/runtime/blob/480c49b2419ab4a0b34bfd86754abc2f17079c77/src/libraries/System.Threading.Tasks.Parallel/tests/ParallelForTests.cs#L1074
When this call to `cts.Cancel`:
https://github.com/dotnet/runtime/blob/480c49b2419ab4a0b34bfd86754abc2f17079c77/src/libraries/System.Threading.Tasks.Parallel/tests/ParallelForTests.cs#L1065
is dispatched via helpers, it takes much longer than when it's
dispatched via a fast tail call (we have to jit a couple of IL stubs).
Because of that, it's possible that all other actions complete on the
other thread before cancellation is completed.

3 years agoFix GetAppdomainStaticAddress for non-collectible assemblies (#41076)
David Mason [Mon, 24 Aug 2020 21:53:07 +0000 (14:53 -0700)]
Fix GetAppdomainStaticAddress for non-collectible assemblies (#41076)

3 years agoFix half equality method (#41259)
Huo Yaoyuan [Mon, 24 Aug 2020 21:49:34 +0000 (05:49 +0800)]
Fix half equality method (#41259)

* Align Half.Equals implementation with Double.Equals.

* Add tests for new Half.Equals behaviour.

3 years agoCorrectly enumerate files in Microsoft.NETCore.BrowserDebugHost.Transport.pkgproj...
Alexander Köplinger [Mon, 24 Aug 2020 21:25:35 +0000 (23:25 +0200)]
Correctly enumerate files in Microsoft.NETCore.BrowserDebugHost.Transport.pkgproj (#41290)

On CI when the repo is built from a clean checkout in one go we were evaluating the wildcard in the ItemGroup
before the files were actually built which meant they weren't put into the nuget package.

We need to list each file explicitly to fix that.

3 years agofix GetAsync_SupportedSSLVersion_Succeeds test (#41056)
Tomas Weinfurt [Mon, 24 Aug 2020 21:07:59 +0000 (14:07 -0700)]
fix GetAsync_SupportedSSLVersion_Succeeds test (#41056)

3 years agomap macOS compat 10.16 version to 11.0 (#41176)
Tomas Weinfurt [Mon, 24 Aug 2020 20:52:18 +0000 (13:52 -0700)]
map macOS compat 10.16 version to 11.0 (#41176)

* map macOS compat 10.16 version to 11.0

* feedback from review

3 years ago[coop] Add debug option to disable stack scan (#40985)
Vlad Brezae [Mon, 24 Aug 2020 20:03:25 +0000 (23:03 +0300)]
[coop] Add debug option to disable stack scan (#40985)

When this is enabled, the GC doesn't scan stack or registers. This mode is meant to disable scanning of native frames. This implementation only makes sense in full interpreter mode, where the interp stack is scanned separately from the thread stack. Longer term we could use this mode to scan only the managed stack, also in jit mode.

The point of this mode is to be able to stress test the GC in a wasm like environment, where stack can't be scanned. We can more easily reproduce and investigate GC crashes in this configuration, that would also happen on wasm.

3 years agoFix wasm sample after that was broken after this PR: https://github.com/dotnet/runtim...
Thays Grazia [Mon, 24 Aug 2020 20:00:27 +0000 (17:00 -0300)]
Fix wasm sample after that was broken after this PR: https://github.com/dotnet/runtime/pull/40478 (#41277)

3 years agoDelete dead code and obsolete comments (#41211)
Jan Kotas [Mon, 24 Aug 2020 18:27:21 +0000 (11:27 -0700)]
Delete dead code and obsolete comments (#41211)

3 years agoFix Char.GetUnicodeCategory to returns correct results (#41200)
Tarek Mahmoud Sayed [Mon, 24 Aug 2020 17:45:19 +0000 (10:45 -0700)]
Fix Char.GetUnicodeCategory to returns correct results (#41200)

* Fix Char.GetUnicodeCategory to returns correct results

3 years agoRe-enable testing on OSX 10.15 (#40524)
Jo Shields [Mon, 24 Aug 2020 16:24:50 +0000 (12:24 -0400)]
Re-enable testing on OSX 10.15 (#40524)

* Re-enable testing on OSX 10.15

* ActiveIssue for failing font issue

3 years agoupdate helixprecommands (#41205)
Olivia Chen [Mon, 24 Aug 2020 16:12:54 +0000 (09:12 -0700)]
update helixprecommands (#41205)

3 years agoFix MethodInfo Emit for generic interfaces (#40587)
Wei Zheng [Mon, 24 Aug 2020 15:25:17 +0000 (23:25 +0800)]
Fix MethodInfo Emit for generic interfaces (#40587)

3 years ago[Wasm] Reduce max length on browser for ToArrayShouldWorkWithSpecialLengthLazyEnumera...
Steve Pfister [Mon, 24 Aug 2020 15:21:29 +0000 (11:21 -0400)]
[Wasm] Reduce max length on browser for ToArrayShouldWorkWithSpecialLengthLazyEnumerables Linq test (#41241)

Addresses the occasional timeouts in System.Linq tests.  The last 3-4 iterations of ToArrayShouldWorkWithSpecialLengthLazyEnumerables take
between 20 - 56 seconds each and likely trigger longer GC runs.

Fixes https://github.com/dotnet/runtime/issues/41114

Co-authored-by: Steve Pfister <steve.pfister@microsoft.com>
Co-authored-by: Alexander Köplinger <alex.koeplinger@outlook.com>
3 years ago[mono] Thread DllImportSearchPath flags down to LoadLibraryEx (#41229)
Ryan Lucia [Mon, 24 Aug 2020 14:40:44 +0000 (10:40 -0400)]
[mono] Thread DllImportSearchPath flags down to LoadLibraryEx (#41229)

This mostly completes support for the attribute. Our algorithm differs a bit from CoreCLR right now, so we don't support the legacy behavior flag since it makes less since in the context of our algorithm, but this should be good enough for most cases.

3 years agomore managed pointer rooting (#40934)
Katelyn Gadd [Mon, 24 Aug 2020 09:45:53 +0000 (02:45 -0700)]
more managed pointer rooting (#40934)

Update more bindings and library code to store managed pointers in roots so that objects can't be collected or moved.
Fixes some bugs in the wasm root APIs.

3 years agoFix perf regression in IntPtr operators on 32-bit platforms (#41198)
Jan Kotas [Mon, 24 Aug 2020 08:51:48 +0000 (01:51 -0700)]
Fix perf regression in IntPtr operators on 32-bit platforms (#41198)

Switching to C# built-in uint/nuint types caused these operators to use long/ulong IntPtr/UIntPtr constructors instead of int/uint IntPtr constructors that it were used before.

The fix is to avoid going through the IntPtr/UIntPtr constructors and just depend on the built-in uint/nuint implicit conversions.

Fixes #41167

3 years agoremove unused local (#41226)
Seonyoung Park [Mon, 24 Aug 2020 05:22:43 +0000 (14:22 +0900)]
remove unused local (#41226)

* remove unused local

issue dotnet#30457
remove unused local variable fullPath at line 415

* Update src/libraries/System.Security.Cryptography.X509Certificates/src/System/Security/Cryptography/X509Certificates/X509Certificate2.cs

Co-authored-by: Kevin Gosse <krix33@gmail.com>
Co-authored-by: Kevin Gosse <krix33@gmail.com>
3 years ago[mono] Add more detailed logs for the PInvoke resolution process (#41228)
Ryan Lucia [Mon, 24 Aug 2020 04:24:53 +0000 (00:24 -0400)]
[mono] Add more detailed logs for the PInvoke resolution process (#41228)

Similar logging was added to the managed loading algorithm when it proved extremely useful for debugging a Blazor crash, so the equivalent is probably useful for the unmanaged library algorithm as well

3 years agoFix wrong copy prop after `ASG(promoted LCL_VAR with 1 field, call)`. (#41197)
Sergey Andreenko [Mon, 24 Aug 2020 02:29:50 +0000 (19:29 -0700)]
Fix wrong copy prop after `ASG(promoted LCL_VAR with 1 field, call)`. (#41197)

* Add Andy's repro test.

* Andy's fix.

* fix other places

* Improve dump.

3 years agoFix Array.Sort in the presence of nulls (#41234)
Petr Onderka [Sun, 23 Aug 2020 22:39:02 +0000 (00:39 +0200)]
Fix Array.Sort in the presence of nulls (#41234)

* Add failing test case

* Fix Array.Sort in the presence of nulls

3 years agoRemove unused local (#40967)
Seonyoung Park [Sun, 23 Aug 2020 17:51:01 +0000 (02:51 +0900)]
Remove unused local (#40967)

issue dotnet#30457
remove unused local variable dwErrorCode at line 248

3 years ago[master] Update dependencies from dotnet/runtime-assets dotnet/llvm-project dotnet...
dotnet-maestro[bot] [Sun, 23 Aug 2020 16:07:37 +0000 (09:07 -0700)]
[master] Update dependencies from  dotnet/runtime-assets dotnet/llvm-project dotnet/icu mono/linker dotnet/arcade Microsoft/vstest dotnet/xharness (#41025)

* Update dependencies from https://github.com/dotnet/arcade build 20200817.6

Microsoft.DotNet.XUnitExtensions , Microsoft.DotNet.GenFacades , Microsoft.DotNet.Build.Tasks.Feed , Microsoft.DotNet.Build.Tasks.Packaging , Microsoft.DotNet.Build.Tasks.SharedFramework.Sdk , Microsoft.DotNet.Build.Tasks.TargetFramework.Sdk , Microsoft.DotNet.CodeAnalysis , Microsoft.DotNet.GenAPI , Microsoft.DotNet.XUnitConsoleRunner , Microsoft.DotNet.Arcade.Sdk , Microsoft.DotNet.Helix.Sdk , Microsoft.DotNet.RemoteExecutor , Microsoft.DotNet.VersionTools.Tasks , Microsoft.DotNet.ApiCompat
 From Version 5.0.0-beta.20407.3 -> To Version 5.0.0-beta.20417.6

* Update dependencies from https://github.com/mono/linker build 20200818.3

Microsoft.NET.ILLink.Tasks
 From Version 5.0.0-preview.3.20413.1 -> To Version 5.0.0-preview.3.20418.3

* Update dependencies from https://github.com/dotnet/llvm-project build 20200818.1

runtime.linux-x64.Microsoft.NETCore.Runtime.Mono.LLVM.Tools , runtime.win-x64.Microsoft.NETCore.Runtime.Mono.LLVM.Tools , runtime.win-x64.Microsoft.NETCore.Runtime.Mono.LLVM.Sdk , runtime.osx.10.12-x64.Microsoft.NETCore.Runtime.Mono.LLVM.Tools , runtime.osx.10.12-x64.Microsoft.NETCore.Runtime.Mono.LLVM.Sdk , runtime.linux-arm64.Microsoft.NETCore.Runtime.Mono.LLVM.Tools , runtime.linux-arm64.Microsoft.NETCore.Runtime.Mono.LLVM.Sdk , runtime.linux-x64.Microsoft.NETCore.Runtime.Mono.LLVM.Sdk
 From Version 9.0.1-alpha.1.20410.1 -> To Version 9.0.1-alpha.1.20418.1

* Update dependencies from https://github.com/dotnet/xharness build 20200819.1

Microsoft.DotNet.XHarness.CLI , Microsoft.DotNet.XHarness.TestRunners.Xunit
 From Version 1.0.0-prerelease.20411.1 -> To Version 1.0.0-prerelease.20419.1

* Update dependencies from https://github.com/dotnet/icu build 20200818.2

Microsoft.NETCore.Runtime.ICU.Transport
 From Version 5.0.0-preview.8.20410.1 -> To Version 5.0.0-preview.8.20418.2

* Update dependencies from https://github.com/dotnet/xharness build 20200819.2

Microsoft.DotNet.XHarness.CLI , Microsoft.DotNet.XHarness.TestRunners.Xunit
 From Version 1.0.0-prerelease.20411.1 -> To Version 1.0.0-prerelease.20419.2

* Update dependencies from https://github.com/dotnet/runtime-assets build 20200820.1

System.ComponentModel.TypeConverter.TestData , System.Drawing.Common.TestData , System.IO.Compression.TestData , System.IO.Packaging.TestData , System.Net.TestData , System.Private.Runtime.UnicodeData , System.Security.Cryptography.X509Certificates.TestData , System.Windows.Extensions.TestData
 From Version 5.0.0-beta.20377.1 -> To Version 5.0.0-beta.20420.1

* Update dependencies from https://github.com/mono/linker build 20200820.2

Microsoft.NET.ILLink.Tasks
 From Version 5.0.0-preview.3.20413.1 -> To Version 6.0.0-alpha.1.20420.2

* Update dependencies from https://github.com/dotnet/arcade build 20200819.21

Microsoft.DotNet.GenFacades , Microsoft.DotNet.Build.Tasks.Feed , Microsoft.DotNet.Build.Tasks.Packaging , Microsoft.DotNet.Build.Tasks.SharedFramework.Sdk , Microsoft.DotNet.Build.Tasks.TargetFramework.Sdk , Microsoft.DotNet.CodeAnalysis , Microsoft.DotNet.GenAPI , Microsoft.DotNet.XUnitExtensions , Microsoft.DotNet.Helix.Sdk , Microsoft.DotNet.RemoteExecutor , Microsoft.DotNet.VersionTools.Tasks , Microsoft.DotNet.XUnitConsoleRunner , Microsoft.DotNet.Arcade.Sdk , Microsoft.DotNet.ApiCompat
 From Version 5.0.0-beta.20417.5 -> To Version 5.0.0-beta.20419.21

* Update dependencies from https://github.com/microsoft/vstest build 20200821-01

Microsoft.NET.Test.Sdk
 From Version 16.8.0-preview-20200730-03 -> To Version 16.8.0-preview-20200821-01

* Update dependencies from https://github.com/dotnet/xharness build 20200820.1

Microsoft.DotNet.XHarness.CLI , Microsoft.DotNet.XHarness.TestRunners.Xunit
 From Version 1.0.0-prerelease.20411.1 -> To Version 1.0.0-prerelease.20420.1

* Pin compilers version

* Add dotnet6 feed to NuGet.config

* Update dependencies from https://github.com/mono/linker build 20200822.1

Microsoft.NET.ILLink.Tasks
 From Version 5.0.0-preview.3.20413.1 -> To Version 6.0.0-alpha.1.20422.1

* Update dependencies from https://github.com/dotnet/arcade build 20200819.21

Microsoft.DotNet.GenFacades , Microsoft.DotNet.Build.Tasks.Feed , Microsoft.DotNet.Build.Tasks.Packaging , Microsoft.DotNet.Build.Tasks.SharedFramework.Sdk , Microsoft.DotNet.Build.Tasks.TargetFramework.Sdk , Microsoft.DotNet.CodeAnalysis , Microsoft.DotNet.GenAPI , Microsoft.DotNet.XUnitExtensions , Microsoft.DotNet.Helix.Sdk , Microsoft.DotNet.RemoteExecutor , Microsoft.DotNet.VersionTools.Tasks , Microsoft.DotNet.XUnitConsoleRunner , Microsoft.DotNet.Arcade.Sdk , Microsoft.DotNet.ApiCompat
 From Version 5.0.0-beta.20417.5 -> To Version 5.0.0-beta.20419.21

* Update dependencies from https://github.com/microsoft/vstest build 20200821-04

Microsoft.NET.Test.Sdk
 From Version 16.8.0-preview-20200730-03 -> To Version 16.8.0-release-20200821-04

Co-authored-by: dotnet-maestro[bot] <dotnet-maestro[bot]@users.noreply.github.com>
Co-authored-by: Matt Mitchell <mmitche@microsoft.com>
Co-authored-by: Santiago Fernandez Madero <safern@microsoft.com>
3 years agoUse nint instead of IntPtr in generic SpanHelpers (#41199)
Jan Kotas [Sun, 23 Aug 2020 16:01:51 +0000 (09:01 -0700)]
Use nint instead of IntPtr in generic SpanHelpers (#41199)

3 years agoFix linux_musl runs (#41224)
Tomáš Rylek [Sun, 23 Aug 2020 12:53:00 +0000 (14:53 +0200)]
Fix linux_musl runs (#41224)

This bug was caused by slight semantic change I inadvertently
introduced in my PR

https://github.com/dotnet/runtime/pull/40959

According to today logic in the relevant scripts, TargetOS
shouldn't include the OS subgroup spec. I have modified
send-to-helix-step to pass it in a separate property parameter
(TargetOSSubgroup) so that it can be used for construction
of the HelixRuntimeRid.

Thanks

Tomas

3 years agoRevert "Improve Windows error handling in Diagnostics IPC (#41008)" (#41220)
Jan Kotas [Sun, 23 Aug 2020 01:04:22 +0000 (18:04 -0700)]
Revert "Improve Windows error handling in Diagnostics IPC (#41008)" (#41220)

This reverts commit 5cabbabe3a3bdeaaf8f0b9dc34cf401ee88e86ff.

3 years agoMove Editor Attribute to S.CM.Primitives and apply to types that had it in netfx...
Santiago Fernandez Madero [Sun, 23 Aug 2020 00:23:57 +0000 (17:23 -0700)]
Move Editor Attribute to S.CM.Primitives and apply to types that had it in netfx (#41145)

* Move EditorAttribute to System.ComponentModel.Primitives

* Add EditorAttribute to types that had it in netfx and fix some DesignerSerializableAttributes

* PR Feedback

* PR Feedback

3 years agoAvoid having two copies of System.Private.CoreLib.ni.pdb in the same NuGet package...
Anton Lapounov [Sun, 23 Aug 2020 00:14:58 +0000 (17:14 -0700)]
Avoid having two copies of System.Private.CoreLib.ni.pdb in the same NuGet package directory (#41057)

3 years agoAdd regression test for GitHub issue 13394 (#41210)
Tomáš Rylek [Sat, 22 Aug 2020 20:24:05 +0000 (22:24 +0200)]
Add regression test for GitHub issue 13394 (#41210)

3 years agoAdd DO-NOT-SIGN comment for files that should not be signed (#41185)
Nikola Milosavljevic [Sat, 22 Aug 2020 20:18:56 +0000 (13:18 -0700)]
Add DO-NOT-SIGN comment for files that should not be signed (#41185)

3 years ago[wasm][debugger] Fix expression evaluation when it is a reference (#41135)
Ankit Jain [Sat, 22 Aug 2020 18:34:59 +0000 (14:34 -0400)]
[wasm][debugger] Fix expression evaluation when it is a reference (#41135)

* [wasm][debugger] Fix expression evaluation when it is a reference

.. preceded by spaces. Eg: `"  foo.dateTime", or `"  foo.count"`

* Explanation of the fix:

- these particular expressions end up in the code path where we get a
SimpleMemberAccessExpression, and only one member access (like `a.b.c`)
was found.

- that code path had
    `return memberAccessValues[0]?["value"]?.Value<JObject>();`

  - which is incorrect, and we need to return `memberAccessValues[0]`,
  which is the value itself.