sirit/src/instructions/memory.cpp

75 lines
2.7 KiB
C++
Raw Normal View History

2018-10-18 09:27:17 +02:00
/* This file is part of the sirit project.
2019-07-14 23:48:59 +02:00
* Copyright (c) 2019 sirit
* This software may be used and distributed according to the terms of the
* 3-Clause BSD License
2018-10-18 09:27:17 +02:00
*/
2019-03-11 07:26:21 +01:00
#include <cassert>
2018-10-18 09:27:17 +02:00
#include "sirit/sirit.h"
#include "stream.h"
2018-10-18 09:27:17 +02:00
namespace Sirit {
2018-10-18 09:27:17 +02:00
2020-06-02 07:13:37 +02:00
Id Module::OpImageTexelPointer(Id result_type, Id image, Id coordinate, Id sample) {
code->Reserve(6);
return *code << OpId{spv::Op::OpImageTexelPointer, result_type} << image << coordinate << sample
<< EndOp{};
2020-06-02 07:13:37 +02:00
}
2019-03-11 07:26:21 +01:00
Id Module::OpLoad(Id result_type, Id pointer, std::optional<spv::MemoryAccessMask> memory_access) {
code->Reserve(5);
return *code << OpId{spv::Op::OpLoad, result_type} << pointer << memory_access << EndOp{};
2018-10-31 08:16:26 +01:00
}
2019-03-11 07:26:21 +01:00
Id Module::OpStore(Id pointer, Id object, std::optional<spv::MemoryAccessMask> memory_access) {
code->Reserve(4);
return *code << spv::Op::OpStore << pointer << object << memory_access << EndOp{};
2018-10-31 09:05:06 +01:00
}
2020-07-29 10:46:50 +02:00
Id Module::OpAccessChain(Id result_type, Id base, std::span<const Id> indexes) {
assert(!indexes.empty());
code->Reserve(4 + indexes.size());
return *code << OpId{spv::Op::OpAccessChain, result_type} << base << indexes << EndOp{};
2018-10-31 07:37:36 +01:00
}
Id Module::OpVectorExtractDynamic(Id result_type, Id vector, Id index) {
code->Reserve(5);
return *code << OpId{spv::Op::OpVectorExtractDynamic, result_type} << vector << index
<< EndOp{};
}
Id Module::OpVectorInsertDynamic(Id result_type, Id vector, Id component, Id index) {
code->Reserve(6);
return *code << OpId{spv::Op::OpVectorInsertDynamic, result_type} << vector << component
<< index << EndOp{};
}
2022-11-06 20:02:05 +01:00
Id Module::OpVectorShuffle(Id result_type, Id vector_1, Id vector_2, std::span<const Literal> components) {
code->Reserve(5 + components.size());
return *code << OpId{spv::Op::OpVectorShuffle, result_type} << vector_1 << vector_2
<< components << EndOp{};
}
2018-11-01 02:20:49 +01:00
Id Module::OpCompositeInsert(Id result_type, Id object, Id composite,
2020-07-29 10:46:50 +02:00
std::span<const Literal> indexes) {
code->Reserve(5 + indexes.size());
return *code << OpId{spv::Op::OpCompositeInsert, result_type} << object << composite << indexes
<< EndOp{};
2018-10-31 09:05:06 +01:00
}
2020-07-29 10:46:50 +02:00
Id Module::OpCompositeExtract(Id result_type, Id composite, std::span<const Literal> indexes) {
code->Reserve(4 + indexes.size());
return *code << OpId{spv::Op::OpCompositeExtract, result_type} << composite << indexes
<< EndOp{};
2018-11-04 00:41:03 +01:00
}
2020-07-29 10:46:50 +02:00
Id Module::OpCompositeConstruct(Id result_type, std::span<const Id> ids) {
2018-11-04 06:38:13 +01:00
assert(ids.size() >= 1);
code->Reserve(3 + ids.size());
return *code << OpId{spv::Op::OpCompositeConstruct, result_type} << ids << EndOp{};
2018-11-04 06:38:13 +01:00
}
2018-10-18 09:27:17 +02:00
} // namespace Sirit