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