* This file is part of the OpenBOAT project at Harbin Institute of Technology (HIT)
* and is contributed to the CANN Open Software.
*
* Copyright (c) 2025 AISS Group, Harbin Institute of Technology (HIT).
* All Rights Reserved.
*
* Authors (accounts):
* - Li Wen <@liwenkkklll>
* - Su Tonghua <@sutonghua>
*
* This program is free software: you can redistribute it and/or modify it.
* Licensed under the CANN Open Software License Agreement Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* See the LICENSE file at the root of the repository for the full text of the License.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTIES OF ANY KIND, EXPRESS OR IMPLIED,
* INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
*/
* \file add_v2.cpp
* \brief
*/
#include "add_v2.h"
enum class AddV2TilingKey : uint32_t
{
TILING_KEY_EXAMPLE_FLOAT = 0,
TILING_KEY_EXAMPLE_INT32 = 1,
TILING_KEY_EXAMPLE_INT16 = 2,
TILING_KEY_EXAMPLE_HALF = 3,
};
template <uint32_t schMode>
__global__ __aicore__ void add_v2(GM_ADDR x, GM_ADDR y, GM_ADDR z, GM_ADDR workspace, GM_ADDR tiling)
{
REGISTER_TILING_DEFAULT(AddV2TilingData);
GET_TILING_DATA_WITH_STRUCT(AddV2TilingData, tilingData, tiling);
if constexpr (schMode == static_cast<uint32_t>(AddV2TilingKey::TILING_KEY_EXAMPLE_FLOAT)) {
NsAddV2::AddV2<float> op;
op.Init(x, y, z, &tilingData);
op.Process();
}
else if constexpr (schMode == static_cast<uint32_t>(AddV2TilingKey::TILING_KEY_EXAMPLE_INT32)) {
NsAddV2::AddV2<int32_t> op;
op.Init(x, y, z, &tilingData);
op.Process();
}
else if constexpr (schMode == static_cast<uint32_t>(AddV2TilingKey::TILING_KEY_EXAMPLE_INT16)) {
NsAddV2::AddV2<int16_t> op;
op.Init(x, y, z, &tilingData);
op.Process();
}
else if constexpr (schMode == static_cast<uint32_t>(AddV2TilingKey::TILING_KEY_EXAMPLE_HALF)) {
NsAddV2::AddV2<half> op;
op.Init(x, y, z, &tilingData);
op.Process();
}
}