-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathcuImage.cu
117 lines (97 loc) · 3.04 KB
/
cuImage.cu
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
//********************************************************//
// CUDA SIFT extractor by Marten Bjorkman aka Celebrandil //
//********************************************************//
#include <cstdio>
#include "cutils.h"
#include "cuImage.h"
// Convenience function to allocate memory
void cuImage::AllocateWithHostMemory(int width, int height, float *h_data) {
Allocate(width, height, iAlignUp(width, 128), false, NULL, h_data);
}
// Allocate memory on the host and device
void cuImage::Allocate(int width, int height, int pitch, bool host, float *d_data, float *h_data)
{
// Set image width and height
this->width = width;
this->height = height;
this->pitch = pitch;
// Set device and host data
this->d_data = d_data;
this->h_data = h_data;
t_data = NULL;
// If pointer to device memory is NULL, allocate
if (this->d_data == NULL) {
safeCall(cudaMallocPitch((void **)&this->d_data, (size_t *)&pitch, (size_t)(sizeof(float) * width), (size_t)height));
// Assume pitch is correctly aligned
pitch /= sizeof(float);
if (this->d_data == NULL) {
printf("Failed to allocate device data\n");
}
d_internalAlloc = true;
}
// If pointer to host memory is NULL and we would like to allocate host memory
if (host && this->h_data == NULL) {
this->h_data = (float *)malloc(sizeof(float) * pitch * height);
h_internalAlloc = true;
}
}
cuImage::cuImage() :
width(0), height(0), d_data(NULL), h_data(NULL), t_data(NULL), d_internalAlloc(false), h_internalAlloc(false)
{
}
cuImage::cuImage(int width, int height, float *h_data, bool download) {
d_internalAlloc = false;
h_internalAlloc = false;
AllocateWithHostMemory(width, height, h_data);
if (download) {
HostToDevice();
}
}
cuImage::~cuImage()
{
// If we've allocated device memory, free
if (d_internalAlloc && d_data != NULL) {
safeCall(cudaFree(d_data));
}
d_data = NULL;
// If we've allocated host memory, free
if (h_internalAlloc && h_data != NULL) {
free(h_data);
}
h_data = NULL;
if (t_data != NULL) {
safeCall(cudaFreeArray((cudaArray *)t_data));
}
t_data = NULL;
}
// Copy image from host memory to device memory
double cuImage::HostToDevice()
{
TimerGPU timer(0);
int p = sizeof(float) * pitch;
// Check if both device and host data are non-null
if (d_data != NULL && h_data != NULL) {
safeCall(cudaMemcpy2D(d_data, p, h_data, sizeof(float) * width,
sizeof(float) * width, height, cudaMemcpyHostToDevice));
}
double gpuTime = timer.read();
#ifdef VERBOSE
printf("HostToDevice time = %.2f ms\n", gpuTime);
#endif
return gpuTime;
}
// Copy image from device memory to host memory
double cuImage::DeviceToHost()
{
TimerGPU timer(0);
int p = sizeof(float) * pitch;
if (d_data != NULL && h_data != NULL) {
safeCall(cudaMemcpy2D(h_data, sizeof(float) * width, d_data, p,
sizeof(float) * width, height, cudaMemcpyDeviceToHost));
}
double gpuTime = timer.read();
#ifdef VERBOSE
printf("DeviceToHost time = %.2f ms\n", gpuTime);
#endif
return gpuTime;
}