| 1 | /* Minimal declarations for CUDA support. Testing purposes only. */ |
| 2 | |
| 3 | #include <stddef.h> |
| 4 | |
| 5 | #define __constant__ __attribute__((constant)) |
| 6 | #define __device__ __attribute__((device)) |
| 7 | #define __global__ __attribute__((global)) |
| 8 | #define __host__ __attribute__((host)) |
| 9 | #define __shared__ __attribute__((shared)) |
| 10 | #define __launch_bounds__(...) __attribute__((launch_bounds(__VA_ARGS__))) |
| 11 | |
| 12 | struct dim3 { |
| 13 | unsigned x, y, z; |
| 14 | __host__ __device__ dim3(unsigned x, unsigned y = 1, unsigned z = 1) : x(x), y(y), z(z) {} |
| 15 | }; |
| 16 | |
| 17 | typedef struct cudaStream *cudaStream_t; |
| 18 | typedef enum cudaError {} cudaError_t; |
| 19 | #ifdef __HIP__ |
| 20 | int hipConfigureCall(dim3 gridSize, dim3 blockSize, size_t sharedSize = 0, |
| 21 | cudaStream_t stream = 0); |
| 22 | #else |
| 23 | extern "C" int cudaConfigureCall(dim3 gridSize, dim3 blockSize, |
| 24 | size_t sharedSize = 0, |
| 25 | cudaStream_t stream = 0); |
| 26 | extern "C" int __cudaPushCallConfiguration(dim3 gridSize, dim3 blockSize, |
| 27 | size_t sharedSize = 0, |
| 28 | cudaStream_t stream = 0); |
| 29 | extern "C" cudaError_t cudaLaunchKernel(const void *func, dim3 gridDim, |
| 30 | dim3 blockDim, void **args, |
| 31 | size_t sharedMem, cudaStream_t stream); |
| 32 | #endif |
| 33 | |
| 34 | extern "C" __device__ int printf(const char*, ...); |
| 35 | |