xref: /aosp_15_r20/external/swiftshader/src/System/SwiftConfig.hpp (revision 03ce13f70fcc45d86ee91b7ee4cab1936a95046e)
1*03ce13f7SAndroid Build Coastguard Worker // Copyright 2022 The SwiftShader Authors. All Rights Reserved.
2*03ce13f7SAndroid Build Coastguard Worker //
3*03ce13f7SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
4*03ce13f7SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
5*03ce13f7SAndroid Build Coastguard Worker // You may obtain a copy of the License at
6*03ce13f7SAndroid Build Coastguard Worker //
7*03ce13f7SAndroid Build Coastguard Worker //    http://www.apache.org/licenses/LICENSE-2.0
8*03ce13f7SAndroid Build Coastguard Worker //
9*03ce13f7SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*03ce13f7SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
11*03ce13f7SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*03ce13f7SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
13*03ce13f7SAndroid Build Coastguard Worker // limitations under the License.
14*03ce13f7SAndroid Build Coastguard Worker 
15*03ce13f7SAndroid Build Coastguard Worker #ifndef sw_SwiftConfig_hpp
16*03ce13f7SAndroid Build Coastguard Worker #define sw_SwiftConfig_hpp
17*03ce13f7SAndroid Build Coastguard Worker 
18*03ce13f7SAndroid Build Coastguard Worker #include "Reactor/Nucleus.hpp"
19*03ce13f7SAndroid Build Coastguard Worker #include "marl/scheduler.h"
20*03ce13f7SAndroid Build Coastguard Worker 
21*03ce13f7SAndroid Build Coastguard Worker #include <stdint.h>
22*03ce13f7SAndroid Build Coastguard Worker 
23*03ce13f7SAndroid Build Coastguard Worker namespace sw {
24*03ce13f7SAndroid Build Coastguard Worker 
25*03ce13f7SAndroid Build Coastguard Worker struct Configuration
26*03ce13f7SAndroid Build Coastguard Worker {
27*03ce13f7SAndroid Build Coastguard Worker 	enum class AffinityPolicy : int
28*03ce13f7SAndroid Build Coastguard Worker 	{
29*03ce13f7SAndroid Build Coastguard Worker 		// A thread has affinity with any core in the affinity mask.
30*03ce13f7SAndroid Build Coastguard Worker 		AnyOf = 0,
31*03ce13f7SAndroid Build Coastguard Worker 		// A thread has affinity with a single core in the affinity mask.
32*03ce13f7SAndroid Build Coastguard Worker 		OneOf = 1,
33*03ce13f7SAndroid Build Coastguard Worker 	};
34*03ce13f7SAndroid Build Coastguard Worker 
35*03ce13f7SAndroid Build Coastguard Worker 	// -------- [Processor] --------
36*03ce13f7SAndroid Build Coastguard Worker 	// Number of threads used by the scheduler. A thread count of 0 is
37*03ce13f7SAndroid Build Coastguard Worker 	// interpreted as min(cpu_cores_available, 16).
38*03ce13f7SAndroid Build Coastguard Worker 	uint32_t threadCount = 0;
39*03ce13f7SAndroid Build Coastguard Worker 
40*03ce13f7SAndroid Build Coastguard Worker 	// Core affinity and affinity policy used by the scheduler.
41*03ce13f7SAndroid Build Coastguard Worker 	uint64_t affinityMask = 0xFFFFFFFFFFFFFFFFu;
42*03ce13f7SAndroid Build Coastguard Worker 	AffinityPolicy affinityPolicy = AffinityPolicy::AnyOf;
43*03ce13f7SAndroid Build Coastguard Worker 
44*03ce13f7SAndroid Build Coastguard Worker 	// -------- [Profiler] --------
45*03ce13f7SAndroid Build Coastguard Worker 	// Whether SPIR-V profiling is enabled.
46*03ce13f7SAndroid Build Coastguard Worker 	bool enableSpirvProfiling = false;
47*03ce13f7SAndroid Build Coastguard Worker 	// Period controlling how often SPIR-V profiles are reported.
48*03ce13f7SAndroid Build Coastguard Worker 	uint64_t spvProfilingReportPeriodMs = 1000;
49*03ce13f7SAndroid Build Coastguard Worker 	// Directory where SPIR-V profile reports will be written.
50*03ce13f7SAndroid Build Coastguard Worker 	std::string spvProfilingReportDir = "";
51*03ce13f7SAndroid Build Coastguard Worker };
52*03ce13f7SAndroid Build Coastguard Worker 
53*03ce13f7SAndroid Build Coastguard Worker // Get the configuration as parsed from a configuration file.
54*03ce13f7SAndroid Build Coastguard Worker const Configuration &getConfiguration();
55*03ce13f7SAndroid Build Coastguard Worker 
56*03ce13f7SAndroid Build Coastguard Worker // Get the scheduler configuration given a configuration.
57*03ce13f7SAndroid Build Coastguard Worker marl::Scheduler::Config getSchedulerConfiguration(const Configuration &config);
58*03ce13f7SAndroid Build Coastguard Worker 
59*03ce13f7SAndroid Build Coastguard Worker }  // namespace sw
60*03ce13f7SAndroid Build Coastguard Worker 
61*03ce13f7SAndroid Build Coastguard Worker #endif
62