2019-06-25 19:49:46 +00:00
|
|
|
// Copyright (c) 2019 Google LLC
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
#include "source/fuzz/transformation.h"
|
|
|
|
|
|
|
|
#include <cassert>
|
|
|
|
|
2020-01-21 13:59:57 +00:00
|
|
|
#include "source/fuzz/fuzzer_util.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_add_constant_boolean.h"
|
2019-12-16 23:54:13 +00:00
|
|
|
#include "source/fuzz/transformation_add_constant_composite.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_add_constant_scalar.h"
|
2020-01-13 22:04:01 +00:00
|
|
|
#include "source/fuzz/transformation_add_dead_block.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_add_dead_break.h"
|
|
|
|
#include "source/fuzz/transformation_add_dead_continue.h"
|
2019-12-19 21:15:09 +00:00
|
|
|
#include "source/fuzz/transformation_add_function.h"
|
2019-12-16 23:54:13 +00:00
|
|
|
#include "source/fuzz/transformation_add_global_undef.h"
|
|
|
|
#include "source/fuzz/transformation_add_global_variable.h"
|
2019-10-11 08:15:47 +00:00
|
|
|
#include "source/fuzz/transformation_add_no_contraction_decoration.h"
|
2019-12-16 23:54:13 +00:00
|
|
|
#include "source/fuzz/transformation_add_type_array.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_add_type_boolean.h"
|
|
|
|
#include "source/fuzz/transformation_add_type_float.h"
|
2019-12-16 23:54:13 +00:00
|
|
|
#include "source/fuzz/transformation_add_type_function.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_add_type_int.h"
|
2019-12-16 23:54:13 +00:00
|
|
|
#include "source/fuzz/transformation_add_type_matrix.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_add_type_pointer.h"
|
2019-12-16 23:54:13 +00:00
|
|
|
#include "source/fuzz/transformation_add_type_struct.h"
|
|
|
|
#include "source/fuzz/transformation_add_type_vector.h"
|
2019-10-27 18:11:07 +00:00
|
|
|
#include "source/fuzz/transformation_composite_construct.h"
|
2019-10-28 09:33:08 +00:00
|
|
|
#include "source/fuzz/transformation_composite_extract.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_copy_object.h"
|
2019-12-12 15:27:40 +00:00
|
|
|
#include "source/fuzz/transformation_merge_blocks.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_move_block_down.h"
|
2019-12-10 14:47:42 +00:00
|
|
|
#include "source/fuzz/transformation_outline_function.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_replace_boolean_constant_with_constant_binary.h"
|
|
|
|
#include "source/fuzz/transformation_replace_constant_with_uniform.h"
|
|
|
|
#include "source/fuzz/transformation_replace_id_with_synonym.h"
|
2019-10-11 06:10:47 +00:00
|
|
|
#include "source/fuzz/transformation_set_function_control.h"
|
2019-10-10 12:34:38 +00:00
|
|
|
#include "source/fuzz/transformation_set_loop_control.h"
|
2019-10-22 17:05:35 +00:00
|
|
|
#include "source/fuzz/transformation_set_memory_operands_mask.h"
|
2019-10-10 10:26:51 +00:00
|
|
|
#include "source/fuzz/transformation_set_selection_control.h"
|
|
|
|
#include "source/fuzz/transformation_split_block.h"
|
2019-11-06 17:11:54 +00:00
|
|
|
#include "source/fuzz/transformation_vector_shuffle.h"
|
2019-06-25 19:49:46 +00:00
|
|
|
#include "source/util/make_unique.h"
|
|
|
|
|
|
|
|
namespace spvtools {
|
|
|
|
namespace fuzz {
|
|
|
|
|
|
|
|
Transformation::~Transformation() = default;
|
|
|
|
|
|
|
|
std::unique_ptr<Transformation> Transformation::FromMessage(
|
|
|
|
const protobufs::Transformation& message) {
|
|
|
|
switch (message.transformation_case()) {
|
|
|
|
case protobufs::Transformation::TransformationCase::kAddConstantBoolean:
|
|
|
|
return MakeUnique<TransformationAddConstantBoolean>(
|
|
|
|
message.add_constant_boolean());
|
2019-12-16 23:54:13 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddConstantComposite:
|
|
|
|
return MakeUnique<TransformationAddConstantComposite>(
|
|
|
|
message.add_constant_composite());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddConstantScalar:
|
|
|
|
return MakeUnique<TransformationAddConstantScalar>(
|
|
|
|
message.add_constant_scalar());
|
2020-01-13 22:04:01 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddDeadBlock:
|
|
|
|
return MakeUnique<TransformationAddDeadBlock>(message.add_dead_block());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddDeadBreak:
|
|
|
|
return MakeUnique<TransformationAddDeadBreak>(message.add_dead_break());
|
2019-07-25 12:50:33 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddDeadContinue:
|
|
|
|
return MakeUnique<TransformationAddDeadContinue>(
|
|
|
|
message.add_dead_continue());
|
2019-12-19 21:15:09 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddFunction:
|
|
|
|
return MakeUnique<TransformationAddFunction>(message.add_function());
|
2019-12-16 23:54:13 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddGlobalUndef:
|
|
|
|
return MakeUnique<TransformationAddGlobalUndef>(
|
|
|
|
message.add_global_undef());
|
|
|
|
case protobufs::Transformation::TransformationCase::kAddGlobalVariable:
|
|
|
|
return MakeUnique<TransformationAddGlobalVariable>(
|
|
|
|
message.add_global_variable());
|
2019-10-11 08:15:47 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::
|
|
|
|
kAddNoContractionDecoration:
|
|
|
|
return MakeUnique<TransformationAddNoContractionDecoration>(
|
|
|
|
message.add_no_contraction_decoration());
|
2019-12-16 23:54:13 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeArray:
|
|
|
|
return MakeUnique<TransformationAddTypeArray>(message.add_type_array());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeBoolean:
|
|
|
|
return MakeUnique<TransformationAddTypeBoolean>(
|
|
|
|
message.add_type_boolean());
|
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeFloat:
|
|
|
|
return MakeUnique<TransformationAddTypeFloat>(message.add_type_float());
|
2019-12-16 23:54:13 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeFunction:
|
|
|
|
return MakeUnique<TransformationAddTypeFunction>(
|
|
|
|
message.add_type_function());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeInt:
|
|
|
|
return MakeUnique<TransformationAddTypeInt>(message.add_type_int());
|
2019-12-16 23:54:13 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeMatrix:
|
|
|
|
return MakeUnique<TransformationAddTypeMatrix>(message.add_type_matrix());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypePointer:
|
|
|
|
return MakeUnique<TransformationAddTypePointer>(
|
|
|
|
message.add_type_pointer());
|
2019-12-16 23:54:13 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeStruct:
|
|
|
|
return MakeUnique<TransformationAddTypeStruct>(message.add_type_struct());
|
|
|
|
case protobufs::Transformation::TransformationCase::kAddTypeVector:
|
|
|
|
return MakeUnique<TransformationAddTypeVector>(message.add_type_vector());
|
2019-10-27 18:11:07 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kCompositeConstruct:
|
|
|
|
return MakeUnique<TransformationCompositeConstruct>(
|
|
|
|
message.composite_construct());
|
2019-10-28 09:33:08 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kCompositeExtract:
|
|
|
|
return MakeUnique<TransformationCompositeExtract>(
|
|
|
|
message.composite_extract());
|
2019-09-11 22:45:20 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kCopyObject:
|
|
|
|
return MakeUnique<TransformationCopyObject>(message.copy_object());
|
2019-12-12 15:27:40 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kMergeBlocks:
|
|
|
|
return MakeUnique<TransformationMergeBlocks>(message.merge_blocks());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kMoveBlockDown:
|
|
|
|
return MakeUnique<TransformationMoveBlockDown>(message.move_block_down());
|
2019-12-10 14:47:42 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kOutlineFunction:
|
|
|
|
return MakeUnique<TransformationOutlineFunction>(
|
|
|
|
message.outline_function());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::
|
|
|
|
kReplaceBooleanConstantWithConstantBinary:
|
|
|
|
return MakeUnique<TransformationReplaceBooleanConstantWithConstantBinary>(
|
|
|
|
message.replace_boolean_constant_with_constant_binary());
|
|
|
|
case protobufs::Transformation::TransformationCase::
|
|
|
|
kReplaceConstantWithUniform:
|
|
|
|
return MakeUnique<TransformationReplaceConstantWithUniform>(
|
|
|
|
message.replace_constant_with_uniform());
|
2019-09-18 19:47:08 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kReplaceIdWithSynonym:
|
|
|
|
return MakeUnique<TransformationReplaceIdWithSynonym>(
|
|
|
|
message.replace_id_with_synonym());
|
2019-10-11 06:10:47 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kSetFunctionControl:
|
|
|
|
return MakeUnique<TransformationSetFunctionControl>(
|
|
|
|
message.set_function_control());
|
2019-10-10 12:34:38 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kSetLoopControl:
|
|
|
|
return MakeUnique<TransformationSetLoopControl>(
|
|
|
|
message.set_loop_control());
|
2019-10-22 17:05:35 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kSetMemoryOperandsMask:
|
|
|
|
return MakeUnique<TransformationSetMemoryOperandsMask>(
|
|
|
|
message.set_memory_operands_mask());
|
2019-10-08 10:25:34 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kSetSelectionControl:
|
|
|
|
return MakeUnique<TransformationSetSelectionControl>(
|
|
|
|
message.set_selection_control());
|
2019-06-25 19:49:46 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kSplitBlock:
|
|
|
|
return MakeUnique<TransformationSplitBlock>(message.split_block());
|
2019-11-06 17:11:54 +00:00
|
|
|
case protobufs::Transformation::TransformationCase::kVectorShuffle:
|
|
|
|
return MakeUnique<TransformationVectorShuffle>(message.vector_shuffle());
|
2019-09-11 22:45:20 +00:00
|
|
|
case protobufs::Transformation::TRANSFORMATION_NOT_SET:
|
2019-06-25 19:49:46 +00:00
|
|
|
assert(false && "An unset transformation was encountered.");
|
|
|
|
return nullptr;
|
|
|
|
}
|
2019-09-11 22:45:20 +00:00
|
|
|
assert(false && "Should be unreachable as all cases must be handled above.");
|
|
|
|
return nullptr;
|
2019-06-25 19:49:46 +00:00
|
|
|
}
|
|
|
|
|
2020-01-21 13:59:57 +00:00
|
|
|
bool Transformation::CheckIdIsFreshAndNotUsedByThisTransformation(
|
|
|
|
uint32_t id, opt::IRContext* context,
|
|
|
|
std::set<uint32_t>* ids_used_by_this_transformation) {
|
|
|
|
if (!fuzzerutil::IsFreshId(context, id)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (ids_used_by_this_transformation->count(id) != 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
ids_used_by_this_transformation->insert(id);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2019-06-25 19:49:46 +00:00
|
|
|
} // namespace fuzz
|
|
|
|
} // namespace spvtools
|