platform/upstream/coreclr.git
6 years agoMove all non-full opt, non-pgo perf legs to periodic (#15398)
Michelle McDaniel [Wed, 6 Dec 2017 19:35:55 +0000 (11:35 -0800)]
Move all non-full opt, non-pgo perf legs to periodic (#15398)

We don't need the perf results for min-opt/no-pgo runs as frequently as
we need full-opt pgo runs (which we want to get per commit, if
possible), so move them to only running once daily.

6 years agoMerge pull request #15388 from BruceForstall/NoLongRunningTests
Bruce Forstall [Wed, 6 Dec 2017 17:22:20 +0000 (09:22 -0800)]
Merge pull request #15388 from BruceForstall/NoLongRunningTests

Don't run ARM/ARM64 tests marked LONG_RUNNING

6 years agoUpdate PgoData to master-20171206-0036 (#15390)
dotnet-maestro-bot [Wed, 6 Dec 2017 16:48:13 +0000 (10:48 -0600)]
Update PgoData to master-20171206-0036 (#15390)

6 years agoMerge pull request #15387 from BruceForstall/FixArmTesting
Bruce Forstall [Wed, 6 Dec 2017 16:45:04 +0000 (08:45 -0800)]
Merge pull request #15387 from BruceForstall/FixArmTesting

Adjust BenchI/BenchF paths to account for recent file moves

6 years agoAddress PR feedback for change adding key to KeyNotFoundException (#15234)
Anirudh Agnihotry [Wed, 6 Dec 2017 07:09:24 +0000 (23:09 -0800)]
Address PR feedback for change adding key to KeyNotFoundException (#15234)

* Throwing KeyNotFoundException using Throw + get for JIT to generate better code for ii

6 years agoDon't run ARM/ARM64 tests marked LONG_RUNNING
Bruce Forstall [Wed, 6 Dec 2017 01:48:54 +0000 (17:48 -0800)]
Don't run ARM/ARM64 tests marked LONG_RUNNING

These tests can time out when run with the default job timeout.
So, disable them in normal runs.

6 years agoUpdate CoreClr to preview1-26005-01 (#15371)
dotnet-maestro-bot [Wed, 6 Dec 2017 01:29:56 +0000 (19:29 -0600)]
Update CoreClr to preview1-26005-01 (#15371)

6 years agoAdjust BenchI/BenchF paths to account for recent file moves
Bruce Forstall [Wed, 6 Dec 2017 00:53:59 +0000 (16:53 -0800)]
Adjust BenchI/BenchF paths to account for recent file moves

6 years ago[Arm64] Enable SIMD (#14633)
Steve MacLean [Tue, 5 Dec 2017 23:15:23 +0000 (18:15 -0500)]
[Arm64] Enable SIMD (#14633)

* [Arm64] EXTERNAL_FeatureSIMD_Default = 1

* [Arm64] Enable SIMD compilation

* [Arm64] Enable SIMD in crossgen

* [Arm64] Allow SIMD in altjit

Add flag SIMD16ByteOnly
Set COMPlus_SIMD16ByteOnly=1 in x64_arm64_altjit.cmd
If SIMD16ByteOnly, limit clear FLAG_USE_AVX2 to disable SIMD32 vector size
Enable SIMD in protonjit

* Fix #if per feedback

6 years agoFixed some broken formatting (#15369)
Matt Warren [Tue, 5 Dec 2017 17:08:36 +0000 (17:08 +0000)]
Fixed some broken formatting (#15369)

6 years agoUpdate BuildTools, CoreClr, PgoData to prerelease-02304-01, preview1-26004-04, master...
dotnet-maestro-bot [Tue, 5 Dec 2017 12:54:34 +0000 (06:54 -0600)]
Update BuildTools, CoreClr, PgoData to prerelease-02304-01, preview1-26004-04, master-20171205-0037, respectively (#15356)

6 years agoRemove old methods using string format (#15363)
Stephen Toub [Tue, 5 Dec 2017 03:53:04 +0000 (22:53 -0500)]
Remove old methods using string format (#15363)

6 years agoHave a Type.IsConvertible property. (#15365)
Jon Hanna [Tue, 5 Dec 2017 03:52:04 +0000 (03:52 +0000)]
Have a Type.IsConvertible property. (#15365)

dotnet/corefx#25671 asks for this as a public API, but this just seeks
to make it available to corefx.

Motivation discussed at dotnet/corefx#25663 and dotnet/corefx#25670

Mirror PR to corert will need and overload making runtime types return
false there.

6 years agoSeparate large perf benchmarks into their own legs (#15231)
Michelle McDaniel [Mon, 4 Dec 2017 22:01:07 +0000 (14:01 -0800)]
Separate large perf benchmarks into their own legs (#15231)

Separate large perf benchmarks into their own legs

This change splits the windows perf test stages into 6 pipelined legs per flavor to reduce the amount of time we spend running the perf tests and reduce the total time of the job. This change also decreases the size of the stashed bin directory by deleting the obj directory. Finally, we move the benchstones suite into one directory (moving BenchF and BenchI into a shared dir called Benchstones)

6 years agoUpdate CoreClr, PgoData to preview1-26004-01, master-20171204-0047, respectively...
dotnet-maestro-bot [Mon, 4 Dec 2017 12:27:25 +0000 (06:27 -0600)]
Update CoreClr, PgoData to preview1-26004-01, master-20171204-0047, respectively (#15350)

6 years agoRename the method FloorLog2 to be more clear & fix spelling (#25335) (#15349)
Zhukov Maxim [Sun, 3 Dec 2017 05:42:48 +0000 (08:42 +0300)]
Rename the method FloorLog2 to be more clear & fix spelling (#25335) (#15349)

6 years agoUpdate CoreClr, PgoData to preview1-26002-02, master-20171202-0035, respectively...
dotnet-maestro-bot [Sat, 2 Dec 2017 20:35:44 +0000 (14:35 -0600)]
Update CoreClr, PgoData to preview1-26002-02, master-20171202-0035, respectively (#15346)

6 years agoJIT: defer removing statements during opt CSE (#15323)
Andy Ayers [Sat, 2 Dec 2017 17:12:09 +0000 (09:12 -0800)]
JIT: defer removing statements during opt CSE (#15323)

The statements may contain CSE defs which if removed can confuse subsequent
CSE processing.

Fixes #15319.

6 years agoDelete sortversioning.cpp/h (#15345)
Jan Kotas [Sat, 2 Dec 2017 09:21:49 +0000 (01:21 -0800)]
Delete sortversioning.cpp/h (#15345)

Fixes #8403

6 years agoUpdate CoreClr, CoreFx to preview1-26002-01, preview1-26002-01, respectively (#15344)
dotnet-maestro-bot [Sat, 2 Dec 2017 04:13:49 +0000 (22:13 -0600)]
Update CoreClr, CoreFx to preview1-26002-01, preview1-26002-01, respectively (#15344)

6 years agoMerge pull request #15315 from CarolEidt/Fix14548
Carol Eidt [Fri, 1 Dec 2017 23:56:43 +0000 (15:56 -0800)]
Merge pull request #15315 from CarolEidt/Fix14548

Unmark unused fields as not lvOnFrame

6 years agoImprove throughput of String.Split(char / char[], ...) (#15322)
Stephen Toub [Fri, 1 Dec 2017 23:27:45 +0000 (18:27 -0500)]
Improve throughput of String.Split(char / char[], ...) (#15322)

* Improve throughput of String.Split(char / char[], ...)

Also reduces the amount of unsafe code used.

* Address PR feedback

6 years agoChange name to perf jobs to reflect the actual OS they run on (#15314)
Victor "Nate" Graf [Fri, 1 Dec 2017 23:18:02 +0000 (15:18 -0800)]
Change name to perf jobs to reflect the actual OS they run on (#15314)

* Change name fo perf jobs to reflect the actual OS they run on

* readd Ubuntu 14.04

6 years agoMerge pull request #15190 from sdmaclea/PR-ARM64-IsContainableMemoryOp
Carol Eidt [Fri, 1 Dec 2017 23:03:18 +0000 (15:03 -0800)]
Merge pull request #15190 from sdmaclea/PR-ARM64-IsContainableMemoryOp

[Arm64] Allow IsContainableMemoryOp() use

6 years agoMerge pull request #15281 from sdmaclea/PR-ARM64-Fix-UNROLL_LIMIT
Bruce Forstall [Fri, 1 Dec 2017 22:58:34 +0000 (14:58 -0800)]
Merge pull request #15281 from sdmaclea/PR-ARM64-Fix-UNROLL_LIMIT

[Arm64] Fix UNROLL_LIMIT logic

6 years agoMerge pull request #15270 from sdmaclea/PR-ARM64-JITSTRESS-lvaStressLclFldCB
Bruce Forstall [Fri, 1 Dec 2017 22:57:24 +0000 (14:57 -0800)]
Merge pull request #15270 from sdmaclea/PR-ARM64-JITSTRESS-lvaStressLclFldCB

[ARM64] Align Compiler::lvaStressLclFldCB padding

6 years agoJIT: handle boundary cases for casts of long shifts (#15294)
Andy Ayers [Fri, 1 Dec 2017 22:08:31 +0000 (14:08 -0800)]
JIT: handle boundary cases for casts of long shifts (#15294)

* JIT: handle boundary cases for casts of long shifts

Remove the assert that the shift count is non-negative.
Don't try and optimize if the shift count is >= 64 or < 0.
Update test case to cover these values.

Updates the fix from #15236.
Closes #15291.

6 years agoUpdate BuildTools, CoreClr, CoreFx to prerelease-02301-01, preview1-26001-02, preview...
dotnet-maestro-bot [Fri, 1 Dec 2017 22:04:54 +0000 (16:04 -0600)]
Update BuildTools, CoreClr, CoreFx to prerelease-02301-01, preview1-26001-02, preview1-26001-02, respectively (#15321)

6 years agoMerge pull request #15262 from sdmaclea/PR-ARM64-JITSTRESS-genEpilogRestoreReg
Bruce Forstall [Fri, 1 Dec 2017 20:30:33 +0000 (12:30 -0800)]
Merge pull request #15262 from sdmaclea/PR-ARM64-JITSTRESS-genEpilogRestoreReg

[Arm64] Use REG_IP1 for genEpilogRestoreReg*

6 years agoMerge pull request #15275 from sdmaclea/PR-ARM64-SIMD-genMultiRegCallStoreToLocal...
Bruce Forstall [Fri, 1 Dec 2017 20:06:57 +0000 (12:06 -0800)]
Merge pull request #15275 from sdmaclea/PR-ARM64-SIMD-genMultiRegCallStoreToLocal-produceReg

[Arm64] SIMD genMultiRegCallStoreToLocal add missing produceReg

6 years agoMerge pull request #15311 from BruceForstall/FixArmFlowTriggering
Bruce Forstall [Fri, 1 Dec 2017 17:48:12 +0000 (09:48 -0800)]
Merge pull request #15311 from BruceForstall/FixArmFlowTriggering

Don't add triggers for arm/armlb/arm64 non-flow jobs

6 years agoMerge pull request #15317 from dotnet-bot/from-tfs
Stephen Toub [Fri, 1 Dec 2017 11:38:30 +0000 (06:38 -0500)]
Merge pull request #15317 from dotnet-bot/from-tfs

Merge changes from TFS

6 years agoUnix: Remove MaxPath, MaxName (#15229)
Tom Deseyn [Fri, 1 Dec 2017 11:38:13 +0000 (12:38 +0100)]
Unix: Remove MaxPath, MaxName (#15229)

* Unix: Remove MaxPath, MaxName

PATH_MAX is not an upper bound on path lengths on Unix. system function return
values should be used to determine behavior, instead of limiting the path length.

NAME_MAX depends on the file system used. Its value depends on the path, it is
not constant for the entire system.

* PR feedback

* Sync with corefx Interop.ReadLink

* Deal with /etc/localtime link containing relative path

6 years agoJumpstub fixes (#15296)
Jan Kotas [Fri, 1 Dec 2017 07:21:40 +0000 (23:21 -0800)]
Jumpstub fixes (#15296)

- Reserve space for jump stubs for precodes and other code fragments at the end of each code heap segment. This is trying
to ensure that eventual allocation of jump stubs for precodes and other code fragments succeeds. Accounting is done
conservatively - reserves more than strictly required. It wastes a bit of address space, but no actual memory. Also,
this reserve is not used to allocate jump stubs for JITed code since the JITing can recover from failure to allocate
the jump stub now. Fixes #14996.

- Improve algorithm to reuse HostCodeHeap segments: Maintain estimated size of the largest free block in HostCodeHeap.
This estimate is updated when allocation request fails, and also when memory is returned to the HostCodeHeap. Fixes #14995.

- Retry JITing on failure to allocate jump stub. Failure to allocate jump during JITing is not fatal anymore. There is
extra memory reserved for jump stubs on retry to ensure that the retry succeeds allocating the jump stubs that it needs
with high probability.

- Respect CodeHeapRequestInfo::getRequestSize for HostCodeHeap. CodeHeapRequestInfo::getRequestSize is used to
throttle code heap segment size for large workloads. Not respecting it in HostCodeHeap lead to too many
too small code heap segments in large workloads.

- Switch HostCodeHeap nibble map to be allocated on regular heap as part. It simplied the math required to estimate
the nibble map size, and allocating on regular heap is overall goodness since it does not need to be executable.

6 years agoMerge pull request #15312 from BruceForstall/FixSmartyArchive
Bruce Forstall [Fri, 1 Dec 2017 06:00:58 +0000 (22:00 -0800)]
Merge pull request #15312 from BruceForstall/FixSmartyArchive

Fix smarty output archiving

6 years agoUpdate CoreClr, CoreFx, PgoData to preview1-26001-01, preview1-26001-01, master-20171...
dotnet-maestro-bot [Fri, 1 Dec 2017 04:04:04 +0000 (22:04 -0600)]
Update CoreClr, CoreFx, PgoData to preview1-26001-01, preview1-26001-01, master-20171130-0053, respectively (#15298)

6 years agoMerge pull request dotnet/corert#5038 from dotnet/nmirror
Jan Kotas [Wed, 29 Nov 2017 06:31:23 +0000 (22:31 -0800)]
Merge pull request dotnet/corert#5038 from dotnet/nmirror

Merge nmirror to master

Signed-off-by: dotnet-bot <dotnet-bot@microsoft.com>
6 years agoUnmark unused fields as lvOnFrame
Carol Eidt [Fri, 1 Dec 2017 01:51:36 +0000 (17:51 -0800)]
Unmark unused fields as lvOnFrame

If a dependently promoted (i.e. non-register candidate) field of a struct is unused, and its parent is not allocated onto the stack, we cannot allocate the dependent fields to the stack either (they were previously being assigned offsets from 0, which may be in the GC ptr area, which causes an assert).

Fix #14548

6 years agoFix smarty output archiving
Bruce Forstall [Fri, 1 Dec 2017 00:23:55 +0000 (16:23 -0800)]
Fix smarty output archiving

Need to unset AltJit environment variables (and possibly others)
before running powershell.

6 years agodelete the second definition of getMethodNameFromMetadata2
dotnet-bot [Fri, 1 Dec 2017 00:04:03 +0000 (16:04 -0800)]
delete the second definition of getMethodNameFromMetadata2

[tfs-changeset: 1682581]

6 years agodelete the second definition of getMethodNameFromMetadata
dotnet-bot [Thu, 30 Nov 2017 23:37:53 +0000 (15:37 -0800)]
delete the second definition of getMethodNameFromMetadata

[tfs-changeset: 1682574]

6 years agoDon't add triggers for arm/armlb/arm64 non-flow jobs
Bruce Forstall [Thu, 30 Nov 2017 21:58:08 +0000 (13:58 -0800)]
Don't add triggers for arm/armlb/arm64 non-flow jobs

6 years agoFixed DCE of call nodes (#15192)
Roman Artemev [Thu, 30 Nov 2017 21:27:10 +0000 (13:27 -0800)]
Fixed DCE of call nodes (#15192)

Fixed DCE of call nodes which affect stack level

6 years agoMerge pull request #15305 from BruceForstall/AddMoreSmartyZipFileLogging
Bruce Forstall [Thu, 30 Nov 2017 20:40:28 +0000 (12:40 -0800)]
Merge pull request #15305 from BruceForstall/AddMoreSmartyZipFileLogging

Add temporary logging to track down failure to ZIP smarty output

6 years agoUse ILAsm from buildtools, take 2 (#15300)
Michal Strehovský [Thu, 30 Nov 2017 20:23:34 +0000 (21:23 +0100)]
Use ILAsm from buildtools, take 2 (#15300)

Since #15172 got rolled back in #15292, trying this again.

This time also deleting garbage `.permission` attributes from the failing tests. Permissions are not supported in CoreCLR.

Filed #15299 on some more ILAsm from CoreCLR frustrations.

6 years agoAdd temporary logging to track down failure to ZIP smarty output
Bruce Forstall [Thu, 30 Nov 2017 20:12:18 +0000 (12:12 -0800)]
Add temporary logging to track down failure to ZIP smarty output

6 years agoRemoved Check Invalid Path Chars (#15191)
Anirudh Agnihotry [Thu, 30 Nov 2017 19:54:26 +0000 (11:54 -0800)]
Removed Check Invalid Path Chars (#15191)

Removed Check Invalid Chars from Coreclr

6 years agoUpdate build definition execute conditions for api v3.2 (#15285)
chcosta [Thu, 30 Nov 2017 17:49:16 +0000 (09:49 -0800)]
Update build definition execute conditions for api v3.2 (#15285)

6 years agoExpose Environment.ProcessorCount via EnvironmentAugments (#15297)
Tom Deseyn [Thu, 30 Nov 2017 15:42:16 +0000 (16:42 +0100)]
Expose Environment.ProcessorCount via EnvironmentAugments (#15297)

6 years ago[Local GC] Fail fast on exceptions within a standalone GC (#15290)
Sean Gillespie [Thu, 30 Nov 2017 05:25:20 +0000 (21:25 -0800)]
[Local GC] Fail fast on exceptions within a standalone GC (#15290)

6 years agoUpdate CoreFx to preview1-25930-02 (#15295)
dotnet-maestro-bot [Thu, 30 Nov 2017 04:38:08 +0000 (22:38 -0600)]
Update CoreFx to preview1-25930-02 (#15295)

6 years agoMerge pull request #15292 from BruceForstall/Revert15172
Bruce Forstall [Thu, 30 Nov 2017 02:43:31 +0000 (18:43 -0800)]
Merge pull request #15292 from BruceForstall/Revert15172

Revert "Use ILAsm from buildtools (#15172)"

6 years ago[RyuJit] Delete contained workaround. (#15257)
Sergey Andreenko [Thu, 30 Nov 2017 02:37:26 +0000 (18:37 -0800)]
[RyuJit] Delete contained workaround.  (#15257)

* Move CodeGen::indirForm and IntForm to common.

* GenTreeFieldList: SetContained only for the head.

* delete the workaround.

* move check from isContained to CheckLIR

`isContained` can't determinate does node has user or not. Move this check to the appropriate place.

* check that SetContained and IsContained are consistent.

6 years agoMerge pull request #15282 from BruceForstall/EnableMoreArmGcStressModes
Bruce Forstall [Thu, 30 Nov 2017 01:12:01 +0000 (17:12 -0800)]
Merge pull request #15282 from BruceForstall/EnableMoreArmGcStressModes

Allow arm/armlb/arm64 to run additional jobs

6 years agoRevert "Use ILAsm from buildtools (#15172)"
Bruce Forstall [Thu, 30 Nov 2017 00:37:38 +0000 (16:37 -0800)]
Revert "Use ILAsm from buildtools (#15172)"

This reverts commit e864120d14c829df6f6d4c6cff6f3d23db19606c.

6 years agoMerge pull request #15288 from wtgodbe/Crossgen
William Godbe [Wed, 29 Nov 2017 23:43:34 +0000 (15:43 -0800)]
Merge pull request #15288 from wtgodbe/Crossgen

Ensure CoreCLR Package version overwrite works correctly in test build

6 years agoFix GC stress C bug for arm (#15269)
Jan Vorlicek [Wed, 29 Nov 2017 23:22:05 +0000 (00:22 +0100)]
Fix GC stress C bug for arm (#15269)

* Fix GC stress C bug for arm

The OnGcCoverageInterrupt function was not removing the "thumb" bit from
the address before putting back the original instruction that was
previously replaced by an invalid instruction that invokes the
OnGcCoverageInterrupt. That resulted in the original instruction being
restored to incorrect location (to the original address + 1) and later
to the GC stress failure.

* Reflect PR feedback

6 years agoEnsure CoreCLR Package version overwrite works correctly in test build
wtgodbe [Wed, 29 Nov 2017 22:56:19 +0000 (14:56 -0800)]
Ensure CoreCLR Package version overwrite works correctly in test build

6 years agoUpdate CoreClr, CoreFx, PgoData to preview1-25929-01, preview1-25929-02, master-20171...
dotnet-maestro-bot [Wed, 29 Nov 2017 22:43:36 +0000 (16:43 -0600)]
Update CoreClr, CoreFx, PgoData to preview1-25929-01, preview1-25929-02, master-20171129-0045, respectively (#15266)

6 years agoAllow arm/armlb/arm64 to run additional jobs
Bruce Forstall [Wed, 29 Nov 2017 22:03:16 +0000 (14:03 -0800)]
Allow arm/armlb/arm64 to run additional jobs

This improves stress test coverage and creates consistency with
other platforms.

The jobs:
```
tieredcompilation
forcerelocs
jitnosimd (will soon be interesting for ARM64)
heapverify1
gcstress0xc_zapdisable
gcstress0xc_zapdisable_jitstress2
gcstress0xc_zapdisable_heapverify1
gcstress0xc_minopts_heapverify1
```

6 years ago[Arm64] Fix UNROLL_LIMIT logic
Steve MacLean [Wed, 29 Nov 2017 21:14:04 +0000 (16:14 -0500)]
[Arm64] Fix UNROLL_LIMIT logic

6 years ago[tfs-changeset: 1682429]
Brian Sullivan [Wed, 29 Nov 2017 21:25:00 +0000 (13:25 -0800)]
[tfs-changeset: 1682429]

6 years ago[ARM64] Align Compiler::lvaStressLclFldCB padding
Steve MacLean [Wed, 29 Nov 2017 15:03:05 +0000 (10:03 -0500)]
[ARM64] Align Compiler::lvaStressLclFldCB padding

6 years agoUse ILAsm from buildtools (#15172)
Michal Strehovský [Wed, 29 Nov 2017 18:16:18 +0000 (19:16 +0100)]
Use ILAsm from buildtools (#15172)

* Use ILAsm from buildtools

On Windows: this stops using the ILASM that ships with Windows in favor
of CoreCLR ILASM
On Unix: this stops using the live built ILASM.

I image this fixes some issues in crossbuild on both platforms but I
can't find where the workarounds for that are.

Necessary prerequisite for being able to build tests for the default
interfaces feature.

6 years ago[Arm64] SIMD genMultiRegCallStoreToLocal add missing produceReg
Steve MacLean [Wed, 29 Nov 2017 17:30:32 +0000 (12:30 -0500)]
[Arm64] SIMD genMultiRegCallStoreToLocal add missing produceReg

6 years agoAvoid provider-related costs for default integer formatting (#15272)
Stephen Toub [Wed, 29 Nov 2017 17:57:47 +0000 (12:57 -0500)]
Avoid provider-related costs for default integer formatting (#15272)

One of the biggest costs when invoking Int32.ToString() and similar methods is in fetching the current culture, accessing its number information, etc.  And if a culture is provided explicitly, there are still costs related to casts.  But when the default format is used for non-negative integer values, the number format information isn't used at all, and we can skip the associated costs.  This improves formatting perf in such cases by upwards of ~25%.

6 years ago[Arm64] Use REG_IP1 for genEpilogRestoreReg*
Steve MacLean [Tue, 28 Nov 2017 20:10:38 +0000 (15:10 -0500)]
[Arm64] Use REG_IP1 for genEpilogRestoreReg*

Avoid conflict with FASTTAILCALL_TARGET reg

6 years agoUpdate BuildTools, CoreClr, CoreFx to prerelease-02228-01, preview1-25928-08, preview...
dotnet-maestro-bot [Wed, 29 Nov 2017 04:37:51 +0000 (22:37 -0600)]
Update BuildTools, CoreClr, CoreFx to prerelease-02228-01, preview1-25928-08, preview1-25929-01, respectively (#15252)

6 years agoMerge pull request #15246 from stephentoub/double_tryformat
Stephen Toub [Wed, 29 Nov 2017 04:34:04 +0000 (23:34 -0500)]
Merge pull request #15246 from stephentoub/double_tryformat

Add double/float.TryFormat

6 years agoAddress PR feedback
Stephen Toub [Wed, 29 Nov 2017 03:22:50 +0000 (22:22 -0500)]
Address PR feedback

- Simplify FCALL signatures
- Simplify mantissa logic copied from corert

6 years agoReduce duplicate code for span formatting in StringBuilder
Stephen Toub [Tue, 28 Nov 2017 18:31:50 +0000 (13:31 -0500)]
Reduce duplicate code for span formatting in StringBuilder

6 years agoAdd double/float.TryFormat
Stephen Toub [Tue, 28 Nov 2017 17:58:36 +0000 (12:58 -0500)]
Add double/float.TryFormat

Also implement ISpanFormattable so that string.Format and StringBuilder.AppendFormat take optimized paths with double and float, and update StringBuilder.Append(double/float) to use the new TryFormat methods.

6 years agoPort ValueStringBuilder updates/fixes from corefx
Stephen Toub [Tue, 28 Nov 2017 17:18:43 +0000 (12:18 -0500)]
Port ValueStringBuilder updates/fixes from corefx

6 years agoMove FormatDouble/Single to managed code
Stephen Toub [Tue, 28 Nov 2017 16:48:37 +0000 (11:48 -0500)]
Move FormatDouble/Single to managed code

Instead of making fcalls to FormatDouble and FormatSingle, move them to managed, and use fcalls for the DoubleToNumber and NumberToDouble they call, shifting down the layer that's implemented in native.  This allows us to then much more easily add TryFormat methods for double and float while also sharing more code between coreclr and corert, from which the managed implementations were taken (they're a direct port of these native implementations from coreclr).  In the process, I also eliminated one fcall that can be implemented in managed easily.  The remaining fcalls are more substantial and will eventually require more effort to bring to managed.

6 years agoJIT: fix bug with int casts of long shifts (#15236)
Andy Ayers [Wed, 29 Nov 2017 02:10:06 +0000 (18:10 -0800)]
JIT: fix bug with int casts of long shifts (#15236)

* JIT: fix bug with int casts of long shifts

The jit is pushing int casts down through long left shifts in ways that can
change computation. The push is only safe if the shift amount is 31 bits or
less. So split the current optimization for shifts into three cases:
* shift amount unknown: don't push the cast
* shift amount > 31: result of cast/shift is zero
* shift amout <= 31: push the cast

Fixes #15077.

6 years agoMerge pull request #15250 from BruceForstall/DisableMuldimjagary
Bruce Forstall [Wed, 29 Nov 2017 01:03:26 +0000 (17:03 -0800)]
Merge pull request #15250 from BruceForstall/DisableMuldimjagary

Disable muldimjagary test for arm

6 years agoMerge pull request #15253 from BruceForstall/FixSmartyArchive2
Bruce Forstall [Wed, 29 Nov 2017 00:54:20 +0000 (16:54 -0800)]
Merge pull request #15253 from BruceForstall/FixSmartyArchive2

Fix archiving of smarty results

6 years agoFix archiving of smarty results
Bruce Forstall [Wed, 29 Nov 2017 00:10:55 +0000 (16:10 -0800)]
Fix archiving of smarty results

Run the command to ZIP the output directory in the same
"Execute Batch File" step as the smarty. Otherwise, a failure
of smarty will cause Jenkins to not run the subsequent batch file
steps, including the ZIP step.

Also, preserve the smarty error code to use that as the batch
file step exit code.

6 years agoFix netci.groovy braces after Linux/x86 change
Bruce Forstall [Wed, 29 Nov 2017 00:30:06 +0000 (16:30 -0800)]
Fix netci.groovy braces after Linux/x86 change

6 years agoDisable muldimjagary test for arm
Bruce Forstall [Tue, 28 Nov 2017 22:31:09 +0000 (14:31 -0800)]
Disable muldimjagary test for arm

Fixes #15245

6 years agoMerge pull request #15247 from wtgodbe/TestNativeBinLocation
William Godbe [Tue, 28 Nov 2017 21:03:34 +0000 (13:03 -0800)]
Merge pull request #15247 from wtgodbe/TestNativeBinLocation

Download test native binaries to correct location

6 years agoDownload test native binaries to correct location
wtgodbe [Tue, 28 Nov 2017 20:49:59 +0000 (12:49 -0800)]
Download test native binaries to correct location

6 years agoUpdate CoreClr to preview1-25928-02 (#15240)
dotnet-maestro-bot [Tue, 28 Nov 2017 19:28:56 +0000 (13:28 -0600)]
Update CoreClr to preview1-25928-02 (#15240)

6 years agoUpdate CoreClr, PgoData to preview1-25927-01, master-20171128-0148, respectively...
dotnet-maestro-bot [Tue, 28 Nov 2017 13:06:38 +0000 (07:06 -0600)]
Update CoreClr, PgoData to preview1-25927-01, master-20171128-0148, respectively (#15239)

6 years agoFix typo in comment in number formatting
Stephen Toub [Tue, 28 Nov 2017 03:06:35 +0000 (22:06 -0500)]
Fix typo in comment in number formatting

6 years agoSwitch new TryParse* and TryFormat methods to use span-based format (#15238)
Stephen Toub [Tue, 28 Nov 2017 03:05:47 +0000 (22:05 -0500)]
Switch new TryParse* and TryFormat methods to use span-based format (#15238)

As part of this, I needed to fix-up several functions that parsed strings assuming they end with '\0', which no longer holds once we switch to using spans.

Also:
- Switched various call sites to using a cast rather than AsReadOnlySpan.
- Updated string.Format / StringBuilder.AppendFormat to use the new span-based support to avoid substring allocations.
- Removed some TODOs that were left in the codebase from some of my previous changes

6 years ago[Local GC] Move knowledge of overlapped I/O objects to the EE through four callbacks...
Sean Gillespie [Mon, 27 Nov 2017 23:41:09 +0000 (15:41 -0800)]
[Local GC] Move knowledge of overlapped I/O objects to the EE through four callbacks (#14982)

* [Local GC] Move knowledge of overlapped I/O objects to the EE through
four callbacks

* Code review feedback:
        1. Rename OverlappedData->AsyncPinned in interface methods
        2. Remove additional FEATURE_REDHAWK defines around async pin
        relocation code

* Eliminate two GCToEEInterface callbacks by passing the callbacks directly as arguments to a method on IGCHandleStore

* Repair clang build

* Split pin and async pin handle scans into two separate callbacks

* Fix the clang and non-Windows builds

6 years agoUpdate CoreClr, CoreFx, PgoData to preview1-25927-01, preview1-25927-01, master-20171...
dotnet-maestro-bot [Mon, 27 Nov 2017 20:09:42 +0000 (14:09 -0600)]
Update CoreClr, CoreFx, PgoData to preview1-25927-01, preview1-25927-01, master-20171127-0045, respectively (#15219)

6 years agoAuto-update ILAsmVersion.txt (#15199)
Michal Strehovský [Mon, 27 Nov 2017 19:49:46 +0000 (20:49 +0100)]
Auto-update ILAsmVersion.txt (#15199)

6 years agoMerge pull request #15187 from BruceForstall/FixArmTailcall
Bruce Forstall [Mon, 27 Nov 2017 19:24:59 +0000 (11:24 -0800)]
Merge pull request #15187 from BruceForstall/FixArmTailcall

Fix arm32 stub indirect tailcall

6 years agoImprove Monitor scaling (#14216)
Koundinya Veluri [Mon, 27 Nov 2017 18:28:02 +0000 (10:28 -0800)]
Improve Monitor scaling (#14216)

Improve Monitor scaling and reduce spinning

Part 1: Improve Monitor scaling

Fixes https://github.com/dotnet/coreclr/issues/13978
- Refactored AwareLock::m_MonitorHeld into a class LockState with operations to mutate the state
- Allowed the lock to be taken by a non-waiter when there is a waiter to prevent creating lock convoys
- Added a bit to LockState to indicate that a waiter is signaled to wake, to avoid waking more than one waiter at a time. A waiter that wakes by observing the signal unsets this bit. See AwareLock::EnterEpilogHelper().
- Added a spinner count to LockState. Spinners now register and unregister themselves and lock releasers don't wake a waiter when there is a registered spinner (the spinner guarantees to take the lock if it's available when unregistering itself)
  - This was necessary mostly on Windows to reduce CPU usage to the expected level in contended cases with several threads. I believe it's the priority boost Windows gives to signaled threads, which seems to cause waiters to much more frequently succeed in acquiring the lock. This causes a CPU usage problem because once the woken waiter releases the lock, on the next lock attempt it will become a spinner. This keeps repeating, converting several waiters into spinners unnecessarily. Before registering spinners, I saw typically 4-6 spinners under contention (with delays inside and outside the lock) when I expected to have only 1-2 spinners at most.
  - It costs an interlocked operation before and after the spin loop, doesn't seem to be too significant since spinning is a relatively slow path anyway, and the reduction in CPU usage in turn reduces contention on the lock and lets more useful work get done
- Updated waiters to spin a bit before going back to waiting, reasons are explained in AwareLock::EnterEpilogHelper()
- Removed AwareLock::Contention() and any references (this removes the 10 repeats of the entire spin loop in that function). With the lock convoy issue gone, this appears to no longer be necessary.

Perf
- On Windows, throughput has increased significantly starting at slightly lower than proc count threads. On Linux, latency and throughput have increased more significantly at similar proc counts.
- Most of the larger regressions are in the unlocked fast paths. The code there hasn't changed and is almost identical (minor layout differences), I'm just considering this noise until we figure out how to get consistently faster code generated.
- The smaller regressions are within noise range

Part 2: Reduce Monitor spinning

Fixes https://github.com/dotnet/coreclr/issues/13980
- Added new config value Monitor_SpinCount and Monitor spins for that many iterations, default is 30 (0x1e). This seems to give a somewhat decent balance between latency, fairness, and throughput. Lower spin counts improve latency and fairness significantly and regress throughput slightly, and higher spin counts improve throughput slightly and regress latency and fairness significantly.
  - The other constants can still be used to disable spinning but otherwise they are no longer used by Monitor
- Decreased the number of bits used for tracking spinner count to 3. This seems to be more than enough since only one thread can take a lock at a time, and prevents spikes of unnecessary CPU usage.

Tried some things that didn't pan out:
- Sleep(0) doesn't seem to add anything to the spin loop, so left it out. Instead of Sleep(0) it can just proceed to waiting. Waiting is more expensive than Sleep(0), but I didn't see that benefit in the tests. Omitting Sleep(0) also keeps the spin loop very short (a few microseconds max).
- Increasing the average YieldProcessor() duration per spin iteration improved thorughput slightly but regressed latency and fairness very quickly. Given that fairness is generally worse with part 1 of this change above, it felt like a better compromise to take a small reduction in throughput for larger improvements in latency and fairness.
- Tried adding a very small % of lock releases by random wake a waiter despite there being spinners to improve fairness. This improved fairness noticeably but not as much as decreasing the spin count slightly, and it was making latency and throughput worse more quickly. After reducing the % to a point where I was hardly seeing fairness improvements, there were still noticeable latency and throughput regressions.

Miscellaneous
- Moved YieldProcessorNormalized code into separate files so that they can be included earlier and where needed
- Added a max for "optimal max normalized yields per spin iteration" since it has a potential to be very large on machines where YieldProcessor may be implemented as no-op, in which case it's probably not worth spinning for the full duration
- Refactored duplicate code in portable versions of MonEnterWorker, MonEnter, and MonReliableEnter. MonTryEnter has a slightly different structure, did not refactor that.

Perf
- Throughput is a bit lower than before at lower thread counts and better at medium-high thread counts. It's a bit lower at lower thread counts because of two reasons:
  - Shorter spin loop means the lock will be polled more frequently because the exponential backoff does not get as high, making it more likely for a spinner to steal the lock from another thread, causing the other thread to sometimes wait early
  - The duration of YieldProcessor() calls per spin iteration has decreased and a spinner or spinning waiter are more likely to take the lock, the rest is similar to above
- For the same reasons as above, latency is better than before. Fairness is better on Windows and worse on Linux compared to baseline due to the baseline having differences between these platforms. Latency also has differences between Windows/Linux in the baseline, I suspect those are due to differences in scheduling.
- Performance now scales appropriately on processors with different pause delays

Part 3: Add mitigation for waiter starvation

Normally, threads are allowed to preempt waiters to acquire the lock. There are cases where waiters can be easily starved as a result. For example, a thread that holds a lock for a significant amount of time (much longer than the time it takes to do a context switch), then releases and reacquires the lock in quick succession, and repeats. Though a waiter would be woken upon lock release, usually it will not have enough time to context-switch-in and take the lock, and can be starved for an unreasonably long duration.

In order to prevent such starvation and force a bit of fair forward progress, it is sometimes necessary to change the normal policy and disallow threads from preempting waiters. A new bit was added to LockState and ShouldNotPreemptWaiters() indicates the current state of the policy.
- When the first waiter begins waiting, it records the current time as a "waiter starvation start time". That is a point in time after which no forward progress has occurred for waiters. When a waiter acquires the lock, the time is updated to the current time.
- Before a spinner begins spinning, and when a waiter is signaled to wake, it checks whether the starvation duration has crossed a threshold (currently 100 ms) and if so, sets ShouldNotPreemptWaiters()

When unreasonable starvation is occurring, the lock will be released occasionally and if caused by spinners, spinners will be starting to spin.
- Before starting to spin, if ShouldNotPreemptWaiters() is set, the spinner will skip spinning and wait instead. Spinners that are already registered at the time ShouldNotPreemptWaiters() is set will stop spinning as necessary. Eventually, all spinners will drain and no new ones will be registered.
- After spinners have drained, only a waiter will be able to acquire the lock. When a waiter acquires the lock, or when the last waiter unregisters itself, ShouldNotPreemptWaiters() is cleared to restore the normal policy.

6 years agoRemove excessive console output in debug builds in a set of monitor tests (#15071)
Koundinya Veluri [Mon, 27 Nov 2017 16:56:18 +0000 (08:56 -0800)]
Remove excessive console output in debug builds in a set of monitor tests (#15071)

6 years ago[x86/Linux] Enable CI unittest (#14442)
Hyeongseok Oh [Mon, 27 Nov 2017 13:30:54 +0000 (22:30 +0900)]
[x86/Linux] Enable CI unittest (#14442)

* [x86/Linux] Preparing pri2 unittest

- Copy test binary from x86 Windows build
- Copy CoreFX managed from arm CoreFX managed build
- Add archival

* Fix to merge test job generation

Change approach by expanding existing x64 & arm64 linux infrastructure

* [CI][Linux/x86] Fix configuration and architecture in netci.groovy

Fix to use configuration instead of lowerConfiguration
USe architecture and osGroup

* [CI][Linux/x86] Save test native builds in build job

Fix to save test native build in build job
Saved native builds are used on test job

6 years agoFix resx typo (#15212)
Dan Moseley [Sun, 26 Nov 2017 21:34:21 +0000 (13:34 -0800)]
Fix resx typo (#15212)

* Fix resx typo

* Reword

6 years agoFix Powershell error (#15217)
Bruce Forstall [Sun, 26 Nov 2017 15:13:04 +0000 (07:13 -0800)]
Fix Powershell error (#15217)

6 years agoRemove some dead Unix code (#15221)
Justin Van Patten [Sun, 26 Nov 2017 14:45:40 +0000 (06:45 -0800)]
Remove some dead Unix code (#15221)

Environment.ExpandEnvironmentVariables is only used by RegistryKey
inside corelib, which is only present on Windows. There's no need for a
Unix implementation.

6 years agoSimpler code (same as in String.Manipulation.cs). (#15223)
Jiri {x2} Cincura [Sun, 26 Nov 2017 14:44:54 +0000 (15:44 +0100)]
Simpler code (same as in String.Manipulation.cs). (#15223)

6 years agoSort the Action/Func delegates (#15222)
Justin Van Patten [Sun, 26 Nov 2017 13:47:32 +0000 (05:47 -0800)]
Sort the Action/Func delegates (#15222)

6 years agoUse string.Create in BitConverter.ToString(byte[]) (#15218)
Justin Van Patten [Sun, 26 Nov 2017 02:32:15 +0000 (18:32 -0800)]
Use string.Create in BitConverter.ToString(byte[]) (#15218)

Avoids unnecessary allocations and copying, and reduces the amount of unsafe code.

6 years agoUpdate CoreClr, CoreFx, PgoData to preview1-25925-02, preview1-25925-02, master-20171...
dotnet-maestro-bot [Sat, 25 Nov 2017 16:42:21 +0000 (10:42 -0600)]
Update CoreClr, CoreFx, PgoData to preview1-25925-02, preview1-25925-02, master-20171125-0056, respectively (#15210)