-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathSiPixelDigiErrorsCUDA.cc
42 lines (33 loc) · 1.66 KB
/
SiPixelDigiErrorsCUDA.cc
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
#include "CUDADataFormats/SiPixelDigiErrorsCUDA.h"
#include "CUDACore/device_unique_ptr.h"
#include "CUDACore/host_unique_ptr.h"
#include "CUDACore/copyAsync.h"
#include "CUDACore/memsetAsync.h"
#include <cassert>
SiPixelDigiErrorsCUDA::SiPixelDigiErrorsCUDA(size_t maxFedWords, PixelFormatterErrors errors, cudaStream_t stream)
: formatterErrors_h(std::move(errors)) {
error_d = cms::cuda::make_device_unique<cms::cuda::SimpleVector<PixelErrorCompact>>(stream);
data_d = cms::cuda::make_device_unique<PixelErrorCompact[]>(maxFedWords, stream);
cms::cuda::memsetAsync(data_d, 0x00, maxFedWords, stream);
error_h = cms::cuda::make_host_unique<cms::cuda::SimpleVector<PixelErrorCompact>>(stream);
cms::cuda::make_SimpleVector(error_h.get(), maxFedWords, data_d.get());
assert(error_h->empty());
assert(error_h->capacity() == static_cast<int>(maxFedWords));
cms::cuda::copyAsync(error_d, error_h, stream);
}
void SiPixelDigiErrorsCUDA::copyErrorToHostAsync(cudaStream_t stream) {
cms::cuda::copyAsync(error_h, error_d, stream);
}
SiPixelDigiErrorsCUDA::HostDataError SiPixelDigiErrorsCUDA::dataErrorToHostAsync(cudaStream_t stream) const {
// On one hand size() could be sufficient. On the other hand, if
// someone copies the SimpleVector<>, (s)he might expect the data
// buffer to actually have space for capacity() elements.
auto data = cms::cuda::make_host_unique<PixelErrorCompact[]>(error_h->capacity(), stream);
// but transfer only the required amount
if (not error_h->empty()) {
cms::cuda::copyAsync(data, data_d, error_h->size(), stream);
}
auto err = *error_h;
err.set_data(data.get());
return HostDataError(err, std::move(data));
}