2018-02-18 05:26:28 +08:00
|
|
|
/*
|
2020-02-22 16:28:27 +08:00
|
|
|
* Copyright (C) 2018-2020 Intel Corporation
|
2018-02-18 05:26:28 +08:00
|
|
|
*
|
2018-09-18 15:11:08 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2018-02-18 05:26:28 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-02-23 05:50:57 +08:00
|
|
|
#include "opencl/source/mem_obj/map_operations_handler.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/helpers/ptr_math.h"
|
2018-02-18 05:26:28 +08:00
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
using namespace NEO;
|
2018-02-18 05:26:28 +08:00
|
|
|
|
|
|
|
size_t MapOperationsHandler::size() const {
|
|
|
|
std::lock_guard<std::mutex> lock(mtx);
|
|
|
|
return mappedPointers.size();
|
|
|
|
}
|
|
|
|
|
2018-04-04 15:29:48 +08:00
|
|
|
bool MapOperationsHandler::add(void *ptr, size_t ptrLength, cl_map_flags &mapFlags, MemObjSizeArray &size, MemObjOffsetArray &offset, uint32_t mipLevel) {
|
2018-02-18 05:26:28 +08:00
|
|
|
std::lock_guard<std::mutex> lock(mtx);
|
2018-04-04 15:29:48 +08:00
|
|
|
MapInfo mapInfo(ptr, ptrLength, size, offset, mipLevel);
|
2018-02-18 05:26:28 +08:00
|
|
|
mapInfo.readOnly = (mapFlags == CL_MAP_READ);
|
|
|
|
|
|
|
|
if (isOverlapping(mapInfo)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
mappedPointers.push_back(mapInfo);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool MapOperationsHandler::isOverlapping(MapInfo &inputMapInfo) {
|
|
|
|
if (inputMapInfo.readOnly) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
auto inputStartPtr = inputMapInfo.ptr;
|
|
|
|
auto inputEndPtr = ptrOffset(inputStartPtr, inputMapInfo.ptrLength);
|
|
|
|
|
|
|
|
for (auto &mapInfo : mappedPointers) {
|
|
|
|
auto mappedStartPtr = mapInfo.ptr;
|
|
|
|
auto mappedEndPtr = ptrOffset(mappedStartPtr, mapInfo.ptrLength);
|
|
|
|
|
|
|
|
// Requested ptr starts before or inside existing ptr range and overlapping end
|
|
|
|
if (inputStartPtr < mappedEndPtr && inputEndPtr >= mappedStartPtr) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool MapOperationsHandler::find(void *mappedPtr, MapInfo &outMapInfo) {
|
|
|
|
std::lock_guard<std::mutex> lock(mtx);
|
|
|
|
|
|
|
|
for (auto &mapInfo : mappedPointers) {
|
|
|
|
if (mapInfo.ptr == mappedPtr) {
|
|
|
|
outMapInfo = mapInfo;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void MapOperationsHandler::remove(void *mappedPtr) {
|
|
|
|
std::lock_guard<std::mutex> lock(mtx);
|
|
|
|
|
|
|
|
auto endIter = mappedPointers.end();
|
|
|
|
for (auto it = mappedPointers.begin(); it != endIter; it++) {
|
|
|
|
if (it->ptr == mappedPtr) {
|
|
|
|
std::iter_swap(it, mappedPointers.end() - 1);
|
|
|
|
mappedPointers.pop_back();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|