mirror of
https://github.com/intel/compute-runtime.git
synced 2026-01-04 15:53:45 +08:00
Class for local memory bank selection based on usage
Related-To: NEO-2906 Change-Id: I8b9cae5191da6344ee8d4f0cf7125f95d0bc6b35 Signed-off-by: Pawel Wilma <pawel.wilma@intel.com>
This commit is contained in:
34
runtime/memory_manager/local_memory_usage.h
Normal file
34
runtime/memory_manager/local_memory_usage.h
Normal file
@@ -0,0 +1,34 @@
|
||||
/*
|
||||
* Copyright (C) 2019 Intel Corporation
|
||||
*
|
||||
* SPDX-License-Identifier: MIT
|
||||
*
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "runtime/helpers/debug_helpers.h"
|
||||
#include "runtime/helpers/properties_helper.h"
|
||||
|
||||
#include <atomic>
|
||||
#include <memory>
|
||||
|
||||
namespace NEO {
|
||||
class LocalMemoryUsageBankSelector : public NonCopyableOrMovableClass {
|
||||
public:
|
||||
LocalMemoryUsageBankSelector() = delete;
|
||||
LocalMemoryUsageBankSelector(uint32_t banksCount);
|
||||
uint32_t getLeastOccupiedBank();
|
||||
void freeOnBank(uint32_t bankIndex, uint64_t allocationSize);
|
||||
void reserveOnBank(uint32_t bankIndex, uint64_t allocationSize);
|
||||
|
||||
MOCKABLE_VIRTUAL uint64_t getOccupiedMemorySizeForBank(uint32_t bankIndex) {
|
||||
UNRECOVERABLE_IF(bankIndex >= banksCount);
|
||||
return memorySizes[bankIndex].load();
|
||||
}
|
||||
|
||||
protected:
|
||||
uint32_t banksCount = 0;
|
||||
std::unique_ptr<std::atomic<uint64_t>[]> memorySizes = nullptr;
|
||||
};
|
||||
} // namespace NEO
|
||||
Reference in New Issue
Block a user