File: topology.h

package info (click to toggle)
intel-compute-runtime 25.35.35096.9-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 79,324 kB
  • sloc: cpp: 926,243; lisp: 3,433; sh: 715; makefile: 162; python: 21
file content (40 lines) | stat: -rw-r--r-- 934 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
 * 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);
TopologyInfo getTopologyInfoMultiTile(const std::span<TopologyBitmap> &topologyBitmap, const TopologyLimits &topologyLimits, TopologyMap &topologyMap);

} // namespace NEO