23#ifdef MLIR_ENABLE_CUDA_CUSPARSE
25#ifdef MLIR_ENABLE_CUDA_CUSPARSELT
26#include "cusparseLt.h"
32#define MLIR_CUDA_WRAPPERS_EXPORT __declspec(dllexport)
34#define MLIR_CUDA_WRAPPERS_EXPORT __attribute__((visibility("default")))
37#define CUDA_REPORT_IF_ERROR(expr) \
38 [](CUresult result) { \
41 const char *name = nullptr; \
42 cuGetErrorName(result, &name); \
45 fprintf(stderr, "'%s' failed with '%s'\n", #expr, name); \
48#define CUSPARSE_REPORT_IF_ERROR(expr) \
50 cusparseStatus_t status = (expr); \
51 if (status != CUSPARSE_STATUS_SUCCESS) { \
52 fprintf(stderr, "cuSPARSE '%s' failed with '%s'\n", #expr, \
53 cusparseGetErrorString(status)); \
61 const char *kDebugEnvironmentVariable =
"MLIR_CUDA_DEBUG";
62 static bool isEnabled = getenv(kDebugEnvironmentVariable) !=
nullptr;
66#define debug_print(fmt, ...) \
68 if (isDebugEnabled()) \
69 fprintf(stderr, "%s:%d:%s(): " fmt, "CudaRuntimeWrappers.cpp", __LINE__, \
70 __func__, __VA_ARGS__); \
88 static CUcontext context = [] {
103#ifdef MLIR_ENABLE_CUDA_CUSPARSE
108static cusparseHandle_t cusparse_env =
nullptr;
110#ifdef MLIR_ENABLE_CUDA_CUSPARSELT
113static cusparseLtHandle_t cusparseLt_env;
114static bool cusparseLt_initiated =
false;
122 CUmodule module =
nullptr;
130 CUmodule module =
nullptr;
131 char jitErrorBuffer[4096] = {0};
132 CUjit_option jitOptions[] = {CU_JIT_ERROR_LOG_BUFFER,
133 CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES,
134 CU_JIT_OPTIMIZATION_LEVEL};
135 void *jitOptionsVals[] = {jitErrorBuffer,
136 reinterpret_cast<void *
>(
sizeof(jitErrorBuffer)),
137 reinterpret_cast<void *
>(optLevel)};
140 cuModuleLoadDataEx(&module, data, 3, jitOptions, jitOptionsVals);
142 fprintf(stderr,
"JIT compilation failed with: '%s'\n", jitErrorBuffer);
151 CUresult
result = cuModuleUnload(module);
152 if (
result != CUDA_SUCCESS &&
result != CUDA_ERROR_DEINITIALIZED)
158 CUfunction function =
nullptr;
169 intptr_t blockZ, int32_t smem, CUstream stream,
void **params,
170 void **extra,
size_t ) {
174 int32_t maxShmem = 0;
178 &maxShmem, CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN,
180 if (maxShmem < smem) {
182 "Requested shared memory (%dkb) is larger than maximum allowed "
183 "shared memory (%dkb) for this device\n",
187 function, CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES, smem));
190 "threads: %ld, %ld, %ld, "
192 gridX, gridY, gridZ, blockX, blockY, blockZ, smem);
194 blockY, blockZ, smem, stream, params,
200 CUstream stream =
nullptr;
221 CUevent
event =
nullptr;
244 return reinterpret_cast<void *
>(ptr);
248 cuMemAllocManaged(&ptr, sizeBytes, CU_MEM_ATTACH_GLOBAL));
249 return reinterpret_cast<void *
>(ptr);
252 return reinterpret_cast<void *
>(ptr);
261mgpuMemcpy(
void *dst,
void *src,
size_t sizeBytes, CUstream stream) {
263 reinterpret_cast<CUdeviceptr
>(src),
268mgpuMemset32(
void *dst,
unsigned int value,
size_t count, CUstream stream) {
270 value, count, stream));
274mgpuMemset16(
void *dst,
unsigned short value,
size_t count, CUstream stream) {
276 value, count, stream));
304 for (
int64_t i = rank - 1, runningStride = 1; i >= 0; i--) {
305 denseStrides[i] = runningStride;
306 runningStride *= sizes[i];
308 uint64_t sizeBytes = sizes[0] * denseStrides[0] * elementSizeBytes;
309 int64_t *strides = &sizes[rank];
311 for (
unsigned i = 0; i < rank; ++i)
312 assert(strides[i] == denseStrides[i] &&
313 "Mismatch in computed dense strides");
315 auto *ptr = descriptor->
data + descriptor->
offset * elementSizeBytes;
331 auto *ptr = descriptor->
data + descriptor->
offset * elementSizeBytes;
343#if (CUDA_VERSION >= 12000)
349 void **params,
void **extra) {
352 int32_t maxShmem = 0;
356 &maxShmem, CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN,
358 if (maxShmem < smem) {
360 "Requested shared memory (%dkb) is larger than maximum allowed "
361 "shared memory (%dkb) for this device\n",
365 function, CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES, smem));
368 CUlaunchConfig config;
369 config.gridDimX = gridX;
370 config.gridDimY = gridY;
371 config.gridDimZ = gridZ;
372 config.blockDimX = blockX;
373 config.blockDimY = blockY;
374 config.blockDimZ = blockZ;
375 config.sharedMemBytes = smem;
376 config.hStream = stream;
378 CUlaunchAttribute launchAttrs[3];
381 bool hasCluster = clusterX > 0 && clusterY > 0 && clusterZ > 0;
383 launchAttrs[numAttrs].id = CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION;
384 launchAttrs[numAttrs].value.clusterDim.x = clusterX;
385 launchAttrs[numAttrs].value.clusterDim.y = clusterY;
386 launchAttrs[numAttrs].value.clusterDim.z = clusterZ;
389 launchAttrs[numAttrs].id =
390 CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE;
391 launchAttrs[numAttrs].value.clusterSchedulingPolicyPreference =
392 CU_CLUSTER_SCHEDULING_POLICY_SPREAD;
396 launchAttrs[numAttrs].id = CU_LAUNCH_ATTRIBUTE_COOPERATIVE;
397 launchAttrs[numAttrs].value.cooperative = 1;
400 config.numAttrs = numAttrs;
401 config.attrs = launchAttrs;
403 debug_print(
"Launching cooperative kernel (cluster=%d), "
405 "threads: %ld, %ld, %ld, "
407 hasCluster, gridX, gridY, gridZ, blockX, blockY, blockZ, smem);
416 CUstream stream,
void **params,
void **extra,
size_t ) {
420 int32_t maxShmem = 0;
424 &maxShmem, CU_DEVICE_ATTRIBUTE_MAX_SHARED_MEMORY_PER_BLOCK_OPTIN,
426 if (maxShmem < smem) {
428 "Requested shared memory (%dkb) is larger than maximum allowed "
429 "shared memory (%dkb) for this device\n",
433 function, CU_FUNC_ATTRIBUTE_MAX_DYNAMIC_SHARED_SIZE_BYTES, smem));
435 CUlaunchConfig config;
436 config.gridDimX = gridX;
437 config.gridDimY = gridY;
438 config.gridDimZ = gridZ;
439 config.blockDimX = blockX;
440 config.blockDimY = blockY;
441 config.blockDimZ = blockZ;
442 config.sharedMemBytes = smem;
443 config.hStream = stream;
444 CUlaunchAttribute launchAttr[2];
445 launchAttr[0].id = CU_LAUNCH_ATTRIBUTE_CLUSTER_DIMENSION;
446 launchAttr[0].value.clusterDim.x = clusterX;
447 launchAttr[0].value.clusterDim.y = clusterY;
448 launchAttr[0].value.clusterDim.z = clusterZ;
449 launchAttr[1].id = CU_LAUNCH_ATTRIBUTE_CLUSTER_SCHEDULING_POLICY_PREFERENCE;
450 launchAttr[1].value.clusterSchedulingPolicyPreference =
451 CU_CLUSTER_SCHEDULING_POLICY_SPREAD;
453 config.attrs = launchAttr;
456 "cluster: %ld, %ld, %ld, "
458 "threads: %ld, %ld, %ld, "
460 clusterX, clusterY, clusterZ, gridX, gridY, gridZ, blockX, blockY,
467 CUtensorMap *tensorMap,
468 CUtensorMapDataType tensorDataType,
469 cuuint32_t tensorRank,
471 const cuuint64_t *globalDim,
472 const cuuint64_t *globalStrides,
473 const cuuint32_t *boxDim,
474 const cuuint32_t *elementStrides,
475 CUtensorMapInterleave interleave,
476 CUtensorMapSwizzle swizzle,
477 CUtensorMapL2promotion l2Promotion,
478 CUtensorMapFloatOOBfill oobFill
482 tensorMap, tensorDataType, tensorRank, globalAddress, globalDim,
483 globalStrides, boxDim, elementStrides, interleave, swizzle, l2Promotion,
488 "globalDim[5]: %zu, %zu, %zu, %zu, %zu\n"
489 "globalStrides[5]: %zu, %zu, %zu, %zu, %zu\n"
490 "boxDim[5]: %u, %u, %u, %u, %u\n"
491 "elementStrides[5]: %u, %u, %u, %u, %u\n"
496 (
void *)&tensorMap, tensorDataType, tensorRank, globalDim[0],
497 globalDim[1], globalDim[2], globalDim[3], globalDim[4],
498 globalStrides[0], globalStrides[1], globalStrides[2],
499 globalStrides[3], globalStrides[4], boxDim[0], boxDim[1],
500 boxDim[2], boxDim[3], boxDim[4], elementStrides[0],
501 elementStrides[1], elementStrides[2], elementStrides[3],
502 elementStrides[4], interleave, swizzle, l2Promotion, oobFill);
506void mgpuGetMemRefDataAndShape(
void *rawDescriptor,
char **addr,
507 uint64_t *globalDim, uint64_t *globalStrides,
508 const CUtensorMapDataType tensorDataType) {
511 *addr = descriptor->data;
512 for (
int i = 0; i < Rank; ++i) {
513 globalDim[i] =
static_cast<uint64_t
>(descriptor->sizes[Rank - i - 1]);
515 static constexpr int elementSizeInBytes[] = {1, 2, 4, 4, 8, 8, 2,
517 for (
int i = 0; i < Rank - 1; ++i) {
518 globalStrides[i] =
static_cast<uint64_t
>(
519 descriptor->strides[Rank - i - 2] * elementSizeInBytes[tensorDataType]);
525 void *rankedDescriptor,
526 const CUtensorMapDataType tensorDataType,
527 CUtensorMapInterleave interleave,
528 CUtensorMapSwizzle swizzle,
529 CUtensorMapL2promotion l2Promotion,
530 CUtensorMapFloatOOBfill oobFill,
533 CUtensorMap tensorMap;
535 uint32_t boxDim[5] = {1, 1, 1, 1, 1}, elementStrides[5] = {1, 1, 1, 1, 1};
536 uint64_t globalDim[5] = {1, 1, 1, 1, 1}, globalStrides[5] = {0};
537 uint32_t tensorRank32 = uint32_t(tensorRank);
539 char *globalAddress =
nullptr;
540 switch (tensorRank) {
542 mgpuGetMemRefDataAndShape<1>(rankedDescriptor, &globalAddress, globalDim,
543 globalStrides, tensorDataType);
546 mgpuGetMemRefDataAndShape<2>(rankedDescriptor, &globalAddress, globalDim,
547 globalStrides, tensorDataType);
550 mgpuGetMemRefDataAndShape<3>(rankedDescriptor, &globalAddress, globalDim,
551 globalStrides, tensorDataType);
554 mgpuGetMemRefDataAndShape<4>(rankedDescriptor, &globalAddress, globalDim,
555 globalStrides, tensorDataType);
558 mgpuGetMemRefDataAndShape<5>(rankedDescriptor, &globalAddress, globalDim,
559 globalStrides, tensorDataType);
564 "'mgpuTensorMapEncodeTiledMemref' failed with 'rank is too high'\n");
568 for (
int64_t r = 0; r < tensorRank; ++r) {
569 boxDim[r] =
static_cast<uint32_t
>(inputBoxDims[tensorRank - r - 1]);
573 mgpuTensorMapEncodeTiled(&tensorMap, tensorDataType, tensorRank32,
574 globalAddress, globalDim, globalStrides, boxDim,
575 elementStrides, interleave, swizzle, l2Promotion,
578 CUdeviceptr dTensorMap;
581 reinterpret_cast<CUdeviceptr
>(&tensorMap),
582 sizeof(CUtensorMap)));
583 return reinterpret_cast<void *
>(dTensorMap);
587#ifdef MLIR_ENABLE_CUDA_CUSPARSE
595#define ALPHABETA(dtp, alpha, beta) \
596 __nv_bfloat16(alpha##16bf) = 1.0f; \
597 __nv_bfloat16(beta##16bf) = 1.0f; \
598 __half(alpha##16f) = 1.0f; \
599 __half(beta##16f) = 1.0f; \
600 float(alpha##f) = 1.0f; \
601 float(beta##f) = 1.0f; \
602 double(alpha##d) = 1.0; \
603 double(beta##d) = 1.0; \
604 const void *(alpha##p) = nullptr; \
605 const void *(beta##p) = nullptr; \
606 if (dtp == CUDA_R_16BF || dtp == CUDA_C_16BF) { \
607 (alpha##p) = reinterpret_cast<void *>(&(alpha##16bf)); \
608 (beta##p) = reinterpret_cast<void *>(&(beta##16bf)); \
609 } else if (dtp == CUDA_R_16F || dtp == CUDA_C_16F) { \
610 (alpha##p) = reinterpret_cast<void *>(&(alpha##16f)); \
611 (beta##p) = reinterpret_cast<void *>(&(beta##16f)); \
612 } else if (dtp == CUDA_R_32F || dtp == CUDA_C_32F) { \
613 (alpha##p) = reinterpret_cast<void *>(&(alpha##f)); \
614 (beta##p) = reinterpret_cast<void *>(&(beta##f)); \
616 (alpha##p) = reinterpret_cast<void *>(&(alpha##d)); \
617 (beta##p) = reinterpret_cast<void *>(&(beta##d)); \
623 assert(!cusparse_env &&
"client called mgpuCreateSparseEnv() twice");
628 assert(cusparse_env &&
"client did not call mgpuCreateSparseEnv()");
630 cusparse_env =
nullptr;
634mgpuCreateDnVec(
intptr_t size,
void *values, int32_t dtp, CUstream ) {
635 cusparseDnVecDescr_t vec =
nullptr;
636 auto dTp =
static_cast<cudaDataType_t
>(dtp);
638 return reinterpret_cast<void *
>(vec);
642mgpuDestroyDnVec(
void *v, CUstream ) {
643 cusparseDnVecDescr_t vec =
reinterpret_cast<cusparseDnVecDescr_t
>(v);
650 cusparseDnMatDescr_t mat =
nullptr;
651 auto dTp =
static_cast<cudaDataType_t
>(dtp);
653 values, dTp, CUSPARSE_ORDER_ROW))
654 return reinterpret_cast<void *
>(mat);
658mgpuDestroyDnMat(
void *m, CUstream ) {
659 cusparseDnMatDescr_t mat =
reinterpret_cast<cusparseDnMatDescr_t
>(m);
665 void *colIdxs,
void *values, int32_t itp, int32_t dtp,
667 cusparseSpMatDescr_t mat =
nullptr;
668 auto iTp =
static_cast<cusparseIndexType_t
>(itp);
669 auto dTp =
static_cast<cudaDataType_t
>(dtp);
671 colIdxs, values, iTp,
672 CUSPARSE_INDEX_BASE_ZERO, dTp))
673 return reinterpret_cast<void *
>(mat);
676#ifdef CUSPARSE_COO_AOS
679 void *values, int32_t itp, int32_t dtp, CUstream ) {
680 cusparseSpMatDescr_t mat =
nullptr;
681 auto iTp =
static_cast<cusparseIndexType_t
>(itp);
682 auto dTp =
static_cast<cudaDataType_t
>(dtp);
684 &mat, rows, cols, nnz, idxs, values, iTp, CUSPARSE_INDEX_BASE_ZERO, dTp))
685 return reinterpret_cast<void *
>(mat);
691 void *colIdxs,
void *values, int32_t ptp, int32_t itp,
692 int32_t dtp, CUstream ) {
693 cusparseSpMatDescr_t mat =
nullptr;
694 auto pTp =
static_cast<cusparseIndexType_t
>(ptp);
695 auto iTp =
static_cast<cusparseIndexType_t
>(itp);
696 auto dTp =
static_cast<cudaDataType_t
>(dtp);
698 colIdxs, values, pTp, iTp,
699 CUSPARSE_INDEX_BASE_ZERO, dTp))
700 return reinterpret_cast<void *
>(mat);
705 void *rowIdxs,
void *values, int32_t ptp, int32_t itp,
706 int32_t dtp, CUstream ) {
707 cusparseSpMatDescr_t mat =
nullptr;
708 auto pTp =
static_cast<cusparseIndexType_t
>(ptp);
709 auto iTp =
static_cast<cusparseIndexType_t
>(itp);
710 auto dTp =
static_cast<cudaDataType_t
>(dtp);
712 rowIdxs, values, pTp, iTp,
713 CUSPARSE_INDEX_BASE_ZERO, dTp))
714 return reinterpret_cast<void *
>(mat);
719 intptr_t cBsz,
void *rowPos,
void *colIdxs,
void *values,
720 int32_t ptp, int32_t itp, int32_t dtp, CUstream ) {
721 cusparseSpMatDescr_t mat =
nullptr;
722#if CUSPARSE_VERSION >= 12100
723 auto pTp =
static_cast<cusparseIndexType_t
>(ptp);
724 auto iTp =
static_cast<cusparseIndexType_t
>(itp);
725 auto dTp =
static_cast<cudaDataType_t
>(dtp);
727 &mat, brows, bcols, bnnz, rBsz, cBsz, rowPos, colIdxs, values, pTp, iTp,
728 CUSPARSE_INDEX_BASE_ZERO, dTp, CUSPARSE_ORDER_ROW))
730 return reinterpret_cast<void *
>(mat);
734mgpuDestroySpMat(
void *m, CUstream ) {
735 cusparseSpMatDescr_t mat =
reinterpret_cast<cusparseSpMatDescr_t
>(m);
740 int32_t ma,
void *a,
void *x,
void *y, int32_t ctp, CUstream ) {
741 assert(cusparse_env &&
"client did not call mgpuCreateSparseEnv()");
742 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
743 cusparseSpMatDescr_t matA =
reinterpret_cast<cusparseSpMatDescr_t
>(a);
744 cusparseDnVecDescr_t vecX =
reinterpret_cast<cusparseDnVecDescr_t
>(x);
745 cusparseDnVecDescr_t vecY =
reinterpret_cast<cusparseDnVecDescr_t
>(y);
746 cudaDataType_t cTp =
static_cast<cudaDataType_t
>(ctp);
747 ALPHABETA(cTp, alpha, beta)
748 size_t bufferSize = 0;
750 cusparse_env, modeA, alphap, matA, vecX, betap, vecY, cTp,
751 CUSPARSE_SPMV_ALG_DEFAULT, &bufferSize))
756 void *y, int32_t ctp,
759 assert(cusparse_env &&
"client did not call mgpuCreateSparseEnv()");
760 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
761 cusparseSpMatDescr_t matA =
reinterpret_cast<cusparseSpMatDescr_t
>(a);
762 cusparseDnVecDescr_t vecX =
reinterpret_cast<cusparseDnVecDescr_t
>(x);
763 cusparseDnVecDescr_t vecY =
reinterpret_cast<cusparseDnVecDescr_t
>(y);
764 cudaDataType_t cTp =
static_cast<cudaDataType_t
>(ctp);
765 ALPHABETA(cTp, alpha, beta)
768 CUSPARSE_SPMV_ALG_DEFAULT, buf))
772mgpuSpMMBufferSize(int32_t ma, int32_t mb,
void *a,
void *
b,
void *c,
773 int32_t ctp, CUstream ) {
774 assert(cusparse_env &&
"client did not call mgpuCreateSparseEnv()");
775 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
776 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
777 cusparseSpMatDescr_t matA =
reinterpret_cast<cusparseSpMatDescr_t
>(a);
778 cusparseDnMatDescr_t matB =
reinterpret_cast<cusparseDnMatDescr_t
>(
b);
779 cusparseDnMatDescr_t matC =
reinterpret_cast<cusparseDnMatDescr_t
>(c);
780 cudaDataType_t cTp =
static_cast<cudaDataType_t
>(ctp);
781 ALPHABETA(cTp, alpha, beta)
782 size_t bufferSize = 0;
784 cusparse_env, modeA, modeB, alphap, matA, matB, betap, matC, cTp,
785 CUSPARSE_SPMM_ALG_DEFAULT, &bufferSize))
790 void *a,
void *
b,
void *c,
791 int32_t ctp,
void *buf,
793 assert(cusparse_env &&
"client did not call mgpuCreateSparseEnv()");
794 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
795 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
796 cusparseSpMatDescr_t matA =
reinterpret_cast<cusparseSpMatDescr_t
>(a);
797 cusparseDnMatDescr_t matB =
reinterpret_cast<cusparseDnMatDescr_t
>(
b);
798 cusparseDnMatDescr_t matC =
reinterpret_cast<cusparseDnMatDescr_t
>(c);
799 cudaDataType_t cTp =
static_cast<cudaDataType_t
>(ctp);
800 ALPHABETA(cTp, alpha, beta)
802 matA, matB, betap, matC, cTp,
803 CUSPARSE_SPMM_ALG_DEFAULT, buf))
807mgpuSDDMMBufferSize(int32_t ma, int32_t mb,
void *a,
void *
b,
void *c,
808 int32_t ctp, CUstream ) {
809 assert(cusparse_env &&
"client did not call mgpuCreateSparseEnv()");
810 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
811 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
812 cusparseDnMatDescr_t matA =
reinterpret_cast<cusparseDnMatDescr_t
>(a);
813 cusparseDnMatDescr_t matB =
reinterpret_cast<cusparseDnMatDescr_t
>(
b);
814 cusparseSpMatDescr_t matC =
reinterpret_cast<cusparseSpMatDescr_t
>(c);
815 auto cTp =
static_cast<cudaDataType_t
>(ctp);
816 ALPHABETA(cTp, alpha, beta)
817 size_t bufferSize = 0;
819 cusparse_env, modeA, modeB, alphap, matA, matB, betap, matC, cTp,
820 CUSPARSE_SDDMM_ALG_DEFAULT, &bufferSize))
825 void *a,
void *
b,
void *c,
826 int32_t ctp,
void *buf,
828 assert(cusparse_env &&
"client did not call mgpuCreateSparseEnv()");
829 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
830 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
831 cusparseDnMatDescr_t matA =
reinterpret_cast<cusparseDnMatDescr_t
>(a);
832 cusparseDnMatDescr_t matB =
reinterpret_cast<cusparseDnMatDescr_t
>(
b);
833 cusparseSpMatDescr_t matC =
reinterpret_cast<cusparseSpMatDescr_t
>(c);
834 auto cTp =
static_cast<cudaDataType_t
>(ctp);
835 ALPHABETA(cTp, alpha, beta)
837 matA, matB, betap, matC, cTp,
838 CUSPARSE_SDDMM_ALG_DEFAULT, buf))
842mgpuSpGEMMCreateDescr(CUstream ) {
843 cusparseSpGEMMDescr_t spgemmDesc =
nullptr;
845 return reinterpret_cast<void *
>(spgemmDesc);
849mgpuSpGEMMDestroyDescr(
void *s, CUstream ) {
850 cusparseSpGEMMDescr_t spgemmDesc =
reinterpret_cast<cusparseSpGEMMDescr_t
>(s);
855 void *s, int32_t ma, int32_t mb,
void *a,
void *
b,
void *c, int32_t ctp,
856 intptr_t bs,
void *buf, CUstream ) {
857 cusparseSpGEMMDescr_t spgemmDesc =
reinterpret_cast<cusparseSpGEMMDescr_t
>(s);
858 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
859 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
860 cusparseSpMatDescr_t matA =
reinterpret_cast<cusparseSpMatDescr_t
>(a);
861 cusparseSpMatDescr_t matB =
reinterpret_cast<cusparseSpMatDescr_t
>(
b);
862 cusparseSpMatDescr_t matC =
reinterpret_cast<cusparseSpMatDescr_t
>(c);
863 auto cTp =
static_cast<cudaDataType_t
>(ctp);
864 ALPHABETA(cTp, alpha, beta)
865 size_t newBufferSize = bs;
867 cusparse_env, modeA, modeB, alphap, matA, matB, betap, matC, cTp,
868 CUSPARSE_SPGEMM_DEFAULT, spgemmDesc, &newBufferSize, buf))
869 return newBufferSize;
873mgpuSpGEMMCompute(
void *s, int32_t ma, int32_t mb,
void *a,
void *
b,
void *c,
874 int32_t ctp,
intptr_t bsz2,
void *buf2, CUstream ) {
875 cusparseSpGEMMDescr_t spgemmDesc =
reinterpret_cast<cusparseSpGEMMDescr_t
>(s);
876 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
877 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
878 cusparseSpMatDescr_t matA =
reinterpret_cast<cusparseSpMatDescr_t
>(a);
879 cusparseSpMatDescr_t matB =
reinterpret_cast<cusparseSpMatDescr_t
>(
b);
880 cusparseSpMatDescr_t matC =
reinterpret_cast<cusparseSpMatDescr_t
>(c);
881 auto cTp =
static_cast<cudaDataType_t
>(ctp);
882 ALPHABETA(cTp, alpha, beta)
883 size_t newBufferSize2 = bsz2;
885 cusparse_env, modeA, modeB, alphap, matA, matB, betap, matC, cTp,
886 CUSPARSE_SPGEMM_DEFAULT, spgemmDesc, &newBufferSize2, buf2))
887 return newBufferSize2;
891mgpuSpGEMMCopy(
void *s, int32_t ma, int32_t mb,
void *a,
void *
b,
void *c,
892 int32_t ctp, CUstream ) {
893 cusparseSpGEMMDescr_t spgemmDesc =
reinterpret_cast<cusparseSpGEMMDescr_t
>(s);
894 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
895 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
896 cusparseSpMatDescr_t matA =
reinterpret_cast<cusparseSpMatDescr_t
>(a);
897 cusparseSpMatDescr_t matB =
reinterpret_cast<cusparseSpMatDescr_t
>(
b);
898 cusparseSpMatDescr_t matC =
reinterpret_cast<cusparseSpMatDescr_t
>(c);
899 auto cTp =
static_cast<cudaDataType_t
>(ctp);
900 ALPHABETA(cTp, alpha, beta)
902 cusparseSpGEMM_copy(cusparse_env, modeA, modeB, alphap, matA, matB, betap,
903 matC, cTp, CUSPARSE_SPGEMM_DEFAULT, spgemmDesc))
907mgpuSpMatGetSize(
void *m,
void *r,
void *c,
void *n, CUstream ) {
908 cusparseConstSpMatDescr_t matDescr =
909 reinterpret_cast<cusparseConstSpMatDescr_t
>(m);
917mgpuSetCsrPointers(
void *m,
void *p,
void *c,
void *v, CUstream ) {
918 cusparseSpMatDescr_t matDescr =
reinterpret_cast<cusparseSpMatDescr_t
>(m);
922#ifdef MLIR_ENABLE_CUDA_CUSPARSELT
928struct cusparseLtSpMatHandleAndData {
929 cusparseLtMatDescriptor_t mat;
933 cusparseLtMatmulAlgSelection_t alg_sel;
934 cusparseLtMatmulPlan_t plan;
935 cusparseLtMatmulDescriptor_t matmul;
936 void *values{
nullptr};
939struct cusparseLtDnMatHandleAndData {
940 cusparseLtMatDescriptor_t mat;
941 void *values{
nullptr};
944static_assert(
sizeof(cusparseLtHandle_t) == 11024,
945 "Unexpected cusparseLt handle size");
946static_assert(
sizeof(cusparseLtSpMatHandleAndData) == 44104,
947 "Unexpected cusparseLt sparse matrix handle size");
948static_assert(
sizeof(cusparseLtDnMatHandleAndData) == 11032,
949 "Unexpected cusparseLt dense matrix handle size");
954 assert(!cusparseLt_initiated &&
955 "client called mgpuCreateSparseLtEnv() twice");
958 cusparseLt_initiated =
true;
962 assert(cusparseLt_initiated &&
"client did not call mgpuCreateSparseLtEnv()");
964 cusparseLt_initiated =
false;
968mgpuCreateCuSparseLtDnMat(
void *dh,
intptr_t rows,
intptr_t cols,
void *values,
969 int32_t dtp, CUstream ) {
970 assert(cusparseLt_initiated &&
"client did not call mgpuCreateSparseLtEnv()");
971 auto dnmat_handle =
reinterpret_cast<cusparseLtDnMatHandleAndData *
>(dh);
972 dnmat_handle->values = values;
973 auto dTp =
static_cast<cudaDataType_t
>(dtp);
975 const uint32_t alignment = 16;
977 &cusparseLt_env, &(dnmat_handle->mat), rows, cols, cols,
978 alignment, dTp, CUSPARSE_ORDER_ROW))
982mgpuDestroyCuSparseLtDnMat(
void *dh, CUstream ) {
983 auto dnmat_handle =
reinterpret_cast<cusparseLtDnMatHandleAndData *
>(dh);
989 void *values, int32_t dtp, CUstream ) {
990 assert(cusparseLt_initiated &&
"client did not call mgpuCreateSparseLtEnv()");
991 auto spmat_handle =
reinterpret_cast<cusparseLtSpMatHandleAndData *
>(sh);
992 spmat_handle->values = values;
993 auto dTp =
static_cast<cudaDataType_t
>(dtp);
995 const uint32_t alignment = 16;
997 &cusparseLt_env, &(spmat_handle->mat), rows, cols, cols, alignment,
998 dTp, CUSPARSE_ORDER_ROW, CUSPARSELT_SPARSITY_50_PERCENT))
1002mgpuDestroyCuSparseLtSpMat(
void *sh, CUstream ) {
1003 auto spmat_handle =
reinterpret_cast<cusparseLtSpMatHandleAndData *
>(sh);
1013mgpuCuSparseLtSpMMBufferSize(
void *bs, int32_t ma, int32_t mb,
void *a,
void *
b,
1014 void *c, int32_t ctp, int32_t prune_flag,
1016 assert(cusparseLt_initiated &&
"client did not call mgpuCreateSparseLtEnv()");
1019 auto matA =
reinterpret_cast<cusparseLtSpMatHandleAndData *
>(a);
1020 auto matB =
reinterpret_cast<cusparseLtDnMatHandleAndData *
>(
b);
1021 auto matC =
reinterpret_cast<cusparseLtDnMatHandleAndData *
>(c);
1022 auto workspace_size =
reinterpret_cast<size_t *
>(bs);
1023 auto compressed_size = &(
reinterpret_cast<size_t *
>(bs)[1]);
1024 auto compressed_buffer_size = &(
reinterpret_cast<size_t *
>(bs)[2]);
1025 auto cTp =
static_cast<cusparseComputeType
>(ctp);
1027 cusparseOperation_t modeA =
static_cast<cusparseOperation_t
>(ma);
1028 cusparseOperation_t modeB =
static_cast<cusparseOperation_t
>(mb);
1030 &cusparseLt_env, &(matA->matmul), modeA, modeB, &(matA->mat),
1031 &(matB->mat), &(matC->mat), &(matC->mat), cTp))
1033 &cusparseLt_env, &(matA->alg_sel), &(matA->matmul),
1034 CUSPARSELT_MATMUL_ALG_DEFAULT))
1037 &cusparseLt_env, &(matA->alg_sel), CUSPARSELT_MATMUL_ALG_CONFIG_ID, &alg,
1041 &cusparseLt_env, &(matA->plan), &(matA->matmul), &(matA->alg_sel)))
1046 &cusparseLt_env, &(matA->matmul), matA->values, matA->values,
1047 CUSPARSELT_PRUNE_SPMMA_STRIP, stream))
1052 if (prune_flag == 2) {
1053 int *dvalid = (
int *)
mgpuMemAlloc(
sizeof(
int), stream,
false);
1055 &cusparseLt_env, &(matA->matmul), matA->values, dvalid, stream))
1057 mgpuMemcpy(&valid, dvalid,
sizeof(
int), stream);
1061 fprintf(stderr,
"CUPARSE-LT: sparse matrix is not 2:4; computed results "
1062 "will be invalid\n");
1066 &cusparseLt_env, &(matA->plan), workspace_size))
1068 &cusparseLt_env, &(matA->plan), compressed_size, compressed_buffer_size))
1072mgpuCuSparseLtSpMM(
void *a,
void *
b,
void *c,
void *d_workspace,
1073 void *dA_compressed,
void *dA_compressedBuffer,
1075 assert(cusparseLt_initiated &&
"client did not call mgpuCreateSparseLtEnv()");
1076 auto matA =
reinterpret_cast<cusparseLtSpMatHandleAndData *
>(a);
1077 auto matB =
reinterpret_cast<cusparseLtDnMatHandleAndData *
>(
b);
1078 auto matC =
reinterpret_cast<cusparseLtDnMatHandleAndData *
>(c);
1080 ALPHABETA(CUDA_R_32F, alpha, beta)
1082 cusparseLtSpMMACompress(&cusparseLt_env, &(matA->plan), (matA->values),
1083 dA_compressed, dA_compressedBuffer, stream))
1088 cusparseLtMatmul(&cusparseLt_env, &(matA->plan), alphap, dA_compressed,
1089 matB->values, betap, matC->values,
1090 matC->values, d_workspace,
nullptr, 0))
#define CUSPARSE_REPORT_IF_ERROR(expr)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuStreamWaitEvent(CUstream stream, CUevent event)
#define MLIR_CUDA_WRAPPERS_EXPORT
MLIR_CUDA_WRAPPERS_EXPORT void mgpuModuleUnload(CUmodule module)
MLIR_CUDA_WRAPPERS_EXPORT void * mgpuMemAlloc(uint64_t sizeBytes, CUstream stream, bool isHostShared)
#define CUDA_REPORT_IF_ERROR(expr)
static thread_local int32_t defaultDevice
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemHostRegisterMemRef(int64_t rank, StridedMemRefType< char, 1 > *descriptor, int64_t elementSizeBytes)
Registers a memref with the CUDA runtime.
MLIR_CUDA_WRAPPERS_EXPORT CUmodule mgpuModuleLoadJIT(void *data, int optLevel, size_t)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemHostUnregister(void *ptr)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuEventRecord(CUevent event, CUstream stream)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemcpy(void *dst, void *src, size_t sizeBytes, CUstream stream)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemset16(void *dst, unsigned short value, size_t count, CUstream stream)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemset32(void *dst, unsigned int value, size_t count, CUstream stream)
MLIR_CUDA_WRAPPERS_EXPORT CUfunction mgpuModuleGetFunction(CUmodule module, const char *name)
#define debug_print(fmt,...)
MLIR_CUDA_WRAPPERS_EXPORT CUevent mgpuEventCreate()
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemHostRegister(void *ptr, uint64_t sizeBytes)
Helper functions for writing mlir example code.
static bool isDebugEnabled()
Helper method that checks environment value for debugging.
MLIR_CUDA_WRAPPERS_EXPORT void mgpuStreamSynchronize(CUstream stream)
MLIR_CUDA_WRAPPERS_EXPORT CUstream mgpuStreamCreate()
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemFree(void *ptr, CUstream)
MLIR_CUDA_WRAPPERS_EXPORT CUmodule mgpuModuleLoad(void *data, size_t)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuSetDefaultDevice(int32_t device)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuStreamDestroy(CUstream stream)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuLaunchKernel(CUfunction function, intptr_t gridX, intptr_t gridY, intptr_t gridZ, intptr_t blockX, intptr_t blockY, intptr_t blockZ, int32_t smem, CUstream stream, void **params, void **extra, size_t)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuMemHostUnregisterMemRef(int64_t rank, StridedMemRefType< char, 1 > *descriptor, int64_t elementSizeBytes)
Unregisters a memref with the CUDA runtime.
MLIR_CUDA_WRAPPERS_EXPORT void mgpuEventSynchronize(CUevent event)
MLIR_CUDA_WRAPPERS_EXPORT void mgpuEventDestroy(CUevent event)
static CUdevice getDefaultCuDevice()
void mgpuLaunchKernelCooperative(hipFunction_t function, intptr_t gridX, intptr_t gridY, intptr_t gridZ, intptr_t clusterX, intptr_t clusterY, intptr_t clusterZ, intptr_t blockX, intptr_t blockY, intptr_t blockZ, int32_t smem, hipStream_t stream, void **params, void **)
StridedMemRef descriptor type with static rank.