fuzzer_pass_add_function_calls.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // Copyright (c) 2020 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #ifndef SOURCE_FUZZ_FUZZER_PASS_ADD_FUNCTION_CALLS_H_
  15. #define SOURCE_FUZZ_FUZZER_PASS_ADD_FUNCTION_CALLS_H_
  16. #include "source/fuzz/fuzzer_pass.h"
  17. namespace spvtools {
  18. namespace fuzz {
  19. // Fuzzer pass that adds calls at random to (a) livesafe functions, from
  20. // anywhere, and (b) any functions, from dead blocks.
  21. class FuzzerPassAddFunctionCalls : public FuzzerPass {
  22. public:
  23. FuzzerPassAddFunctionCalls(opt::IRContext* ir_context,
  24. TransformationContext* transformation_context,
  25. FuzzerContext* fuzzer_context,
  26. protobufs::TransformationSequence* transformations,
  27. bool ignore_inapplicable_transformations);
  28. void Apply() override;
  29. private:
  30. // Randomly chooses suitable arguments to invoke |callee| right before
  31. // instruction |caller_inst_it| of block |caller_block| in |caller_function|,
  32. // based on both existing available instructions and the addition of new
  33. // instructions to the module.
  34. std::vector<uint32_t> ChooseFunctionCallArguments(
  35. const opt::Function& callee, opt::Function* caller_function,
  36. opt::BasicBlock* caller_block,
  37. const opt::BasicBlock::iterator& caller_inst_it);
  38. };
  39. } // namespace fuzz
  40. } // namespace spvtools
  41. #endif // SOURCE_FUZZ_FUZZER_PASS_ADD_FUNCTION_CALLS_H_