blob: 280871dac558aa0a2d24d9306566f46d29129342 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
// 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 <stdio.h>
#include <stdlib.h>
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<slang::IGlobalSession> 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<slang::ISession> session;
SLANG_CHECK(globalSession->createSession(sessionDesc, session.writeRef()) == SLANG_OK);
ComPtr<slang::IBlob> diagnosticBlob;
auto module = session->loadModuleFromSourceString(
"m",
"m.slang",
userSourceBody,
diagnosticBlob.writeRef());
SLANG_CHECK(module != nullptr);
ComPtr<slang::IComponentType> linkedProgram;
module->link(linkedProgram.writeRef(), diagnosticBlob.writeRef());
SLANG_CHECK(linkedProgram != nullptr);
ComPtr<slang::IBlob> 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);
}
|