Welcome to mirror list, hosted at ThFree Co, Russian Federation.

crossIBC.ps1 « eng - github.com/dotnet/runtime.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 7eb9623b3f5e426a17f785f1dddf1c30f9734cd3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#This script is for applying IBC data to Linux binaries on Windows. This is because currently IBCMerge does not run on Linux.
#It assumes that the binary output of a Linux build will live in a directory called Linux in the root of the repo, and it leaves
#the optimized binaries in a directory called Optimized.
param(
    [Parameter(Mandatory=$true)][string]$ToolSource,
    [Parameter(Mandatory=$true)][string]$ToolUser,
    [Parameter(Mandatory=$true)][string]$ToolPAT,
    [Parameter(Mandatory=$true)][string]$RepoRoot,
    [bool]$UsePartialNgen
)

#There seems to be a bug in the optional tool restore step that causes those packages to be downloaded to the root of the drive.
#That is why we have to look in both the root and the packages directory for IBCMerge.
function Find-IBCMerge {
    $IBCMergePath = gci -recurse .\.packages | where {$_.Name.Contains("ibcmerge.exe")}
    if(!$IBCMergePath)
    {
        Write-Error -Category ResourceUnavailable "Could not find IBCMerge.exe"
        exit
    }
    $IBCMergePath.FullName
}

#Both the Preprocess-IBCMerge and Apply-IBCData are taken directly from the steps done in codeOptimization.targets
function Preprocess-IBCMerge
{
    foreach($file in gci -recurse .packages\optimization.linux-x64.ibc.corefx\*.dll)
    {
        & $IBCMerge -q -f -delete -mo $file.FullName $file.FullName.Replace(".dll", ".ibc")
        & $IBCMerge -mi $file.FullName
    }
}

function Apply-IBCData
{
    $pwd = (Get-Item -Path ".\").FullName
    foreach($file in gci -recurse .packages\optimization.linux-x64.ibc.corefx\*.dll)
    {
        #Here we look through all of the Linux binaries for the implementation dll that matches in name to the IBC data
        $fileToOptimize = gci -recurse Linux\*Linux*\*.dll | where {$_.Name.Contains($file.Name)} | where {$_.FullName.Contains("netcoreapp")}
        if(!$fileToOptimize)
        {
            $fileToOptimize = gci -recurse Linux\*Unix*\*.dll | where {$_.Name.Contains($file.Name)} | where {$_.FullName.Contains("netcoreapp")}
        }
        if(!$fileToOptimize)
        {
            $fileToOptimize = gci -recurse Linux\*AnyOS*\*.dll | where {$_.Name.Contains($file.Name)} | where {$_.FullName.Contains("netcoreapp")} | where {!$_.FullName.Contains("netfx")}
        }
        if($fileToOptimize)
        {
            if(!$UsePartialNgen)
            {
                Write-Host "$IBCMerge -q -f -mo $fileToOptimize -incremental $file"
                & $IBCMerge -q -f -mo $fileToOptimize -incremental $file
            }
            else
            {
                & $IBCMerge -q -f -mo $fileToOptimize -incremental $file -partialNGEN -minify
            }
            $copyLocation = Join-Path -Path $pwd -ChildPath "Optimized"
            Write-Host "Copy-Item $fileToOptimize -Destination $copyLocation"
            Copy-Item $fileToOptimize -Destination $copyLocation
        }
    }
}

pushd $RepoRoot
.\build.cmd -restore /p:OptionalToolSource=$ToolSource /p:OptionalToolSourceUser=$ToolUser /p:OptionalToolSourcePassword=$ToolPAT /p:EnableProfileGuidedOptimization=true /p:IBCTarget=Linux -release -ci
mkdir Optimized
$IBCMerge = Find-IBCMerge
Preprocess-IBCMerge
Apply-IBCData
popd