kernel_key.h 1.7 KB
Newer Older
T
tensor-tang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/* Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
 *
 * 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. */

#pragma once
T
tensor-tang 已提交
16
#include "paddle/fluid/operators/jit/kernel_base.h"
T
tensor-tang 已提交
17 18 19 20
#include "paddle/fluid/platform/place.h"

namespace paddle {
namespace operators {
T
tensor-tang 已提交
21
namespace jit {
T
tensor-tang 已提交
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

struct KernelKey {
  struct Hash {
    size_t operator()(const KernelKey& key) const {
      int place = key.place_.which();               // less than 2^8
      int type = static_cast<int>(key.type_) << 8;  // less than 2^(32-8)
      std::hash<int> hasher;
      return hasher(place + type);
    }
  };

  KernelType type_;
  platform::Place place_;

  KernelKey(KernelType type, platform::Place place)
      : type_(type), place_(place) {}
  size_t hash_key() const { return Hash()(*this); }

  bool operator==(const KernelKey& o) const {
    return platform::places_are_same_class(place_, o.place_) &&
           type_ == o.type_;
  }
  bool operator!=(const KernelKey& o) const { return !(*this == o); }
};

T
tensor-tang 已提交
47 48 49 50
// Every JitCode should have a method to get the key from attribution
template <typename Attr>
size_t JitCodeKey(const Attr& attr);

T
tensor-tang 已提交
51
}  // namespace jit
T
tensor-tang 已提交
52 53
}  // namespace operators
}  // namespace paddle