blob: 5012175a9f8517a1c16b7fd6aebacd6a464a54cd (
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
74
75
76
77
78
79
80
|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
// ===========================================================================
// File: TieredCompilation.h
//
// ===========================================================================
#ifndef TIERED_COMPILATION_H
#define TIERED_COMPILATION_H
// TieredCompilationManager determines which methods should be recompiled and
// how they should be recompiled to best optimize the running code. It then
// handles logistics of getting new code created and installed.
class TieredCompilationManager
{
#ifdef FEATURE_TIERED_COMPILATION
public:
#if defined(DACCESS_COMPILE) || defined(CROSSGEN_COMPILE)
TieredCompilationManager() {}
#else
TieredCompilationManager();
#endif
void Init();
#endif // FEATURE_TIERED_COMPILATION
public:
static NativeCodeVersion::OptimizationTier GetInitialOptimizationTier(PTR_MethodDesc pMethodDesc);
#ifdef FEATURE_TIERED_COMPILATION
public:
void OnMethodCalled(MethodDesc* pMethodDesc, bool isFirstCall, int currentCallCountLimit, BOOL* shouldStopCountingCallsRef, BOOL* wasPromotedToNextTierRef);
void OnMethodCallCountingStoppedWithoutTierPromotion(MethodDesc* pMethodDesc);
void AsyncPromoteMethodToTier1(MethodDesc* pMethodDesc);
void Shutdown();
static CORJIT_FLAGS GetJitFlags(NativeCodeVersion nativeCodeVersion);
private:
bool IsTieringDelayActive();
bool TryInitiateTieringDelay();
static void WINAPI TieringDelayTimerCallback(PVOID parameter, BOOLEAN timerFired);
static void TieringDelayTimerCallbackInAppDomain(LPVOID parameter);
void TieringDelayTimerCallbackWorker();
static void ResumeCountingCalls(MethodDesc* pMethodDesc);
bool TryAsyncOptimizeMethods();
static DWORD StaticOptimizeMethodsCallback(void* args);
void OptimizeMethodsCallback();
void OptimizeMethods();
void OptimizeMethod(NativeCodeVersion nativeCodeVersion);
NativeCodeVersion GetNextMethodToOptimize();
BOOL CompileCodeVersion(NativeCodeVersion nativeCodeVersion);
void ActivateCodeVersion(NativeCodeVersion nativeCodeVersion);
bool IncrementWorkerThreadCountIfNeeded();
void DecrementWorkerThreadCount();
#ifdef _DEBUG
DWORD DebugGetWorkerThreadCount();
#endif
Crst m_lock;
SList<SListElem<NativeCodeVersion>> m_methodsToOptimize;
UINT32 m_countOfMethodsToOptimize;
BOOL m_isAppDomainShuttingDown;
DWORD m_countOptimizationThreadsRunning;
SArray<MethodDesc*>* m_methodsPendingCountingForTier1;
HANDLE m_tieringDelayTimerHandle;
bool m_tier1CallCountingCandidateMethodRecentlyRecorded;
CLREvent m_asyncWorkDoneEvent;
#endif // FEATURE_TIERED_COMPILATION
};
#endif // TIERED_COMPILATION_H
|