#pragma once
#include "megcore_cdefs.h"
#include "megdnn/handle.h"
#include "src/common/utils.h"
#include "src/cuda/handle.h"
#include "src/cuda/utils.cuh"
#include <cublas_v2.h>
#include <cuda_runtime_api.h>
#include "src/cuda/cudnn_with_check.h"
namespace megdnn {
namespace cuda {
static inline HandleImpl* concrete_handle(Handle* handle) {
return static_cast<cuda::HandleImpl*>(handle);
}
static inline cudnnHandle_t cudnn_handle(Handle* handle) {
return concrete_handle(handle)->cudnn_handle();
}
static inline cublasHandle_t cublas_handle(Handle* handle) {
return concrete_handle(handle)->cublas_handle();
}
static inline cudaStream_t cuda_stream(Handle* handle) {
return concrete_handle(handle)->stream();
}
static inline megcore::AsyncErrorInfo* async_error_info(Handle* handle) {
return concrete_handle(handle)->megcore_context().error_info;
}
static inline void CUDART_CB
callback_free(cudaStream_t , cudaError_t status, void* userData) {
cuda_check(status);
free(userData);
}
const cudaDeviceProp& current_device_prop();
const cudaDeviceProp* get_device_prop(int device);
bool is_compute_capability_required(int major, int minor);
bool is_compute_capability_equalto(int major, int minor);
size_t max_batch_x_channel_size();
uint32_t param_buffer_start_address();
const char* current_device_arch_name();
} }