Compare commits
3 Commits
interval-z
...
atomicops-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
35297201dc | ||
|
|
5ccdeb33ff | ||
|
|
b4f7f64c5f |
@@ -1,3 +1,6 @@
|
|||||||
|
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
@@ -9,21 +12,23 @@
|
|||||||
namespace Shader::Maxwell {
|
namespace Shader::Maxwell {
|
||||||
namespace {
|
namespace {
|
||||||
enum class Type : u64 {
|
enum class Type : u64 {
|
||||||
_1D,
|
_1D = 0,
|
||||||
BUFFER_1D,
|
_1D_BUFFER = 1,
|
||||||
ARRAY_1D,
|
_1D_ARRAY = 2,
|
||||||
_2D,
|
_2D = 3,
|
||||||
ARRAY_2D,
|
_2D_ARRAY = 4,
|
||||||
_3D,
|
_3D = 5,
|
||||||
|
_UNK6 = 6,
|
||||||
|
_UNK7 = 7,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class Size : u64 {
|
enum class Size : u64 {
|
||||||
U32,
|
U32,
|
||||||
S32,
|
S32,
|
||||||
U64,
|
U64,
|
||||||
S64,
|
|
||||||
F32FTZRN,
|
F32FTZRN,
|
||||||
F16x2FTZRN,
|
F16x2FTZRN,
|
||||||
|
S64,
|
||||||
SD32,
|
SD32,
|
||||||
SD64,
|
SD64,
|
||||||
};
|
};
|
||||||
@@ -50,33 +55,33 @@ TextureType GetType(Type type) {
|
|||||||
switch (type) {
|
switch (type) {
|
||||||
case Type::_1D:
|
case Type::_1D:
|
||||||
return TextureType::Color1D;
|
return TextureType::Color1D;
|
||||||
case Type::BUFFER_1D:
|
case Type::_1D_BUFFER:
|
||||||
return TextureType::Buffer;
|
return TextureType::Buffer;
|
||||||
case Type::ARRAY_1D:
|
case Type::_1D_ARRAY:
|
||||||
return TextureType::ColorArray1D;
|
return TextureType::ColorArray1D;
|
||||||
case Type::_2D:
|
case Type::_2D:
|
||||||
return TextureType::Color2D;
|
return TextureType::Color2D;
|
||||||
case Type::ARRAY_2D:
|
case Type::_2D_ARRAY:
|
||||||
return TextureType::ColorArray2D;
|
return TextureType::ColorArray2D;
|
||||||
case Type::_3D:
|
case Type::_3D:
|
||||||
return TextureType::Color3D;
|
return TextureType::Color3D;
|
||||||
|
default:
|
||||||
|
throw NotImplementedException("Invalid type {}", type);
|
||||||
}
|
}
|
||||||
throw NotImplementedException("Invalid type {}", type);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
IR::Value MakeCoords(TranslatorVisitor& v, IR::Reg reg, Type type) {
|
IR::Value MakeCoords(TranslatorVisitor& v, IR::Reg reg, Type type) {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case Type::_1D:
|
case Type::_1D:
|
||||||
case Type::BUFFER_1D:
|
case Type::_1D_BUFFER:
|
||||||
return v.X(reg);
|
return v.X(reg);
|
||||||
case Type::_2D:
|
case Type::_2D:
|
||||||
return v.ir.CompositeConstruct(v.X(reg), v.X(reg + 1));
|
return v.ir.CompositeConstruct(v.X(reg), v.X(reg + 1));
|
||||||
case Type::_3D:
|
case Type::_3D:
|
||||||
return v.ir.CompositeConstruct(v.X(reg), v.X(reg + 1), v.X(reg + 2));
|
return v.ir.CompositeConstruct(v.X(reg), v.X(reg + 1), v.X(reg + 2));
|
||||||
default:
|
default:
|
||||||
break;
|
throw NotImplementedException("Invalid type {}", type);
|
||||||
}
|
}
|
||||||
throw NotImplementedException("Invalid type {}", type);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
IR::Value ApplyAtomicOp(IR::IREmitter& ir, const IR::U32& handle, const IR::Value& coords,
|
IR::Value ApplyAtomicOp(IR::IREmitter& ir, const IR::U32& handle, const IR::Value& coords,
|
||||||
|
|||||||
Reference in New Issue
Block a user