2025-08-05 22:33:38 +00:00
|
|
|
/*
|
|
|
|
|
* Copyright (C) 2025 Intel Corporation
|
|
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include "shared/source/helpers/topology_map.h"
|
|
|
|
|
|
|
|
|
|
#include <cstdint>
|
|
|
|
|
#include <span>
|
|
|
|
|
|
|
|
|
|
namespace NEO {
|
|
|
|
|
|
|
|
|
|
struct TopologyBitmap {
|
|
|
|
|
std::span<const uint8_t> dssGeometry;
|
|
|
|
|
std::span<const uint8_t> dssCompute;
|
|
|
|
|
std::span<const uint8_t> l3Banks;
|
|
|
|
|
std::span<const uint8_t> eu; // shared by all subslices
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct TopologyInfo {
|
|
|
|
|
int sliceCount;
|
|
|
|
|
int subSliceCount;
|
|
|
|
|
int euCount;
|
|
|
|
|
int l3BankCount;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct TopologyLimits {
|
|
|
|
|
int maxSlices;
|
|
|
|
|
int maxSubSlicesPerSlice;
|
|
|
|
|
int maxEusPerSubSlice;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
TopologyInfo getTopologyInfo(const TopologyBitmap &topologyBitmap, const TopologyLimits &topologyLimits, TopologyMapping &topologyMapping);
|
2025-09-10 17:20:59 +00:00
|
|
|
TopologyInfo getTopologyInfoMultiTile(std::span<const TopologyBitmap> topologyBitmap, const TopologyLimits &topologyLimits, TopologyMap &topologyMap);
|
2025-08-05 22:33:38 +00:00
|
|
|
|
|
|
|
|
} // namespace NEO
|