| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272 |
- // 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>
- #include "source/fuzz/fuzzer_util.h"
- #include "source/fuzz/transformation_access_chain.h"
- #include "source/fuzz/transformation_add_constant_boolean.h"
- #include "source/fuzz/transformation_add_constant_composite.h"
- #include "source/fuzz/transformation_add_constant_null.h"
- #include "source/fuzz/transformation_add_constant_scalar.h"
- #include "source/fuzz/transformation_add_copy_memory.h"
- #include "source/fuzz/transformation_add_dead_block.h"
- #include "source/fuzz/transformation_add_dead_break.h"
- #include "source/fuzz/transformation_add_dead_continue.h"
- #include "source/fuzz/transformation_add_function.h"
- #include "source/fuzz/transformation_add_global_undef.h"
- #include "source/fuzz/transformation_add_global_variable.h"
- #include "source/fuzz/transformation_add_image_sample_unused_components.h"
- #include "source/fuzz/transformation_add_local_variable.h"
- #include "source/fuzz/transformation_add_no_contraction_decoration.h"
- #include "source/fuzz/transformation_add_parameter.h"
- #include "source/fuzz/transformation_add_spec_constant_op.h"
- #include "source/fuzz/transformation_add_type_array.h"
- #include "source/fuzz/transformation_add_type_boolean.h"
- #include "source/fuzz/transformation_add_type_float.h"
- #include "source/fuzz/transformation_add_type_function.h"
- #include "source/fuzz/transformation_add_type_int.h"
- #include "source/fuzz/transformation_add_type_matrix.h"
- #include "source/fuzz/transformation_add_type_pointer.h"
- #include "source/fuzz/transformation_add_type_struct.h"
- #include "source/fuzz/transformation_add_type_vector.h"
- #include "source/fuzz/transformation_adjust_branch_weights.h"
- #include "source/fuzz/transformation_composite_construct.h"
- #include "source/fuzz/transformation_composite_extract.h"
- #include "source/fuzz/transformation_compute_data_synonym_fact_closure.h"
- #include "source/fuzz/transformation_copy_object.h"
- #include "source/fuzz/transformation_equation_instruction.h"
- #include "source/fuzz/transformation_function_call.h"
- #include "source/fuzz/transformation_invert_comparison_operator.h"
- #include "source/fuzz/transformation_load.h"
- #include "source/fuzz/transformation_merge_blocks.h"
- #include "source/fuzz/transformation_move_block_down.h"
- #include "source/fuzz/transformation_outline_function.h"
- #include "source/fuzz/transformation_permute_function_parameters.h"
- #include "source/fuzz/transformation_permute_phi_operands.h"
- #include "source/fuzz/transformation_push_id_through_variable.h"
- #include "source/fuzz/transformation_record_synonymous_constants.h"
- #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"
- #include "source/fuzz/transformation_replace_linear_algebra_instruction.h"
- #include "source/fuzz/transformation_replace_parameter_with_global.h"
- #include "source/fuzz/transformation_set_function_control.h"
- #include "source/fuzz/transformation_set_loop_control.h"
- #include "source/fuzz/transformation_set_memory_operands_mask.h"
- #include "source/fuzz/transformation_set_selection_control.h"
- #include "source/fuzz/transformation_split_block.h"
- #include "source/fuzz/transformation_store.h"
- #include "source/fuzz/transformation_swap_commutable_operands.h"
- #include "source/fuzz/transformation_swap_conditional_branch_operands.h"
- #include "source/fuzz/transformation_toggle_access_chain_instruction.h"
- #include "source/fuzz/transformation_vector_shuffle.h"
- #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::kAccessChain:
- return MakeUnique<TransformationAccessChain>(message.access_chain());
- case protobufs::Transformation::TransformationCase::kAddConstantBoolean:
- return MakeUnique<TransformationAddConstantBoolean>(
- message.add_constant_boolean());
- case protobufs::Transformation::TransformationCase::kAddConstantComposite:
- return MakeUnique<TransformationAddConstantComposite>(
- message.add_constant_composite());
- case protobufs::Transformation::TransformationCase::kAddConstantNull:
- return MakeUnique<TransformationAddConstantNull>(
- message.add_constant_null());
- case protobufs::Transformation::TransformationCase::kAddConstantScalar:
- return MakeUnique<TransformationAddConstantScalar>(
- message.add_constant_scalar());
- case protobufs::Transformation::TransformationCase::kAddCopyMemory:
- return MakeUnique<TransformationAddCopyMemory>(message.add_copy_memory());
- case protobufs::Transformation::TransformationCase::kAddDeadBlock:
- return MakeUnique<TransformationAddDeadBlock>(message.add_dead_block());
- case protobufs::Transformation::TransformationCase::kAddDeadBreak:
- return MakeUnique<TransformationAddDeadBreak>(message.add_dead_break());
- case protobufs::Transformation::TransformationCase::kAddDeadContinue:
- return MakeUnique<TransformationAddDeadContinue>(
- message.add_dead_continue());
- case protobufs::Transformation::TransformationCase::kAddFunction:
- return MakeUnique<TransformationAddFunction>(message.add_function());
- case protobufs::Transformation::TransformationCase::kAddGlobalUndef:
- return MakeUnique<TransformationAddGlobalUndef>(
- message.add_global_undef());
- case protobufs::Transformation::TransformationCase::kAddGlobalVariable:
- return MakeUnique<TransformationAddGlobalVariable>(
- message.add_global_variable());
- case protobufs::Transformation::TransformationCase::
- kAddImageSampleUnusedComponents:
- return MakeUnique<TransformationAddImageSampleUnusedComponents>(
- message.add_image_sample_unused_components());
- case protobufs::Transformation::TransformationCase::kAddLocalVariable:
- return MakeUnique<TransformationAddLocalVariable>(
- message.add_local_variable());
- case protobufs::Transformation::TransformationCase::
- kAddNoContractionDecoration:
- return MakeUnique<TransformationAddNoContractionDecoration>(
- message.add_no_contraction_decoration());
- case protobufs::Transformation::TransformationCase::kAddParameter:
- return MakeUnique<TransformationAddParameter>(message.add_parameter());
- case protobufs::Transformation::TransformationCase::kAddSpecConstantOp:
- return MakeUnique<TransformationAddSpecConstantOp>(
- message.add_spec_constant_op());
- case protobufs::Transformation::TransformationCase::kAddTypeArray:
- return MakeUnique<TransformationAddTypeArray>(message.add_type_array());
- case protobufs::Transformation::TransformationCase::kAddTypeBoolean:
- return MakeUnique<TransformationAddTypeBoolean>(
- message.add_type_boolean());
- case protobufs::Transformation::TransformationCase::kAddTypeFloat:
- return MakeUnique<TransformationAddTypeFloat>(message.add_type_float());
- case protobufs::Transformation::TransformationCase::kAddTypeFunction:
- return MakeUnique<TransformationAddTypeFunction>(
- message.add_type_function());
- case protobufs::Transformation::TransformationCase::kAddTypeInt:
- return MakeUnique<TransformationAddTypeInt>(message.add_type_int());
- case protobufs::Transformation::TransformationCase::kAddTypeMatrix:
- return MakeUnique<TransformationAddTypeMatrix>(message.add_type_matrix());
- case protobufs::Transformation::TransformationCase::kAddTypePointer:
- return MakeUnique<TransformationAddTypePointer>(
- message.add_type_pointer());
- case protobufs::Transformation::TransformationCase::kAddTypeStruct:
- return MakeUnique<TransformationAddTypeStruct>(message.add_type_struct());
- case protobufs::Transformation::TransformationCase::kAddTypeVector:
- return MakeUnique<TransformationAddTypeVector>(message.add_type_vector());
- case protobufs::Transformation::TransformationCase::kAdjustBranchWeights:
- return MakeUnique<TransformationAdjustBranchWeights>(
- message.adjust_branch_weights());
- case protobufs::Transformation::TransformationCase::kCompositeConstruct:
- return MakeUnique<TransformationCompositeConstruct>(
- message.composite_construct());
- case protobufs::Transformation::TransformationCase::kCompositeExtract:
- return MakeUnique<TransformationCompositeExtract>(
- message.composite_extract());
- case protobufs::Transformation::TransformationCase::
- kComputeDataSynonymFactClosure:
- return MakeUnique<TransformationComputeDataSynonymFactClosure>(
- message.compute_data_synonym_fact_closure());
- case protobufs::Transformation::TransformationCase::kCopyObject:
- return MakeUnique<TransformationCopyObject>(message.copy_object());
- case protobufs::Transformation::TransformationCase::kEquationInstruction:
- return MakeUnique<TransformationEquationInstruction>(
- message.equation_instruction());
- case protobufs::Transformation::TransformationCase::kFunctionCall:
- return MakeUnique<TransformationFunctionCall>(message.function_call());
- case protobufs::Transformation::TransformationCase::
- kInvertComparisonOperator:
- return MakeUnique<TransformationInvertComparisonOperator>(
- message.invert_comparison_operator());
- case protobufs::Transformation::TransformationCase::kLoad:
- return MakeUnique<TransformationLoad>(message.load());
- case protobufs::Transformation::TransformationCase::kMergeBlocks:
- return MakeUnique<TransformationMergeBlocks>(message.merge_blocks());
- case protobufs::Transformation::TransformationCase::kMoveBlockDown:
- return MakeUnique<TransformationMoveBlockDown>(message.move_block_down());
- case protobufs::Transformation::TransformationCase::kOutlineFunction:
- return MakeUnique<TransformationOutlineFunction>(
- message.outline_function());
- case protobufs::Transformation::TransformationCase::
- kPermuteFunctionParameters:
- return MakeUnique<TransformationPermuteFunctionParameters>(
- message.permute_function_parameters());
- case protobufs::Transformation::TransformationCase::kPermutePhiOperands:
- return MakeUnique<TransformationPermutePhiOperands>(
- message.permute_phi_operands());
- case protobufs::Transformation::TransformationCase::kPushIdThroughVariable:
- return MakeUnique<TransformationPushIdThroughVariable>(
- message.push_id_through_variable());
- case protobufs::Transformation::TransformationCase::
- kRecordSynonymousConstants:
- return MakeUnique<TransformationRecordSynonymousConstants>(
- message.record_synonymous_constants());
- case protobufs::Transformation::TransformationCase::
- kReplaceParameterWithGlobal:
- return MakeUnique<TransformationReplaceParameterWithGlobal>(
- message.replace_parameter_with_global());
- 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());
- case protobufs::Transformation::TransformationCase::kReplaceIdWithSynonym:
- return MakeUnique<TransformationReplaceIdWithSynonym>(
- message.replace_id_with_synonym());
- case protobufs::Transformation::TransformationCase::
- kReplaceLinearAlgebraInstruction:
- return MakeUnique<TransformationReplaceLinearAlgebraInstruction>(
- message.replace_linear_algebra_instruction());
- case protobufs::Transformation::TransformationCase::kSetFunctionControl:
- return MakeUnique<TransformationSetFunctionControl>(
- message.set_function_control());
- case protobufs::Transformation::TransformationCase::kSetLoopControl:
- return MakeUnique<TransformationSetLoopControl>(
- message.set_loop_control());
- case protobufs::Transformation::TransformationCase::kSetMemoryOperandsMask:
- return MakeUnique<TransformationSetMemoryOperandsMask>(
- message.set_memory_operands_mask());
- case protobufs::Transformation::TransformationCase::kSetSelectionControl:
- return MakeUnique<TransformationSetSelectionControl>(
- message.set_selection_control());
- case protobufs::Transformation::TransformationCase::kSplitBlock:
- return MakeUnique<TransformationSplitBlock>(message.split_block());
- case protobufs::Transformation::TransformationCase::kStore:
- return MakeUnique<TransformationStore>(message.store());
- case protobufs::Transformation::TransformationCase::kSwapCommutableOperands:
- return MakeUnique<TransformationSwapCommutableOperands>(
- message.swap_commutable_operands());
- case protobufs::Transformation::TransformationCase::
- kSwapConditionalBranchOperands:
- return MakeUnique<TransformationSwapConditionalBranchOperands>(
- message.swap_conditional_branch_operands());
- case protobufs::Transformation::TransformationCase::
- kToggleAccessChainInstruction:
- return MakeUnique<TransformationToggleAccessChainInstruction>(
- message.toggle_access_chain_instruction());
- case protobufs::Transformation::TransformationCase::kVectorShuffle:
- return MakeUnique<TransformationVectorShuffle>(message.vector_shuffle());
- case protobufs::Transformation::TRANSFORMATION_NOT_SET:
- assert(false && "An unset transformation was encountered.");
- return nullptr;
- }
- assert(false && "Should be unreachable as all cases must be handled above.");
- return nullptr;
- }
- bool Transformation::CheckIdIsFreshAndNotUsedByThisTransformation(
- uint32_t id, opt::IRContext* ir_context,
- std::set<uint32_t>* ids_used_by_this_transformation) {
- if (!fuzzerutil::IsFreshId(ir_context, id)) {
- return false;
- }
- if (ids_used_by_this_transformation->count(id) != 0) {
- return false;
- }
- ids_used_by_this_transformation->insert(id);
- return true;
- }
- } // namespace fuzz
- } // namespace spvtools
|