|
|
|
@ -13,7 +13,7 @@ ModelFrame::ModelFrame(cl_device_id device_id, cl_context context) { |
|
|
|
|
y_cl = CL_CHECK_ERR(clCreateBuffer(context, CL_MEM_READ_WRITE, MODEL_WIDTH * MODEL_HEIGHT, NULL, &err)); |
|
|
|
|
u_cl = CL_CHECK_ERR(clCreateBuffer(context, CL_MEM_READ_WRITE, (MODEL_WIDTH / 2) * (MODEL_HEIGHT / 2), NULL, &err)); |
|
|
|
|
v_cl = CL_CHECK_ERR(clCreateBuffer(context, CL_MEM_READ_WRITE, (MODEL_WIDTH / 2) * (MODEL_HEIGHT / 2), NULL, &err)); |
|
|
|
|
net_input_cl = CL_CHECK_ERR(clCreateBuffer(context, CL_MEM_READ_WRITE, MODEL_FRAME_SIZE * sizeof(uint8_t), NULL, &err)); |
|
|
|
|
net_input_cl = CL_CHECK_ERR(clCreateBuffer(context, CL_MEM_READ_WRITE, frame_size_bytes, NULL, &err)); |
|
|
|
|
|
|
|
|
|
transform_init(&transform, context, device_id); |
|
|
|
|
loadyuv_init(&loadyuv, context, device_id, MODEL_WIDTH, MODEL_HEIGHT); |
|
|
|
@ -24,15 +24,16 @@ uint8_t* ModelFrame::prepare(cl_mem yuv_cl, int frame_width, int frame_height, i |
|
|
|
|
yuv_cl, frame_width, frame_height, frame_stride, frame_uv_offset, |
|
|
|
|
y_cl, u_cl, v_cl, MODEL_WIDTH, MODEL_HEIGHT, projection); |
|
|
|
|
|
|
|
|
|
loadyuv_queue(&loadyuv, q, y_cl, u_cl, v_cl, net_input_cl); |
|
|
|
|
if (output == NULL) { |
|
|
|
|
loadyuv_queue(&loadyuv, q, y_cl, u_cl, v_cl, net_input_cl); |
|
|
|
|
|
|
|
|
|
std::memmove(&input_frames[0], &input_frames[MODEL_FRAME_SIZE], sizeof(uint8_t) * MODEL_FRAME_SIZE); |
|
|
|
|
CL_CHECK(clEnqueueReadBuffer(q, net_input_cl, CL_TRUE, 0, MODEL_FRAME_SIZE * sizeof(uint8_t), &input_frames[MODEL_FRAME_SIZE], 0, nullptr, nullptr)); |
|
|
|
|
std::memmove(&input_frames[0], &input_frames[MODEL_FRAME_SIZE], frame_size_bytes); |
|
|
|
|
CL_CHECK(clEnqueueReadBuffer(q, net_input_cl, CL_TRUE, 0, frame_size_bytes, &input_frames[MODEL_FRAME_SIZE], 0, nullptr, nullptr)); |
|
|
|
|
clFinish(q); |
|
|
|
|
return &input_frames[0]; |
|
|
|
|
} else { |
|
|
|
|
loadyuv_queue(&loadyuv, q, y_cl, u_cl, v_cl, *output, true); |
|
|
|
|
copy_queue(&loadyuv, q, *output, *output, frame_size_bytes, 0, frame_size_bytes); |
|
|
|
|
copy_queue(&loadyuv, q, net_input_cl, *output, 0, frame_size_bytes, frame_size_bytes); |
|
|
|
|
|
|
|
|
|
// NOTE: Since thneed is using a different command queue, this clFinish is needed to ensure the image is ready.
|
|
|
|
|
clFinish(q); |
|
|
|
|
return NULL; |
|
|
|
|