forked from pytorch/pytorch
-
Notifications
You must be signed in to change notification settings - Fork 1
/
MetaFallbackKernel.cpp
27 lines (23 loc) · 1013 Bytes
/
MetaFallbackKernel.cpp
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
#include <ATen/core/dispatch/Dispatcher.h>
#include <c10/core/impl/PyInterpreter.h>
#include <torch/library.h>
namespace at::impl {
static void metaFallback(
const c10::OperatorHandle& op,
c10::DispatchKeySet dispatch_keys,
torch::jit::Stack* stack) {
c10::Dispatcher::singleton().throwIfHasPythonModule(op.operator_name());
TORCH_CHECK_NOT_IMPLEMENTED(
false,
op.operator_name(),
": attempted to run this operator with Meta tensors, but there was no ",
"fake impl or Meta kernel registered. You may have run into this message "
"while using an operator with PT2 compilation APIs (torch.compile/torch.export); "
"in order to use this operator with those APIs you'll need to add a fake impl. "
"Please see the following for next steps: "
"https://pytorch.org/tutorials/advanced/custom_ops_landing_page.html");
}
TORCH_LIBRARY_IMPL(_, Meta, m) {
m.fallback(torch::CppFunction::makeFromBoxedFunction<&metaFallback>());
}
} // namespace at::impl