2018-11-08 13:05:46 +01:00
|
|
|
/*
|
2021-12-16 02:13:00 +00:00
|
|
|
* Copyright (C) 2018-2022 Intel Corporation
|
2018-11-08 13:05:46 +01:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-09-01 21:36:15 +02:00
|
|
|
#pragma once
|
|
|
|
|
2022-08-09 13:34:45 +00:00
|
|
|
#include "shared/source/helpers/mt_helpers.h"
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/os_interface/os_context.h"
|
2018-11-08 13:05:46 +01:00
|
|
|
|
2022-08-30 12:02:01 +00:00
|
|
|
#include <atomic>
|
2019-07-11 14:29:45 +02:00
|
|
|
#include <vector>
|
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
namespace NEO {
|
2018-11-08 13:05:46 +01:00
|
|
|
class Drm;
|
|
|
|
|
2019-02-27 11:17:17 +01:00
|
|
|
class OsContextLinux : public OsContext {
|
2018-11-08 13:05:46 +01:00
|
|
|
public:
|
2019-02-27 11:17:17 +01:00
|
|
|
OsContextLinux() = delete;
|
|
|
|
~OsContextLinux() override;
|
2021-08-11 17:36:00 +00:00
|
|
|
OsContextLinux(Drm &drm, uint32_t contextId, const EngineDescriptor &engineDescriptor);
|
2019-02-27 11:17:17 +01:00
|
|
|
|
2018-11-26 14:04:52 +01:00
|
|
|
unsigned int getEngineFlag() const { return engineFlag; }
|
2022-06-28 17:10:24 +02:00
|
|
|
void setEngineFlag(unsigned int engineFlag) { this->engineFlag = engineFlag; }
|
2019-07-17 15:38:14 +02:00
|
|
|
const std::vector<uint32_t> &getDrmContextIds() const { return drmContextIds; }
|
2020-08-17 12:07:39 +02:00
|
|
|
const std::vector<uint32_t> &getDrmVmIds() const { return drmVmIds; }
|
2022-08-30 12:02:01 +00:00
|
|
|
void setNewResourceBound() {
|
|
|
|
tlbFlushCounter++;
|
|
|
|
};
|
|
|
|
|
|
|
|
uint32_t peekTlbFlushCounter() const { return tlbFlushCounter.load(); }
|
|
|
|
|
|
|
|
void setTlbFlushed(uint32_t newCounter) {
|
2022-08-09 13:34:45 +00:00
|
|
|
NEO::MultiThreadHelpers::interlockedMax(lastFlushedTlbFlushCounter, newCounter);
|
2022-08-30 12:02:01 +00:00
|
|
|
};
|
|
|
|
bool isTlbFlushRequired() const {
|
|
|
|
return (tlbFlushCounter.load() > lastFlushedTlbFlushCounter.load());
|
|
|
|
};
|
2021-03-31 13:06:23 +00:00
|
|
|
bool isDirectSubmissionSupported(const HardwareInfo &hwInfo) const override;
|
2020-07-02 11:49:46 +02:00
|
|
|
Drm &getDrm() const;
|
2021-02-05 15:27:21 +00:00
|
|
|
void waitForPagingFence();
|
2021-08-11 17:36:00 +00:00
|
|
|
static OsContext *create(OSInterface *osInterface, uint32_t contextId, const EngineDescriptor &engineDescriptor);
|
2021-12-16 02:13:00 +00:00
|
|
|
void reInitializeContext() override;
|
2018-11-08 13:05:46 +01:00
|
|
|
|
|
|
|
protected:
|
2021-04-15 16:14:04 +00:00
|
|
|
void initializeContext() override;
|
|
|
|
|
2022-08-30 12:02:01 +00:00
|
|
|
std::atomic<uint32_t> tlbFlushCounter{0};
|
|
|
|
std::atomic<uint32_t> lastFlushedTlbFlushCounter{0};
|
2018-11-26 14:04:52 +01:00
|
|
|
unsigned int engineFlag = 0;
|
2019-07-11 14:29:45 +02:00
|
|
|
std::vector<uint32_t> drmContextIds;
|
2020-08-17 12:07:39 +02:00
|
|
|
std::vector<uint32_t> drmVmIds;
|
2018-11-08 13:05:46 +01:00
|
|
|
Drm &drm;
|
|
|
|
};
|
2019-03-26 11:59:46 +01:00
|
|
|
} // namespace NEO
|