aboutsummaryrefslogtreecommitdiff
path: root/libgomp
diff options
context:
space:
mode:
authorThomas Schwinge <thomas@codesourcery.com>2022-04-06 14:12:29 +0200
committerThomas Schwinge <thomas@codesourcery.com>2022-04-06 22:30:14 +0200
commit5e431ae4ccc5fb0e077e598cb4efb1e12fc66c68 (patch)
tree1e4a8ca3d571895cb30d293511407f51ce52c0e7 /libgomp
parent790e9814454662b6cd51d2fce1aa022ef73fedb8 (diff)
downloadgcc-5e431ae4ccc5fb0e077e598cb4efb1e12fc66c68.zip
gcc-5e431ae4ccc5fb0e077e598cb4efb1e12fc66c68.tar.gz
gcc-5e431ae4ccc5fb0e077e598cb4efb1e12fc66c68.tar.bz2
Move 'libgomp/plugin/cuda/cuda.h' to 'include/cuda/cuda.h'
... so that it may be used by other projects that inherit GCC's 'include' directory. include/ * cuda/cuda.h: New file. libgomp/ * plugin/cuda/cuda.h: Remove file. * plugin/plugin-nvptx.c [PLUGIN_NVPTX_DYNAMIC]: Include "cuda/cuda.h" instead of <cuda.h>. * plugin/configfrag.ac <PLUGIN_NVPTX_DYNAMIC>: Don't set 'PLUGIN_NVPTX_CPPFLAGS'. * configure: Regenerate.
Diffstat (limited to 'libgomp')
-rwxr-xr-xlibgomp/configure1
-rw-r--r--libgomp/plugin/configfrag.ac1
-rw-r--r--libgomp/plugin/cuda/cuda.h195
-rw-r--r--libgomp/plugin/plugin-nvptx.c6
4 files changed, 5 insertions, 198 deletions
diff --git a/libgomp/configure b/libgomp/configure
index bdbe3d1..5ef071e 100755
--- a/libgomp/configure
+++ b/libgomp/configure
@@ -15362,7 +15362,6 @@ rm -f core conftest.err conftest.$ac_objext \
&& (test "x$CUDA_DRIVER_LIB" = x \
|| test "x$CUDA_DRIVER_LIB" = xno); then
PLUGIN_NVPTX=1
- PLUGIN_NVPTX_CPPFLAGS='-I$(srcdir)/plugin/cuda'
PLUGIN_NVPTX_LIBS='-ldl'
PLUGIN_NVPTX_DYNAMIC=1
else
diff --git a/libgomp/plugin/configfrag.ac b/libgomp/plugin/configfrag.ac
index 9f9d0a7..09f87f4 100644
--- a/libgomp/plugin/configfrag.ac
+++ b/libgomp/plugin/configfrag.ac
@@ -197,7 +197,6 @@ if test x"$enable_offload_targets" != x; then
&& (test "x$CUDA_DRIVER_LIB" = x \
|| test "x$CUDA_DRIVER_LIB" = xno); then
PLUGIN_NVPTX=1
- PLUGIN_NVPTX_CPPFLAGS='-I$(srcdir)/plugin/cuda'
PLUGIN_NVPTX_LIBS='-ldl'
PLUGIN_NVPTX_DYNAMIC=1
else
diff --git a/libgomp/plugin/cuda/cuda.h b/libgomp/plugin/cuda/cuda.h
deleted file mode 100644
index 5c679c1..0000000
--- a/libgomp/plugin/cuda/cuda.h
+++ /dev/null
@@ -1,195 +0,0 @@
-/* CUDA API description.
- Copyright (C) 2017-2022 Free Software Foundation, Inc.
-
-This file is part of GCC.
-
-GCC is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 3, or (at your option)
-any later version.
-
-GCC is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
-
-Under Section 7 of GPL version 3, you are granted additional
-permissions described in the GCC Runtime Library Exception, version
-3.1, as published by the Free Software Foundation.
-
-You should have received a copy of the GNU General Public License and
-a copy of the GCC Runtime Library Exception along with this program;
-see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
-<http://www.gnu.org/licenses/>.
-
-This header provides the minimum amount of typedefs, enums and function
-declarations to be able to compile plugin-nvptx.c if cuda.h and
-libcuda.so.1 are not available. */
-
-#ifndef GCC_CUDA_H
-#define GCC_CUDA_H
-
-#include <stdlib.h>
-
-#define CUDA_VERSION 8000
-
-typedef void *CUcontext;
-typedef int CUdevice;
-#if defined(__LP64__) || defined(_WIN64)
-typedef unsigned long long CUdeviceptr;
-#else
-typedef unsigned CUdeviceptr;
-#endif
-typedef void *CUevent;
-typedef void *CUfunction;
-typedef void *CUlinkState;
-typedef void *CUmodule;
-typedef size_t (*CUoccupancyB2DSize)(int);
-typedef void *CUstream;
-
-typedef enum {
- CUDA_SUCCESS = 0,
- CUDA_ERROR_INVALID_VALUE = 1,
- CUDA_ERROR_OUT_OF_MEMORY = 2,
- CUDA_ERROR_INVALID_CONTEXT = 201,
- CUDA_ERROR_NOT_FOUND = 500,
- CUDA_ERROR_NOT_READY = 600,
- CUDA_ERROR_LAUNCH_FAILED = 719,
- CUDA_ERROR_COOPERATIVE_LAUNCH_TOO_LARGE = 720,
- CUDA_ERROR_NOT_PERMITTED = 800,
- CUDA_ERROR_NOT_SUPPORTED = 801,
- CUDA_ERROR_UNKNOWN = 999
-} CUresult;
-
-typedef enum {
- CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_BLOCK = 1,
- CU_DEVICE_ATTRIBUTE_WARP_SIZE = 10,
- CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_BLOCK = 12,
- CU_DEVICE_ATTRIBUTE_CLOCK_RATE = 13,
- CU_DEVICE_ATTRIBUTE_GPU_OVERLAP = 15,
- CU_DEVICE_ATTRIBUTE_MULTIPROCESSOR_COUNT = 16,
- CU_DEVICE_ATTRIBUTE_INTEGRATED = 18,
- CU_DEVICE_ATTRIBUTE_CAN_MAP_HOST_MEMORY = 19,
- CU_DEVICE_ATTRIBUTE_COMPUTE_MODE = 20,
- CU_DEVICE_ATTRIBUTE_CONCURRENT_KERNELS = 31,
- CU_DEVICE_ATTRIBUTE_MAX_THREADS_PER_MULTIPROCESSOR = 39,
- CU_DEVICE_ATTRIBUTE_ASYNC_ENGINE_COUNT = 40,
- CU_DEVICE_ATTRIBUTE_MAX_REGISTERS_PER_MULTIPROCESSOR = 82
-} CUdevice_attribute;
-
-enum {
- CU_EVENT_DEFAULT = 0,
- CU_EVENT_DISABLE_TIMING = 2
-};
-
-typedef enum {
- CU_FUNC_ATTRIBUTE_MAX_THREADS_PER_BLOCK = 0,
- CU_FUNC_ATTRIBUTE_NUM_REGS = 4
-} CUfunction_attribute;
-
-typedef enum {
- CU_JIT_WALL_TIME = 2,
- CU_JIT_INFO_LOG_BUFFER = 3,
- CU_JIT_INFO_LOG_BUFFER_SIZE_BYTES = 4,
- CU_JIT_ERROR_LOG_BUFFER = 5,
- CU_JIT_ERROR_LOG_BUFFER_SIZE_BYTES = 6,
- CU_JIT_OPTIMIZATION_LEVEL = 7,
- CU_JIT_LOG_VERBOSE = 12
-} CUjit_option;
-
-typedef enum {
- CU_JIT_INPUT_PTX = 1
-} CUjitInputType;
-
-enum {
- CU_CTX_SCHED_AUTO = 0
-};
-
-#define CU_LAUNCH_PARAM_END ((void *) 0)
-#define CU_LAUNCH_PARAM_BUFFER_POINTER ((void *) 1)
-#define CU_LAUNCH_PARAM_BUFFER_SIZE ((void *) 2)
-
-enum {
- CU_STREAM_DEFAULT = 0,
- CU_STREAM_NON_BLOCKING = 1
-};
-
-#define cuCtxCreate cuCtxCreate_v2
-CUresult cuCtxCreate (CUcontext *, unsigned, CUdevice);
-#define cuCtxDestroy cuCtxDestroy_v2
-CUresult cuCtxDestroy (CUcontext);
-CUresult cuCtxGetCurrent (CUcontext *);
-CUresult cuCtxGetDevice (CUdevice *);
-#define cuCtxPopCurrent cuCtxPopCurrent_v2
-CUresult cuCtxPopCurrent (CUcontext *);
-#define cuCtxPushCurrent cuCtxPushCurrent_v2
-CUresult cuCtxPushCurrent (CUcontext);
-CUresult cuCtxSynchronize (void);
-CUresult cuDeviceGet (CUdevice *, int);
-#define cuDeviceTotalMem cuDeviceTotalMem_v2
-CUresult cuDeviceTotalMem (size_t *, CUdevice);
-CUresult cuDeviceGetAttribute (int *, CUdevice_attribute, CUdevice);
-CUresult cuDeviceGetCount (int *);
-CUresult cuDeviceGetName (char *, int, CUdevice);
-CUresult cuEventCreate (CUevent *, unsigned);
-#define cuEventDestroy cuEventDestroy_v2
-CUresult cuEventDestroy (CUevent);
-CUresult cuEventElapsedTime (float *, CUevent, CUevent);
-CUresult cuEventQuery (CUevent);
-CUresult cuEventRecord (CUevent, CUstream);
-CUresult cuEventSynchronize (CUevent);
-CUresult cuFuncGetAttribute (int *, CUfunction_attribute, CUfunction);
-CUresult cuGetErrorString (CUresult, const char **);
-CUresult cuInit (unsigned);
-CUresult cuDriverGetVersion (int *);
-CUresult cuLaunchKernel (CUfunction, unsigned, unsigned, unsigned, unsigned,
- unsigned, unsigned, unsigned, CUstream, void **, void **);
-#define cuLinkAddData cuLinkAddData_v2
-CUresult cuLinkAddData (CUlinkState, CUjitInputType, void *, size_t, const char *,
- unsigned, CUjit_option *, void **);
-CUresult cuLinkComplete (CUlinkState, void **, size_t *);
-#define cuLinkCreate cuLinkCreate_v2
-CUresult cuLinkCreate (unsigned, CUjit_option *, void **, CUlinkState *);
-CUresult cuLinkDestroy (CUlinkState);
-#define cuMemGetInfo cuMemGetInfo_v2
-CUresult cuMemGetInfo (size_t *, size_t *);
-#define cuMemAlloc cuMemAlloc_v2
-CUresult cuMemAlloc (CUdeviceptr *, size_t);
-#define cuMemAllocHost cuMemAllocHost_v2
-CUresult cuMemAllocHost (void **, size_t);
-CUresult cuMemcpy (CUdeviceptr, CUdeviceptr, size_t);
-#define cuMemcpyDtoDAsync cuMemcpyDtoDAsync_v2
-CUresult cuMemcpyDtoDAsync (CUdeviceptr, CUdeviceptr, size_t, CUstream);
-#define cuMemcpyDtoH cuMemcpyDtoH_v2
-CUresult cuMemcpyDtoH (void *, CUdeviceptr, size_t);
-#define cuMemcpyDtoHAsync cuMemcpyDtoHAsync_v2
-CUresult cuMemcpyDtoHAsync (void *, CUdeviceptr, size_t, CUstream);
-#define cuMemcpyHtoD cuMemcpyHtoD_v2
-CUresult cuMemcpyHtoD (CUdeviceptr, const void *, size_t);
-#define cuMemcpyHtoDAsync cuMemcpyHtoDAsync_v2
-CUresult cuMemcpyHtoDAsync (CUdeviceptr, const void *, size_t, CUstream);
-#define cuMemFree cuMemFree_v2
-CUresult cuMemFree (CUdeviceptr);
-CUresult cuMemFreeHost (void *);
-#define cuMemGetAddressRange cuMemGetAddressRange_v2
-CUresult cuMemGetAddressRange (CUdeviceptr *, size_t *, CUdeviceptr);
-#define cuMemHostGetDevicePointer cuMemHostGetDevicePointer_v2
-CUresult cuMemHostGetDevicePointer (CUdeviceptr *, void *, unsigned);
-CUresult cuModuleGetFunction (CUfunction *, CUmodule, const char *);
-#define cuModuleGetGlobal cuModuleGetGlobal_v2
-CUresult cuModuleGetGlobal (CUdeviceptr *, size_t *, CUmodule, const char *);
-CUresult cuModuleLoad (CUmodule *, const char *);
-CUresult cuModuleLoadData (CUmodule *, const void *);
-CUresult cuModuleUnload (CUmodule);
-CUresult cuOccupancyMaxPotentialBlockSize(int *, int *, CUfunction,
- CUoccupancyB2DSize, size_t, int);
-typedef void (*CUstreamCallback)(CUstream, CUresult, void *);
-CUresult cuStreamAddCallback(CUstream, CUstreamCallback, void *, unsigned int);
-CUresult cuStreamCreate (CUstream *, unsigned);
-#define cuStreamDestroy cuStreamDestroy_v2
-CUresult cuStreamDestroy (CUstream);
-CUresult cuStreamQuery (CUstream);
-CUresult cuStreamSynchronize (CUstream);
-CUresult cuStreamWaitEvent (CUstream, CUevent, unsigned);
-
-#endif /* GCC_CUDA_H */
diff --git a/libgomp/plugin/plugin-nvptx.c b/libgomp/plugin/plugin-nvptx.c
index b4f0a84..b28dfca 100644
--- a/libgomp/plugin/plugin-nvptx.c
+++ b/libgomp/plugin/plugin-nvptx.c
@@ -41,7 +41,11 @@
#include "oacc-int.h"
#include <pthread.h>
-#include <cuda.h>
+#if PLUGIN_NVPTX_DYNAMIC
+# include "cuda/cuda.h"
+#else
+# include <cuda.h>
+#endif
#include <stdbool.h>
#include <limits.h>
#include <string.h>