2018-06-22 12:54:33 +02:00
|
|
|
/*
|
2022-05-04 22:10:46 +00:00
|
|
|
* Copyright (C) 2018-2022 Intel Corporation
|
2018-09-18 09:11:08 +02:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2018-06-27 11:35:37 +02:00
|
|
|
#pragma once
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/utilities/reference_tracked_object.h"
|
2018-06-22 12:54:33 +02:00
|
|
|
|
2022-09-22 08:48:55 +00:00
|
|
|
#include <unordered_map>
|
2019-11-05 13:38:20 +01:00
|
|
|
#include <vector>
|
2018-08-01 09:06:46 +02:00
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
namespace NEO {
|
2021-07-30 09:56:58 +00:00
|
|
|
class DirectSubmissionController;
|
2018-07-11 16:47:49 +02:00
|
|
|
class MemoryManager;
|
2020-03-17 07:26:46 +01:00
|
|
|
struct OsEnvironment;
|
2019-11-15 09:59:48 +01:00
|
|
|
struct RootDeviceEnvironment;
|
2018-08-21 15:47:21 +02:00
|
|
|
|
2018-06-22 12:54:33 +02:00
|
|
|
class ExecutionEnvironment : public ReferenceTrackedObject<ExecutionEnvironment> {
|
2018-07-12 11:45:02 +02:00
|
|
|
|
2018-06-27 11:35:37 +02:00
|
|
|
public:
|
2018-07-03 10:00:12 +02:00
|
|
|
ExecutionEnvironment();
|
2018-06-27 11:35:37 +02:00
|
|
|
~ExecutionEnvironment() override;
|
2018-07-23 12:23:48 +02:00
|
|
|
|
2020-09-18 16:19:41 +02:00
|
|
|
MOCKABLE_VIRTUAL bool initializeMemoryManager();
|
2019-12-17 08:11:16 +01:00
|
|
|
void calculateMaxOsContextCount();
|
2021-10-15 12:02:31 +00:00
|
|
|
virtual void prepareRootDeviceEnvironments(uint32_t numRootDevices);
|
2021-10-11 15:34:03 +00:00
|
|
|
void prepareRootDeviceEnvironment(const uint32_t rootDeviceIndexForReInit);
|
2021-01-25 09:24:00 +00:00
|
|
|
void parseAffinityMask();
|
2022-09-22 08:48:55 +00:00
|
|
|
void adjustCcsCount();
|
|
|
|
|
void adjustCcsCount(const uint32_t rootDeviceIndex) const;
|
2021-07-11 00:12:15 +00:00
|
|
|
void sortNeoDevices();
|
2022-05-04 22:10:46 +00:00
|
|
|
void sortNeoDevicesDRM();
|
|
|
|
|
void sortNeoDevicesWDDM();
|
2022-05-17 15:23:15 +00:00
|
|
|
void prepareForCleanup() const;
|
2020-11-23 14:31:20 +00:00
|
|
|
void setDebuggingEnabled() {
|
|
|
|
|
debuggingEnabled = true;
|
2020-07-13 15:14:16 +02:00
|
|
|
}
|
2020-11-23 14:31:20 +00:00
|
|
|
bool isDebuggingEnabled() { return debuggingEnabled; }
|
2021-10-25 15:33:38 +00:00
|
|
|
DirectSubmissionController *initializeDirectSubmissionController();
|
2018-07-23 12:23:48 +02:00
|
|
|
|
2018-07-11 16:47:49 +02:00
|
|
|
std::unique_ptr<MemoryManager> memoryManager;
|
2021-10-25 15:33:38 +00:00
|
|
|
std::unique_ptr<DirectSubmissionController> directSubmissionController;
|
2020-03-17 07:26:46 +01:00
|
|
|
std::unique_ptr<OsEnvironment> osEnvironment;
|
2019-11-15 09:59:48 +01:00
|
|
|
std::vector<std::unique_ptr<RootDeviceEnvironment>> rootDeviceEnvironments;
|
2021-10-11 15:34:03 +00:00
|
|
|
void releaseRootDeviceEnvironmentResources(RootDeviceEnvironment *rootDeviceEnvironment);
|
2020-07-13 15:14:16 +02:00
|
|
|
|
|
|
|
|
protected:
|
2022-09-22 08:48:55 +00:00
|
|
|
void parseCcsCountLimitations();
|
|
|
|
|
void adjustCcsCountImpl(RootDeviceEnvironment *rootDeviceEnvironment) const;
|
2020-11-23 14:31:20 +00:00
|
|
|
bool debuggingEnabled = false;
|
2022-09-22 08:48:55 +00:00
|
|
|
std::unordered_map<uint32_t, uint32_t> rootDeviceNumCcsMap;
|
2018-06-22 12:54:33 +02:00
|
|
|
};
|
2019-03-26 11:59:46 +01:00
|
|
|
} // namespace NEO
|