File: repeated_pass_manager_random_with_recommendations.cpp

package info (click to toggle)
spirv-tools 2020.6-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 21,636 kB
  • sloc: cpp: 366,576; javascript: 5,849; python: 2,551; ansic: 387; sh: 327; ruby: 88; makefile: 19; lisp: 9
file content (62 lines) | stat: -rw-r--r-- 2,537 bytes parent folder | download | duplicates (22)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// Copyright (c) 2020 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/pass_management/repeated_pass_manager_random_with_recommendations.h"

namespace spvtools {
namespace fuzz {

RepeatedPassManagerRandomWithRecommendations::
    RepeatedPassManagerRandomWithRecommendations(
        FuzzerContext* fuzzer_context, RepeatedPassInstances* pass_instances,
        RepeatedPassRecommender* pass_recommender)
    : RepeatedPassManager(fuzzer_context, pass_instances),
      pass_recommender_(pass_recommender),
      num_transformations_applied_before_last_pass_choice_(0),
      last_pass_choice_(nullptr) {}

RepeatedPassManagerRandomWithRecommendations::
    ~RepeatedPassManagerRandomWithRecommendations() = default;

FuzzerPass* RepeatedPassManagerRandomWithRecommendations::ChoosePass(
    const protobufs::TransformationSequence& applied_transformations) {
  assert(static_cast<uint32_t>(applied_transformations.transformation_size()) >=
             num_transformations_applied_before_last_pass_choice_ &&
         "The number of applied transformations should not decrease.");
  if (last_pass_choice_ != nullptr &&
      static_cast<uint32_t>(applied_transformations.transformation_size()) >
          num_transformations_applied_before_last_pass_choice_) {
    // The last pass had some effect, so we make future recommendations based on
    // it.
    for (auto future_pass :
         pass_recommender_->GetFuturePassRecommendations(*last_pass_choice_)) {
      recommended_passes_.push_back(future_pass);
    }
  }

  FuzzerPass* result;
  if (recommended_passes_.empty() || GetFuzzerContext()->ChooseEven()) {
    auto& passes = GetPassInstances()->GetPasses();
    result = passes[GetFuzzerContext()->RandomIndex(passes)].get();
  } else {
    result = recommended_passes_.front();
    recommended_passes_.pop_front();
  }
  assert(result != nullptr && "A pass must have been chosen.");
  last_pass_choice_ = result;
  return result;
}

}  // namespace fuzz
}  // namespace spvtools