// unit-test-cuda-compile.cpp #include "../../source/core/slang-io.h" #include "../../source/core/slang-process.h" #include "slang-com-ptr.h" #include "slang.h" #include "unit-test/slang-unit-test.h" #include #include using namespace Slang; // Test that the compilation API can be used to produce CUDA source. SLANG_UNIT_TEST(CudaCompile) { // Source for a module that contains an undecorated entrypoint. const char* userSourceBody = R"( [CudaDeviceExport] float testExportedFunc(float3 particleRayOrigin) { return dot(particleRayOrigin,particleRayOrigin); }; )"; auto moduleName = "moduleG" + String(Process::getId()); ComPtr globalSession; SLANG_CHECK(slang_createGlobalSession(SLANG_API_VERSION, globalSession.writeRef()) == SLANG_OK); slang::TargetDesc targetDesc = {}; targetDesc.format = SLANG_CUDA_SOURCE; slang::SessionDesc sessionDesc = {}; sessionDesc.targetCount = 1; sessionDesc.targets = &targetDesc; ComPtr session; SLANG_CHECK(globalSession->createSession(sessionDesc, session.writeRef()) == SLANG_OK); ComPtr diagnosticBlob; auto module = session->loadModuleFromSourceString( "m", "m.slang", userSourceBody, diagnosticBlob.writeRef()); SLANG_CHECK(module != nullptr); ComPtr linkedProgram; module->link(linkedProgram.writeRef(), diagnosticBlob.writeRef()); SLANG_CHECK(linkedProgram != nullptr); ComPtr code; linkedProgram->getTargetCode(0, code.writeRef(), diagnosticBlob.writeRef()); SLANG_CHECK(code != nullptr); SLANG_CHECK(code->getBufferSize() != 0); String text = String((char*)code->getBufferPointer()); SLANG_CHECK(text.indexOf("testExportedFunc") > 0); }