sdaccel_device_api.cc 1.11 KB
Newer Older
1 2 3 4 5 6
/*!
 *  Copyright (c) 2018 by Contributors
 * \file sdaccel_device_api.cc
 */
#include <tvm/runtime/registry.h>
#include <dmlc/thread_local.h>
7
#include "sdaccel_common.h"
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22

namespace tvm {
namespace runtime {
namespace cl {

OpenCLThreadEntry* SDAccelWorkspace::GetThreadEntry() {
  return SDAccelThreadEntry::ThreadLocal();
}

const std::shared_ptr<OpenCLWorkspace>& SDAccelWorkspace::Global() {
  static std::shared_ptr<OpenCLWorkspace> inst = std::make_shared<SDAccelWorkspace>();
  return inst;
}

void SDAccelWorkspace::Init() {
23
  OpenCLWorkspace::Init("sdaccel", "accelerator", "Xilinx");
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
}

bool SDAccelWorkspace::IsOpenCLDevice(TVMContext ctx) {
  return ctx.device_type == static_cast<DLDeviceType>(kDLSDAccel);
}

typedef dmlc::ThreadLocalStore<SDAccelThreadEntry> SDAccelThreadStore;

SDAccelThreadEntry* SDAccelThreadEntry::ThreadLocal() {
  return SDAccelThreadStore::Get();
}

TVM_REGISTER_GLOBAL("device_api.sdaccel")
.set_body([](TVMArgs args, TVMRetValue* rv) {
    DeviceAPI* ptr = SDAccelWorkspace::Global().get();
    *rv = static_cast<void*>(ptr);
  });

}  // namespace cl
}  // namespace runtime
}  // namespace tvm