2019-11-08 01:49:46 +08:00
|
|
|
/*
|
2022-05-18 03:04:23 +08:00
|
|
|
* Copyright (C) 2019-2022 Intel Corporation
|
2019-11-08 01:49:46 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2022-05-18 03:04:23 +08:00
|
|
|
#pragma once
|
|
|
|
|
2019-11-08 01:49:46 +08:00
|
|
|
#include <cstddef>
|
|
|
|
#include <cstdint>
|
|
|
|
|
|
|
|
namespace NEO {
|
|
|
|
|
|
|
|
struct KernelHelper {
|
|
|
|
static uint32_t getMaxWorkGroupCount(uint32_t simd, uint32_t availableThreadCount, uint32_t dssCount, uint32_t availableSlmSize,
|
|
|
|
uint32_t usedSlmSize, uint32_t maxBarrierCount, uint32_t numberOfBarriers, uint32_t workDim,
|
|
|
|
const size_t *localWorkSize);
|
2020-10-13 19:14:51 +08:00
|
|
|
|
2020-10-05 01:18:49 +08:00
|
|
|
static uint64_t getPrivateSurfaceSize(uint64_t perHwThreadPrivateMemorySize, uint32_t computeUnitsUsedForScratch) {
|
|
|
|
return perHwThreadPrivateMemorySize * computeUnitsUsedForScratch;
|
2020-10-13 19:14:51 +08:00
|
|
|
}
|
2019-11-08 01:49:46 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace NEO
|