Faiss
 All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator Friends
GpuResources.cpp
1 /**
2  * Copyright (c) 2015-present, Facebook, Inc.
3  * All rights reserved.
4  *
5  * This source code is licensed under the BSD+Patents license found in the
6  * LICENSE file in the root directory of this source tree.
7  */
8 
9 
10 #include "GpuResources.h"
11 #include "utils/DeviceUtils.h"
12 
13 namespace faiss { namespace gpu {
14 
15 GpuResources::~GpuResources() {
16 }
17 
18 cublasHandle_t
20  return getBlasHandle(getCurrentDevice());
21 }
22 
23 cudaStream_t
25  return getDefaultStream(getCurrentDevice());
26 }
27 
28 std::vector<cudaStream_t>
30  return getAlternateStreams(getCurrentDevice());
31 }
32 
35  return getMemoryManager(getCurrentDevice());
36 }
37 
38 cudaStream_t
40  return getAsyncCopyStream(getCurrentDevice());
41 }
42 
43 void
45  CUDA_VERIFY(cudaStreamSynchronize(getDefaultStream(device)));
46 }
47 
48 void
50  syncDefaultStream(getCurrentDevice());
51 }
52 
53 } } // namespace
cudaStream_t getDefaultStreamCurrentDevice()
Calls getDefaultStream with the current device.
virtual cublasHandle_t getBlasHandle(int device)=0
Returns the cuBLAS handle that we use for the given device.
virtual cudaStream_t getDefaultStream(int device)=0
cublasHandle_t getBlasHandleCurrentDevice()
Calls getBlasHandle with the current device.
DeviceMemory & getMemoryManagerCurrentDevice()
Calls getMemoryManager for the current device.
void syncDefaultStreamCurrentDevice()
Calls syncDefaultStream for the current device.
cudaStream_t getAsyncCopyStreamCurrentDevice()
Calls getAsyncCopyStream for the current device.
std::vector< cudaStream_t > getAlternateStreamsCurrentDevice()
Calls getAlternateStreams for the current device.
virtual cudaStream_t getAsyncCopyStream(int device)=0
Returns the stream on which we perform async CPU &lt;-&gt; GPU copies.
void syncDefaultStream(int device)
virtual DeviceMemory & getMemoryManager(int device)=0
Returns the temporary memory manager for the given device.
Manages temporary memory allocations on a GPU device.
Definition: DeviceMemory.h:45
virtual std::vector< cudaStream_t > getAlternateStreams(int device)=0
Returns the set of alternative streams that we use for the given device.