1#ifndef CYTNX_CYTNX_ERROR_H_
2#define CYTNX_CYTNX_ERROR_H_
15 #define __PRETTY_FUNCTION__ __FUNCTION__
18#define cytnx_error_msg(is_true, format, ...) \
21 error_msg(__PRETTY_FUNCTION__, __FILE__, __LINE__, (is_true), (format), __VA_ARGS__); \
23static inline void error_msg(
char const *
const func,
const char *
const file,
int const line,
24 bool is_true,
char const *format, ...) {
28 char output_str[1024];
30 va_start(args, format);
31 vsprintf(msg, format, args);
32 sprintf(output_str,
"\n# Cytnx error occur at %s\n# error: %s\n# file : %s (%d)", func, msg,
36 std::cerr << output_str << std::endl;
37 std::cerr <<
"Stack trace:" << std::endl;
40 size = backtrace(array, 10);
41 char **strings = backtrace_symbols(array, size);
42 for (
size_t i = 0; i < size; i++) {
43 std::cerr << strings[i] << std::endl;
46 throw std::logic_error(output_str);
52#define cytnx_warning_msg(is_true, format, ...) \
55 warning_msg(__PRETTY_FUNCTION__, __FILE__, __LINE__, (is_true), (format), __VA_ARGS__); \
57static inline void warning_msg(
char const *
const func,
const char *
const file,
int const line,
58 bool is_true,
char const *format, ...) {
61 char output_str[1024];
63 va_start(args, format);
64 vsprintf(msg, format, args);
65 sprintf(output_str,
"\n# Cytnx warning occur at %s\n# warning: %s\n# file : %s (%d)", func, msg,
68 std::cerr << output_str << std::endl;
75 #include <cuda_runtime.h>
76 #include <cublas_v2.h>
77 #include <cusolverDn.h>
78 #include <cuComplex.h>
81 #if defined(UNI_CUTENSOR)
85 #ifdef __DRIVER_TYPES_H__
86static const char *_cudaGetErrorEnum(cudaError_t error) {
91 case cudaErrorMissingConfiguration:
92 return "cudaErrorMissingConfiguration";
94 case cudaErrorMemoryAllocation:
95 return "cudaErrorMemoryAllocation";
97 case cudaErrorInitializationError:
98 return "cudaErrorInitializationError";
100 case cudaErrorLaunchFailure:
101 return "cudaErrorLaunchFailure";
103 case cudaErrorPriorLaunchFailure:
104 return "cudaErrorPriorLaunchFailure";
106 case cudaErrorLaunchTimeout:
107 return "cudaErrorLaunchTimeout";
109 case cudaErrorLaunchOutOfResources:
110 return "cudaErrorLaunchOutOfResources";
112 case cudaErrorInvalidDeviceFunction:
113 return "cudaErrorInvalidDeviceFunction";
115 case cudaErrorInvalidConfiguration:
116 return "cudaErrorInvalidConfiguration";
118 case cudaErrorInvalidDevice:
119 return "cudaErrorInvalidDevice";
121 case cudaErrorInvalidValue:
122 return "cudaErrorInvalidValue";
124 case cudaErrorInvalidPitchValue:
125 return "cudaErrorInvalidPitchValue";
127 case cudaErrorInvalidSymbol:
128 return "cudaErrorInvalidSymbol";
130 case cudaErrorMapBufferObjectFailed:
131 return "cudaErrorMapBufferObjectFailed";
133 case cudaErrorUnmapBufferObjectFailed:
134 return "cudaErrorUnmapBufferObjectFailed";
136 case cudaErrorInvalidHostPointer:
137 return "cudaErrorInvalidHostPointer";
139 case cudaErrorInvalidDevicePointer:
140 return "cudaErrorInvalidDevicePointer";
142 case cudaErrorInvalidTexture:
143 return "cudaErrorInvalidTexture";
145 case cudaErrorInvalidTextureBinding:
146 return "cudaErrorInvalidTextureBinding";
148 case cudaErrorInvalidChannelDescriptor:
149 return "cudaErrorInvalidChannelDescriptor";
151 case cudaErrorInvalidMemcpyDirection:
152 return "cudaErrorInvalidMemcpyDirection";
154 case cudaErrorAddressOfConstant:
155 return "cudaErrorAddressOfConstant";
157 case cudaErrorTextureFetchFailed:
158 return "cudaErrorTextureFetchFailed";
160 case cudaErrorTextureNotBound:
161 return "cudaErrorTextureNotBound";
163 case cudaErrorSynchronizationError:
164 return "cudaErrorSynchronizationError";
166 case cudaErrorInvalidFilterSetting:
167 return "cudaErrorInvalidFilterSetting";
169 case cudaErrorInvalidNormSetting:
170 return "cudaErrorInvalidNormSetting";
172 case cudaErrorMixedDeviceExecution:
173 return "cudaErrorMixedDeviceExecution";
175 case cudaErrorCudartUnloading:
176 return "cudaErrorCudartUnloading";
178 case cudaErrorUnknown:
179 return "cudaErrorUnknown";
181 case cudaErrorNotYetImplemented:
182 return "cudaErrorNotYetImplemented";
184 case cudaErrorMemoryValueTooLarge:
185 return "cudaErrorMemoryValueTooLarge";
187 case cudaErrorInvalidResourceHandle:
188 return "cudaErrorInvalidResourceHandle";
190 case cudaErrorNotReady:
191 return "cudaErrorNotReady";
193 case cudaErrorInsufficientDriver:
194 return "cudaErrorInsufficientDriver";
196 case cudaErrorSetOnActiveProcess:
197 return "cudaErrorSetOnActiveProcess";
199 case cudaErrorInvalidSurface:
200 return "cudaErrorInvalidSurface";
202 case cudaErrorNoDevice:
203 return "cudaErrorNoDevice";
205 case cudaErrorECCUncorrectable:
206 return "cudaErrorECCUncorrectable";
208 case cudaErrorSharedObjectSymbolNotFound:
209 return "cudaErrorSharedObjectSymbolNotFound";
211 case cudaErrorSharedObjectInitFailed:
212 return "cudaErrorSharedObjectInitFailed";
214 case cudaErrorUnsupportedLimit:
215 return "cudaErrorUnsupportedLimit";
217 case cudaErrorDuplicateVariableName:
218 return "cudaErrorDuplicateVariableName";
220 case cudaErrorDuplicateTextureName:
221 return "cudaErrorDuplicateTextureName";
223 case cudaErrorDuplicateSurfaceName:
224 return "cudaErrorDuplicateSurfaceName";
226 case cudaErrorDevicesUnavailable:
227 return "cudaErrorDevicesUnavailable";
229 case cudaErrorInvalidKernelImage:
230 return "cudaErrorInvalidKernelImage";
232 case cudaErrorNoKernelImageForDevice:
233 return "cudaErrorNoKernelImageForDevice";
235 case cudaErrorIncompatibleDriverContext:
236 return "cudaErrorIncompatibleDriverContext";
238 case cudaErrorPeerAccessAlreadyEnabled:
239 return "cudaErrorPeerAccessAlreadyEnabled";
241 case cudaErrorPeerAccessNotEnabled:
242 return "cudaErrorPeerAccessNotEnabled";
244 case cudaErrorDeviceAlreadyInUse:
245 return "cudaErrorDeviceAlreadyInUse";
247 case cudaErrorProfilerDisabled:
248 return "cudaErrorProfilerDisabled";
250 case cudaErrorProfilerNotInitialized:
251 return "cudaErrorProfilerNotInitialized";
253 case cudaErrorProfilerAlreadyStarted:
254 return "cudaErrorProfilerAlreadyStarted";
256 case cudaErrorProfilerAlreadyStopped:
257 return "cudaErrorProfilerAlreadyStopped";
260 case cudaErrorAssert:
261 return "cudaErrorAssert";
263 case cudaErrorTooManyPeers:
264 return "cudaErrorTooManyPeers";
266 case cudaErrorHostMemoryAlreadyRegistered:
267 return "cudaErrorHostMemoryAlreadyRegistered";
269 case cudaErrorHostMemoryNotRegistered:
270 return "cudaErrorHostMemoryNotRegistered";
273 case cudaErrorOperatingSystem:
274 return "cudaErrorOperatingSystem";
276 case cudaErrorPeerAccessUnsupported:
277 return "cudaErrorPeerAccessUnsupported";
279 case cudaErrorLaunchMaxDepthExceeded:
280 return "cudaErrorLaunchMaxDepthExceeded";
282 case cudaErrorLaunchFileScopedTex:
283 return "cudaErrorLaunchFileScopedTex";
285 case cudaErrorLaunchFileScopedSurf:
286 return "cudaErrorLaunchFileScopedSurf";
288 case cudaErrorSyncDepthExceeded:
289 return "cudaErrorSyncDepthExceeded";
291 case cudaErrorLaunchPendingCountExceeded:
292 return "cudaErrorLaunchPendingCountExceeded";
294 case cudaErrorNotPermitted:
295 return "cudaErrorNotPermitted";
297 case cudaErrorNotSupported:
298 return "cudaErrorNotSupported";
301 case cudaErrorHardwareStackError:
302 return "cudaErrorHardwareStackError";
304 case cudaErrorIllegalInstruction:
305 return "cudaErrorIllegalInstruction";
307 case cudaErrorMisalignedAddress:
308 return "cudaErrorMisalignedAddress";
310 case cudaErrorInvalidAddressSpace:
311 return "cudaErrorInvalidAddressSpace";
313 case cudaErrorInvalidPc:
314 return "cudaErrorInvalidPc";
316 case cudaErrorIllegalAddress:
317 return "cudaErrorIllegalAddress";
320 case cudaErrorInvalidPtx:
321 return "cudaErrorInvalidPtx";
323 case cudaErrorInvalidGraphicsContext:
324 return "cudaErrorInvalidGraphicsContext";
326 case cudaErrorStartupFailure:
327 return "cudaErrorStartupFailure";
329 case cudaErrorApiFailureBase:
330 return "cudaErrorApiFailureBase";
333 case cudaErrorNvlinkUncorrectable:
334 return "cudaErrorNvlinkUncorrectable";
345static const char *_cudaGetErrorEnum(cublasStatus_t error) {
347 case CUBLAS_STATUS_SUCCESS:
348 return "CUBLAS_STATUS_SUCCESS";
350 case CUBLAS_STATUS_NOT_INITIALIZED:
351 return "CUBLAS_STATUS_NOT_INITIALIZED";
353 case CUBLAS_STATUS_ALLOC_FAILED:
354 return "CUBLAS_STATUS_ALLOC_FAILED";
356 case CUBLAS_STATUS_INVALID_VALUE:
357 return "CUBLAS_STATUS_INVALID_VALUE";
359 case CUBLAS_STATUS_ARCH_MISMATCH:
360 return "CUBLAS_STATUS_ARCH_MISMATCH";
362 case CUBLAS_STATUS_MAPPING_ERROR:
363 return "CUBLAS_STATUS_MAPPING_ERROR";
365 case CUBLAS_STATUS_EXECUTION_FAILED:
366 return "CUBLAS_STATUS_EXECUTION_FAILED";
368 case CUBLAS_STATUS_INTERNAL_ERROR:
369 return "CUBLAS_STATUS_INTERNAL_ERROR";
371 case CUBLAS_STATUS_NOT_SUPPORTED:
372 return "CUBLAS_STATUS_NOT_SUPPORTED";
374 case CUBLAS_STATUS_LICENSE_ERROR:
375 return "CUBLAS_STATUS_LICENSE_ERROR";
382 #ifdef CUSOLVER_COMMON_H_
384static const char *_cudaGetErrorEnum(cusolverStatus_t error) {
386 case CUSOLVER_STATUS_SUCCESS:
387 return "CUSOLVER_STATUS_SUCCESS";
388 case CUSOLVER_STATUS_NOT_INITIALIZED:
389 return "CUSOLVER_STATUS_NOT_INITIALIZED";
390 case CUSOLVER_STATUS_ALLOC_FAILED:
391 return "CUSOLVER_STATUS_ALLOC_FAILED";
392 case CUSOLVER_STATUS_INVALID_VALUE:
393 return "CUSOLVER_STATUS_INVALID_VALUE";
394 case CUSOLVER_STATUS_ARCH_MISMATCH:
395 return "CUSOLVER_STATUS_ARCH_MISMATCH";
396 case CUSOLVER_STATUS_MAPPING_ERROR:
397 return "CUSOLVER_STATUS_MAPPING_ERROR";
398 case CUSOLVER_STATUS_EXECUTION_FAILED:
399 return "CUSOLVER_STATUS_EXECUTION_FAILED";
400 case CUSOLVER_STATUS_INTERNAL_ERROR:
401 return "CUSOLVER_STATUS_INTERNAL_ERROR";
402 case CUSOLVER_STATUS_MATRIX_TYPE_NOT_SUPPORTED:
403 return "CUSOLVER_STATUS_MATRIX_TYPE_NOT_SUPPORTED";
404 case CUSOLVER_STATUS_NOT_SUPPORTED:
405 return "CUSOLVER_STATUS_NOT_SUPPORTED ";
406 case CUSOLVER_STATUS_ZERO_PIVOT:
407 return "CUSOLVER_STATUS_ZERO_PIVOT";
408 case CUSOLVER_STATUS_INVALID_LICENSE:
409 return "CUSOLVER_STATUS_INVALID_LICENSE";
418static const char *_cudaGetErrorEnum(curandStatus_t error) {
420 case CURAND_STATUS_SUCCESS:
421 return "CURAND_STATUS_SUCCESS";
422 case CURAND_STATUS_VERSION_MISMATCH:
423 return "CURAND_STATUS_VERSION_MISMATCH";
424 case CURAND_STATUS_NOT_INITIALIZED:
425 return "CURAND_STATUS_NOT_INITIALIZED";
426 case CURAND_STATUS_ALLOCATION_FAILED:
427 return "CURAND_STATUS_ALLOCATION_FAILED";
428 case CURAND_STATUS_TYPE_ERROR:
429 return "CURAND_STATUS_TYPE_ERROR";
430 case CURAND_STATUS_OUT_OF_RANGE:
431 return "CURAND_STATUS_OUT_OF_RANGE";
432 case CURAND_STATUS_LENGTH_NOT_MULTIPLE:
433 return "CURAND_STATUS_LENGTH_NOT_MULTIPLE";
434 case CURAND_STATUS_DOUBLE_PRECISION_REQUIRED:
435 return "CURAND_STATUS_DOUBLE_PRECISION_REQUIRED";
436 case CURAND_STATUS_LAUNCH_FAILURE:
437 return "CURAND_STATUS_LAUNCH_FAILURE";
438 case CURAND_STATUS_PREEXISTING_FAILURE:
439 return "CURAND_STATUS_PREEXISTING_FAILURE";
440 case CURAND_STATUS_INITIALIZATION_FAILED:
441 return "CURAND_STATUS_INITIALIZATION_FAILED";
442 case CURAND_STATUS_ARCH_MISMATCH:
443 return "CURAND_STATUS_ARCH_MISMATCH";
444 case CURAND_STATUS_INTERNAL_ERROR:
445 return "CURAND_STATUS_INTERNAL_ERROR";
453static const char *_cudaGetErrorEnum(cutensorStatus_t error) {
454 return cutensorGetErrorString(error);
458 #ifdef __DRIVER_TYPES_H__
460 #define DEVICE_RESET cudaDeviceReset();
469void check(T result,
char const *
const func,
const char *
const file,
int const line) {
471 fprintf(stderr,
"CUDA error at %s:%d code=%d(%s) \"%s\" \n", file, line,
472 static_cast<unsigned int>(result), _cudaGetErrorEnum(result), func);
479 #ifdef __DRIVER_TYPES_H__
482 #define checkCudaErrors(val) check((val), #val, __FILE__, __LINE__)