mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-20 00:24:58 +08:00
- Separate logic for fp16/32/46 caps. - Add aggregated constexprs for local & global caps of given type - Pass arguments by reference - Add hwInfo as argument for future refactors - Add static_asserts in L0 to ensure there is no mismatch between internal/external caps Signed-off-by: Kacper Nowak <kacper.nowak@intel.com>
23 lines
1.0 KiB
C++
23 lines
1.0 KiB
C++
/*
|
|
* 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
|