aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2010-06-21 10:22:16 +0200
committerThomas White <taw@physics.org>2012-02-22 15:26:50 +0100
commit2ec9faae510e2eed77e60fbcf31f869a19fca9bf (patch)
tree84cf1aed650f5c8688feef29fa6195031d2168ae
parent6d4420d686800568ddf3210e3f4e66c914944088 (diff)
pattern_sim: Fix up GPU diffraction for new detector geometry
-rw-r--r--src/diffraction-gpu.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/src/diffraction-gpu.c b/src/diffraction-gpu.c
index 6d576287..86594a47 100644
--- a/src/diffraction-gpu.c
+++ b/src/diffraction-gpu.c
@@ -232,52 +232,52 @@ void get_diffraction_gpu(struct gpu_context *gctx, struct image *image,
}
/* Iterate over panels */
- event = malloc(image->det.n_panels * sizeof(cl_event));
- for ( p=0; p<image->det.n_panels; p++ ) {
+ event = malloc(image->det->n_panels * sizeof(cl_event));
+ for ( p=0; p<image->det->n_panels; p++ ) {
size_t dims[3];
size_t ldims[3] = {SAMPLING, SAMPLING, BWSAMPLING};
/* In a future version of OpenCL, this could be done
* with a global work offset. But not yet... */
- dims[0] = 1+image->det.panels[0].max_x-image->det.panels[0].min_x;
- dims[1] = 1+image->det.panels[0].max_y-image->det.panels[0].min_y;
+ dims[0] = 1+image->det->panels[0].max_x-image->det->panels[0].min_x;
+ dims[1] = 1+image->det->panels[0].max_y-image->det->panels[0].min_y;
dims[0] *= SAMPLING;
dims[1] *= SAMPLING;
dims[2] = BWSAMPLING;
clSetKernelArg(gctx->kern, 4, sizeof(cl_float),
- &image->det.panels[p].cx);
+ &image->det->panels[p].cx);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't set arg 4: %s\n", clError(err));
return;
}
clSetKernelArg(gctx->kern, 5, sizeof(cl_float),
- &image->det.panels[p].cy);
+ &image->det->panels[p].cy);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't set arg 5: %s\n", clError(err));
return;
}
clSetKernelArg(gctx->kern, 6, sizeof(cl_float),
- &image->det.panels[p].res);
+ &image->det->panels[p].res);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't set arg 6: %s\n", clError(err));
return;
}
clSetKernelArg(gctx->kern, 7, sizeof(cl_float),
- &image->det.panels[p].clen);
+ &image->det->panels[p].clen);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't set arg 7: %s\n", clError(err));
return;
}
clSetKernelArg(gctx->kern, 11, sizeof(cl_int),
- &image->det.panels[p].min_x);
+ &image->det->panels[p].min_x);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't set arg 11: %s\n", clError(err));
return;
}
clSetKernelArg(gctx->kern, 12, sizeof(cl_int),
- &image->det.panels[p].min_y);
+ &image->det->panels[p].min_y);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't set arg 12: %s\n", clError(err));
return;
@@ -294,13 +294,13 @@ void get_diffraction_gpu(struct gpu_context *gctx, struct image *image,
diff_ptr = clEnqueueMapBuffer(gctx->cq, gctx->diff, CL_TRUE,
CL_MAP_READ, 0, gctx->diff_size,
- image->det.n_panels, event, NULL, &err);
+ image->det->n_panels, event, NULL, &err);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't map diffraction buffer: %s\n", clError(err));
return;
}
tt_ptr = clEnqueueMapBuffer(gctx->cq, gctx->tt, CL_TRUE, CL_MAP_READ, 0,
- gctx->tt_size, image->det.n_panels, event,
+ gctx->tt_size, image->det->n_panels, event,
NULL, &err);
if ( err != CL_SUCCESS ) {
ERROR("Couldn't map tt buffer\n");