File: kernel_properties.h

package info (click to toggle)
intel-compute-runtime 25.44.36015.8-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 79,632 kB
  • sloc: cpp: 931,547; lisp: 2,074; sh: 719; makefile: 162; python: 21
file content (22 lines) | stat: -rw-r--r-- 1,070 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/*
 * Copyright (C) 2021-2024 Intel Corporation
 *
 * SPDX-License-Identifier: MIT
 *
 */

#pragma once

#include <cstdint>
namespace FpAtomicExtFlags {
inline constexpr uint64_t globalLoadStore = 1 << 0; // Supports atomic load, store, and exchange
inline constexpr uint64_t globalAdd = 1 << 1;       // Supports atomic add and subtract
inline constexpr uint64_t globalMinMax = 1 << 2;    // Supports atomic min and max
inline constexpr uint64_t localLoadStore = 1 << 16; // Supports atomic load, store, and exchange
inline constexpr uint64_t localAdd = 1 << 17;       // Supports atomic add and subtract
inline constexpr uint64_t localMinMax = 1 << 18;    // Supports atomic min and max

inline constexpr uint32_t loadStoreAtomicCaps = (0u | FpAtomicExtFlags::globalLoadStore | FpAtomicExtFlags::localLoadStore);
inline constexpr uint32_t minMaxAtomicCaps = (0u | FpAtomicExtFlags::globalMinMax | FpAtomicExtFlags::localMinMax);
inline constexpr uint32_t addAtomicCaps = (0u | FpAtomicExtFlags::globalAdd | FpAtomicExtFlags::localAdd);
} // namespace FpAtomicExtFlags