98inline static void _copy_buffer(
const char *
const restrict input,
char *
const restrict output,
99 const size_t height,
const size_t o_width,
const size_t i_width,
100 const size_t x_offset,
const size_t y_offset,
101 const size_t stride,
const size_t bpp)
104#pragma omp parallel for default(none) \
105 dt_omp_firstprivate(input, output, bpp, o_width, i_width, height, x_offset, y_offset, stride) \
108 for(
size_t j = 0; j <
height; j++)
109 memcpy(output +
bpp * j * o_width,
110 input +
bpp * (x_offset + (y_offset + j) * i_width),
116 const size_t width,
const size_t height,
const size_t chan)
119#pragma omp parallel for simd default(none) \
120 aligned(input, output: 64) \
121 dt_omp_firstprivate(input, output, width, height, chan) \
126 const size_t index = k * chan;
128 output[index + 0] = (float)input[index + 2] / 255.f;
129 output[index + 1] = (float)input[index + 1] / 255.f;
130 output[index + 2] = (float)input[index + 0] / 255.f;
131 output[index + 3] = 0.f;
137 gboolean store_masks)
249 pipe->
icc_filename = g_strdup(icc_filename ? icc_filename :
"");
326 for(GList *nodes = pipe->
nodes; nodes; nodes = g_list_next(nodes))
330 piece->module->cleanup_pipe(piece->module, pipe, piece);
339 g_list_free(pipe->
nodes);
344 g_list_free(pipe->
iop);
355 g_assert(pipe->
nodes == NULL);
356 g_assert(pipe->
iop == NULL);
364 pipe->
iop = g_list_copy(dev->
iop);
365 for(GList *modules = pipe->
iop; modules; modules = g_list_next(modules))
369 piece->
enabled =
module->enabled;
371 piece->histogram_params.roi = NULL;
372 piece->histogram_params.bins_count = 256;
373 piece->histogram_stats.bins_count = 0;
374 piece->histogram_stats.pixels = 0;
376 = ((
module->default_colorspace(module, pipe, NULL) == IOP_CS_RAW) && (dt_image_is_raw(&pipe->image)))
379 piece->iwidth = pipe->
iwidth;
380 piece->iheight = pipe->
iheight;
381 piece->module =
module;
385 piece->blendop_hash = 0;
386 piece->global_hash = 0;
387 piece->global_mask_hash = 0;
388 piece->bypass_cache =
FALSE;
389 piece->process_cl_ready = 0;
390 piece->process_tiling_ready = 0;
391 piece->raster_masks = g_hash_table_new_full(g_direct_hash, g_direct_equal, NULL,
dt_free_align_ptr);
392 memset(&piece->processed_roi_in, 0,
sizeof(piece->processed_roi_in));
393 memset(&piece->processed_roi_out, 0,
sizeof(piece->processed_roi_out));
396 memset(&piece->dsc_mask, 0,
sizeof(piece->dsc_mask));
397 piece->dsc_mask.channels = 1;
399 piece->dsc_mask.filters = 0;
402 pipe->
nodes = g_list_append(pipe->
nodes, piece);
425 return dt_hash(hash, (
const char *)&pos,
sizeof(
int));
442 distort_hash =
dt_hash(distort_hash, (
const char *)&distort_hash,
sizeof(
uint64_t));
445 gboolean bypass_cache =
FALSE;
447 for(GList *node = g_list_first(pipe->
nodes); node; node = g_list_next(node))
464 fprintf(stdout,
"%s: ROI in: %ix%i, ROI out: %ix%i\n", piece->module->op, piece->
planned_roi_in.
width,
471 local_hash =
dt_hash(local_hash, (
const char *)&piece->module->request_mask_display,
sizeof(
int));
481 dt_print(
DT_DEBUG_PIPE,
"[pixelpipe] global hash for %s (%s) in pipe %i with hash %" PRIu64
"\n", piece->module->op, piece->module->multi_name, pipe->
type, hash);
500 if(piece->module == hist->module)
526 for(GList *nodes = g_list_last(pipe->
nodes); nodes; nodes = g_list_previous(nodes))
546 dt_print(
DT_DEBUG_DEV,
"[pixelpipe] synch all modules with defaults_params for pipe %i called from %s\n", pipe->
type, caller_func);
547 dt_print(
DT_DEBUG_DEV,
"[pixelpipe] synch all modules with history for pipe %i called from %s\n", pipe->
type, caller_func);
553 for(GList *nodes = g_list_first(pipe->
nodes); nodes; nodes = g_list_next(nodes))
558 piece->
enabled = piece->module->default_enabled;
559 gboolean found_history =
FALSE;
563 for(GList *history = g_list_nth(dev->
history, history_end - 1);
565 history = g_list_previous(history))
570 found_history =
TRUE;
576 if(!found_history && piece->
enabled)
578 dt_iop_commit_params(piece->module, piece->module->default_params, piece->module->default_blendop_params,
580 dt_print(
DT_DEBUG_PIPE,
"[pixelpipe] info: committed default params for %s (%s) in pipe %i \n", piece->module->op, piece->module->multi_name, pipe->
type);
585 GList *last_item = g_list_nth(dev->
history, history_end - 1);
604 GList *first_item = NULL;
605 for(GList *history = last_item; history; history = g_list_previous(history))
608 first_item = history;
627 for(GList *history = first_item; history && history != fence_item; history = g_list_next(history))
654 dt_print(
DT_DEBUG_DEV,
"[dt_dev_pixelpipe_change] pipeline state changing for pipe %i, flag %i\n", pipe->
type, status);
695 dt_show_times_f(&start,
"[dt_dev_pixelpipe_change] pipeline resync on the current modules stack",
"for pipe %i", pipe->
type);
701 if(module)
return module->output_format(module, pipe, piece, dsc);
716 uint32_t **histogram, uint32_t *histogram_max)
723 if(histogram_params.
roi == NULL)
726 .
width = roi->
width, .height = roi->
height, .crop_x = 0, .crop_y = 0, .crop_width = 0, .crop_height = 0
729 histogram_params.
roi = &histogram_roi;
741 if(!strcmp(op,
"demosaic"))
743 else if(!strcmp(op,
"colorout"))
745 else if(!strcmp(op,
"gamma"))
758 if(!(
bpp == 4 *
sizeof(
float)))
return;
761 if(backbuf == NULL)
return;
762 if(backbuf->
hash == hash)
return;
765 if(backbuf->
buffer == NULL)
769 if(backbuf->
buffer == NULL)
787 if(backbuf->
buffer == NULL)
799 if(backbuf->
buffer == NULL)
807 backbuf->
hash = hash;
818 dt_show_times_f(&start,
"[dev_pixelpipe]",
"copying global histogram for %s", module->
op);
832 dt_aligned_pixel_t picked_color_min, dt_aligned_pixel_t picked_color_max,
846 for(
int k = 0; k < 4; k += 2) fbox[k] = sample->
box[k] * wd;
847 for(
int k = 1; k < 4; k += 2) fbox[k] = sample->
box[k] * ht;
851 fbox[0] = fbox[2] = sample->
point[0] * wd;
852 fbox[1] = fbox[3] = sample->
point[1] * ht;
866 box[0] = fminf(fbox[0], fbox[2]);
867 box[1] = fminf(fbox[1], fbox[3]);
868 box[2] = fmaxf(fbox[0], fbox[2]);
869 box[3] = fmaxf(fbox[1], fbox[3]);
874 for(
int k = 2; k < 4; k++) box[k] += 1;
878 if(box[0] >=
width || box[1] >=
height || box[2] < 0 || box[3] < 0)
return 1;
881 for(
int k = 0; k < 4; k += 2) box[k] =
MIN(
width - 1,
MAX(0, box[k]));
882 for(
int k = 1; k < 4; k += 2) box[k] =
MIN(
height - 1,
MAX(0, box[k]));
885 if(box[2] - box[0] < 1 || box[3] - box[1] < 1)
return 1;
891 const float *pixel,
const dt_iop_roi_t *roi,
float *picked_color,
892 float *picked_color_min,
float *picked_color_max,
899 for(
int k = 0; k < 4; k++)
901 picked_color_min[k] = INFINITY;
902 picked_color_max[k] = -INFINITY;
903 picked_color[k] = 0.0f;
909 dt_aligned_pixel_t min, max, avg;
910 for(
int k = 0; k < 4; k++)
921 for(
int k = 0; k < 4; k++)
923 picked_color_min[k] = min[k];
924 picked_color_max[k] = max[k];
925 picked_color[k] = avg[k];
983 module->input_colorspace(module, pipe, piece), &input_format->
cst,
991 module->histogram = realloc(module->histogram, buf_size);
993 module->histogram_stats = piece->histogram_stats;
1001#define KILL_SWITCH_ABORT \
1002 if(dt_atomic_get_int(&pipe->shutdown)) \
1004 if(*cl_mem_output != NULL) \
1006 dt_opencl_release_mem_object(*cl_mem_output); \
1007 *cl_mem_output = NULL; \
1010 pipe->status = DT_DEV_PIXELPIPE_DIRTY; \
1016#define KILL_SWITCH_AND_FLUSH_CACHE \
1017 if(dt_atomic_get_int(&pipe->shutdown)) \
1019 dt_dev_pixelpipe_cache_remove(darktable.pixelpipe_cache, hash, TRUE, output_entry); \
1020 if(*cl_mem_output != NULL) \
1022 dt_opencl_release_mem_object(*cl_mem_output); \
1023 *cl_mem_output = NULL; \
1026 pipe->status = DT_DEV_PIXELPIPE_DIRTY; \
1046 module->input_colorspace(module, pipe, piece), &input_format->
cst,
1062 module->process_tiling(module, piece, input, *output, roi_in, roi_out, in_bpp);
1069 fprintf(stderr,
"[pixelpipe_process_on_CPU] Warning: processes `%s' even if memory requirements are not met\n", module->
op);
1071 module->process(module, piece, input, *output, roi_in, roi_out);
1078 pipe->
dsc.
cst =
module->output_colorspace(module, pipe, piece);
1086 input_format->
cst, blend_cst, &input_format->
cst,
1105 for(GList *node = g_list_last(pipe->
nodes); node; node = g_list_previous(node))
1108 if(piece->
enabled)
return piece;
1134 input_format->
cst, picker_cst, &input_format->
cst,
1152static void *_gpu_init_buffer(
int devid,
void *
const host_ptr,
const dt_iop_roi_t *roi,
const size_t bpp,
1156 void *cl_mem_input = dt_opencl_alloc_device_use_host_pointer(devid, roi->
width, roi->
height,
bpp, host_ptr,
1157 CL_MEM_READ_WRITE | CL_MEM_USE_HOST_PTR);
1159 if(cl_mem_input == NULL)
1165 return cl_mem_input;
1169static void _gpu_clear_buffer(
void **cl_mem_buffer)
1171 if(*cl_mem_buffer != NULL)
1174 *cl_mem_buffer = NULL;
1178static gboolean _check_zero_memory(
void *cl_mem_pinned,
void *host_ptr,
dt_iop_module_t *module,
const char *message)
1180 if(cl_mem_pinned == host_ptr)
1187 printf(
"❌ Not zero-copy: OpenCL made a temporary device-side copy for %s %s\n", module->
op, message);
1194static int _cl_pinned_memory_copy(
const int devid,
void *host_ptr,
void *cl_mem_buffer,
const dt_iop_roi_t *roi,
1197 void *cl_mem_pinned_input = dt_opencl_map_image(devid, cl_mem_buffer,
TRUE, cl_mode, roi->
width,
1199 dt_opencl_unmap_mem_object(devid, cl_mem_buffer, cl_mem_pinned_input);
1203 if(!_check_zero_memory(cl_mem_pinned_input, host_ptr, module, message))
1205 cl_int err = CL_SUCCESS;
1207 if(cl_mode == CL_MAP_WRITE)
1208 err = dt_opencl_write_host_to_device(devid, host_ptr, cl_mem_buffer, roi->
width, roi->
height,
bpp);
1209 else if(cl_mode == CL_MAP_READ)
1210 err = dt_opencl_read_host_from_device(devid, host_ptr, cl_mem_buffer, roi->
width, roi->
height,
bpp);
1212 if(err != CL_SUCCESS)
1215 module->
op, message);
1229 const size_t in_bpp,
const size_t bpp,
1241 gboolean success_opencl =
TRUE;
1244 const float required_factor_cl = fmaxf(1.0f, (cl_mem_input != NULL) ?
tiling->factor_cl - 1.0f :
tiling->factor_cl);
1248 required_factor_cl,
tiling->overhead);
1258 gboolean possible_cl = (
module->process_cl && piece->process_cl_ready
1259 && !((pipe->type & DT_DEV_PIXELPIPE_PREVIEW) == DT_DEV_PIXELPIPE_PREVIEW
1260 && (module->flags() & IOP_FLAGS_PREVIEW_NON_OPENCL))
1261 && (fits_on_device || piece->process_tiling_ready));
1263 if(possible_cl && !fits_on_device)
1268 const float border =
tiling->overlap + 1;
1272 const gboolean possible = (cl_px > dx * border) || (cl_px > dy * border) || (cl_px > border * border);
1276 module->
op, cl_px / 1e6f, dx*dy / 1e6f, (
int)dx, (
int)dy, (
int)
tiling->overlap);
1283 if(!possible_cl)
goto error;
1290 if(cl_mem_input == NULL)
1293 cl_mem_input = _gpu_init_buffer(pipe->
devid, input, roi_in, in_bpp, module,
"input");
1294 int fail = (cl_mem_input == NULL);
1296 if(!fail && _cl_pinned_memory_copy(pipe->
devid, input, cl_mem_input, roi_in, CL_MAP_WRITE, in_bpp, module,
1302 if(fail)
goto error;
1306 *cl_mem_output = _gpu_init_buffer(pipe->
devid, *output, roi_out,
bpp, module,
"output");
1307 if(*cl_mem_output == NULL)
goto error;
1310 if(!dt_ioppr_transform_image_colorspace_cl(
1311 module, piece->
pipe->devid, cl_mem_input, cl_mem_input, roi_in->
width, roi_in->
height, input_cst_cl,
1312 module->input_colorspace(module, pipe, piece), &input_cst_cl, work_profile))
1316 if(!module->process_cl(module, piece, cl_mem_input, *cl_mem_output, roi_in, roi_out))
1323 pipe->
dsc.
cst =
module->output_colorspace(module, pipe, piece);
1329 success_opencl &= dt_ioppr_transform_image_colorspace_cl(
1330 module, piece->
pipe->devid, cl_mem_input, cl_mem_input, roi_in->
width, roi_in->
height, input_cst_cl,
1331 blend_cst, &input_cst_cl, work_profile);
1332 success_opencl &= dt_ioppr_transform_image_colorspace_cl(
1333 module, piece->
pipe->devid, *cl_mem_output, *cl_mem_output, roi_out->
width, roi_out->
height,
1334 pipe->
dsc.
cst, blend_cst, &pipe->
dsc.
cst, work_profile);
1345 if(dt_develop_blend_process_cl(module, piece, cl_mem_input, *cl_mem_output, roi_in, roi_out))
1351 if(_cl_pinned_memory_copy(pipe->
devid, *output, *cl_mem_output, roi_out, CL_MAP_READ,
bpp, module,
1358 if(input_format->
cst != input_cst_cl)
1361 input_format->
cst = input_cst_cl;
1362 int fail = _cl_pinned_memory_copy(pipe->
devid, input, cl_mem_input, roi_in, CL_MAP_READ, in_bpp, module,
1363 "color-converted input");
1365 if(fail)
goto error;
1371 _gpu_clear_buffer(&cl_mem_input);
1376 module->input_colorspace(module, pipe, piece), &input_format->
cst,
1382 int fail = !
module->process_tiling_cl(module, piece, input, *output, roi_in, roi_out, in_bpp);
1385 if(fail)
goto error;
1391 pipe->
dsc.
cst =
module->output_colorspace(module, pipe, piece);
1400 input_format->
cst, blend_cst, &input_format->
cst,
1425 _gpu_clear_buffer(&cl_mem_input);
1438 _gpu_clear_buffer(cl_mem_output);
1439 _gpu_clear_buffer(&cl_mem_input);
1442 if(input != NULL && *output != NULL)
1444 piece,
tiling, pixelpipe_flow, input_entry);
1453 char histogram_log[32] =
"";
1456 snprintf(histogram_log,
sizeof(histogram_log),
", collected histogram on %s",
1464 start,
"[dev_pixelpipe]",
"processed `%s' on %s%s%s, blended on %s [%s]", module_label,
1476 g_free(module_label);
1488 int hasinf = 0, hasnan = 0;
1489 dt_aligned_pixel_t min = { FLT_MAX };
1490 dt_aligned_pixel_t max = { FLT_MIN };
1492 for(
int k = 0; k < 4 * roi_out->
width * roi_out->
height; k++)
1496 float f = ((
float *)(output))[k];
1503 min[k & 3] = fmin(
f, min[k & 3]);
1504 max[k & 3] = fmax(
f, max[k & 3]);
1509 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs NaNs! [%s]\n", module_label,
1512 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs non-finite floats! [%s]\n", module_label,
1514 fprintf(stderr,
"[dev_pixelpipe] module `%s' min: (%f; %f; %f) max: (%f; %f; %f) [%s]\n", module_label,
1519 int hasinf = 0, hasnan = 0;
1520 float min = FLT_MAX;
1521 float max = FLT_MIN;
1523 for(
int k = 0; k < roi_out->
width * roi_out->
height; k++)
1525 float f = ((
float *)(output))[k];
1537 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs NaNs! [%s]\n", module_label,
1540 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs non-finite floats! [%s]\n", module_label,
1542 fprintf(stderr,
"[dev_pixelpipe] module `%s' min: (%f) max: (%f) [%s]\n", module_label, min, max,
1546 g_free(module_label);
1555 const gboolean bypass_cache,
1556 const size_t bufsize,
const size_t bpp)
1561 output, out_format, &cache_entry);
1562 if(cache_entry == NULL)
return 1;
1566 if(bypass_cache || new_entry)
1586 else if(roi_in->
scale == 1.0f)
1590 const int in_x =
MAX(roi_in->
x, 0);
1591 const int in_y =
MAX(roi_in->
y, 0);
1595 if(cp_width > 0 && cp_height > 0)
1612 roi_in->
x /= roi_out->
scale;
1613 roi_in->
y /= roi_out->
scale;
1616 roi_in->
scale = 1.0f;
1624 "Base buffer init: scale %f != 1.0 but the input has %li bytes per pixel. This case is not "
1625 "covered by the pipeline, please report the bug.\n",
1657 if(strcmp(module->
op,
"gamma") == 0)
1674 const dt_iop_roi_t *roi_out, GList *modules, GList *pieces,
int pos)
1687 void *cl_mem_input = NULL;
1688 *cl_mem_output = NULL;
1694 module = (dt_iop_module_t *)modules->data;
1699 g_list_previous(modules), g_list_previous(pieces), pos - 1);
1706 const size_t bufsize = (size_t)
bpp * roi_out->
width * roi_out->
height;
1708 const gboolean bypass_cache = (module) ? piece->bypass_cache :
FALSE;
1718 && !bypass_cache && !pipe->
reentry
1724 dt_print(
DT_DEBUG_PIPE,
"[dev_pixelpipe] found %" PRIu64
" (%s) for %s pipeline in cache\n", hash, module ? module->
op :
"noop",
1735 if(
_init_base_buffer(pipe, dev, output, cl_mem_output, out_format, &roi_in, roi_out, hash, bypass_cache, bufsize,
1746 memcpy(&roi_in, &piece->planned_roi_in,
sizeof(
dt_iop_roi_t));
1755 piece->processed_roi_in = roi_in;
1756 piece->processed_roi_out = *roi_out;
1759 g_list_previous(modules), g_list_previous(pieces), pos - 1))
1765 piece->dsc_out = piece->dsc_in = *input_format;
1766 module->output_format(module, pipe, piece, &piece->dsc_out);
1767 **out_format = pipe->
dsc = piece->dsc_out;
1775 if(strcmp(module->
op,
"gamma") != 0
1778 && (in_bpp == out_bpp)
1779 && !memcmp(&roi_in, roi_out,
sizeof(
struct dt_iop_roi_t)))
1782 **out_format = pipe->
dsc = piece->dsc_out = piece->dsc_in;
1790 if(input_entry == NULL)
return 1;
1793 char *
name = g_strdup_printf(
"module %s (%s) for pipe %i", module->
op, module->
multi_name, pipe->
type);
1795 output, out_format, &output_entry);
1797 if(output_entry == NULL)
return 1;
1805 if(!pipe->
reentry && !new_entry)
1807 dt_print(
DT_DEBUG_PIPE,
"[pipeline] found %" PRIu64
" (%s) for %s pipeline in cache\n", hash, module ? module->
op :
"noop",
1811 _sample_all(pipe, dev, input, output, &roi_in, roi_out, input_format, out_format, module,
1812 piece, input_hash, hash, in_bpp,
bpp, input_entry, output_entry);
1825 module->tiling_callback(module, piece, &roi_in, roi_out, &tiling);
1849 assert(
tiling.factor > 0.0f);
1850 assert(
tiling.factor_cl > 0.0f);
1859 error = pixelpipe_process_on_GPU(pipe, dev, input, cl_mem_input, input_format, &roi_in, output, cl_mem_output,
1860 out_format, roi_out, module, piece, &
tiling, &pixelpipe_flow, in_bpp,
bpp, input_entry);
1863 piece, &
tiling, &pixelpipe_flow, input_entry);
1871 if(bypass_cache || pipe->
reentry)
1875 **out_format = piece->dsc_out = pipe->
dsc;
1893 _sample_all(pipe, dev, input, output, &roi_in, roi_out, input_format, out_format, module, piece, input_hash,
1894 hash, in_bpp,
bpp, input_entry, output_entry);
1921 GList *nodes = g_list_last(pipe->
nodes);
1923 while(strcmp(piece->module->op, op))
1927 nodes = g_list_previous(nodes);
1935 GList *nodes = pipe->
nodes;
1937 while(strcmp(piece->module->op, op))
1941 nodes = g_list_next(nodes);
1947#define KILL_SWITCH_PIPE \
1948 if(dt_atomic_get_int(&pipe->shutdown)) \
1950 if(pipe->devid >= 0) \
1952 dt_opencl_unlock_device(pipe->devid); \
1955 pipe->status = DT_DEV_PIXELPIPE_DIRTY; \
1956 if(pipe->forms) g_list_free_full(pipe->forms, (void (*)(void *))dt_masks_free_form); \
1972 "[opencl] Too many opencl errors; disabling opencl for this session!\n");
1973 dt_control_log(_(
"Ansel discovered problems with your OpenCL setup; disabling OpenCL for this session!"));
1986 fprintf(stderr,
"[memory] before pixelpipe process\n");
1998 const guint pos = g_list_length(pipe->
iop);
1999 GList *modules = g_list_last(pipe->
iop);
2000 GList *pieces = g_list_last(pipe->
nodes);
2019 gboolean keep_running =
TRUE;
2020 int opencl_error = 0;
2033 void *cl_mem_out = NULL;
2049 _gpu_clear_buffer(&cl_mem_out);
2061 keep_running = (oclerr || (err && pipe->
opencl_error));
2106 if(pipe->
devid >= 0)
2125 && dev->
gui_module->operation_tags_filter() & current_module->operation_tags());
2130 const int width_in,
const int height_in,
2135 GList *modules = g_list_first(pipe->
iop);
2136 GList *pieces = g_list_first(pipe->
nodes);
2142 piece->buf_in = roi_in;
2148 module->modify_roi_out(module, piece, &roi_out, &roi_in);
2156 piece->buf_out = roi_out;
2159 modules = g_list_next(modules);
2160 pieces = g_list_next(pieces);
2178 GList *modules = g_list_last(pipe->
iop);
2179 GList *pieces = g_list_last(pipe->
nodes);
2185 piece->planned_roi_out = roi_out_temp;
2190 module->modify_roi_in(module, piece, &roi_out_temp, &roi_in);
2195 roi_in = roi_out_temp;
2198 piece->planned_roi_in = roi_in;
2199 roi_out_temp = roi_in;
2201 modules = g_list_previous(modules);
2202 pieces = g_list_previous(pieces);
2218 gboolean success =
TRUE;
2220 gchar *target_name = g_strdup_printf(
"%s (%s)", clean_target_name, target_module->
multi_name);
2222 if(source_piece == NULL || current_piece == NULL)
2224 fprintf(stderr,
"[raster masks] ERROR: source: %s, current: %s\n",
2225 (source_piece != NULL) ?
"is defined" :
"is undefined",
2226 (current_piece != NULL) ?
"is definded" :
"is undefined");
2229 if(source_piece == NULL)
2234 hint = g_strdup_printf(
2235 _(
"\n- Check if the module providing the masks for the module %s has not been deleted.\n"),
2238 else if(current_piece == NULL)
2244 hint = g_strdup_printf(_(
"\n- Check if the module %s (%s) providing the masks has not been moved above %s.\n"),
2245 delete_underscore(source_piece->module->name()), source_piece->module->multi_name, clean_target_name);
2248 dt_control_log(_(
"The %s module is trying to reuse a mask from a module but it can't be found.\n"
2249 "Masking in %s will be disabled until a mask is available.\n"
2251 target_name, target_name, hint ? hint :
"");
2254 fprintf(stderr,
"[raster masks] no source module for module %s could be found\n", target_name);
2258 if(success && !source_piece->
enabled)
2261 gchar *source_name = g_strdup_printf(
"%s (%s)", clean_source_name, source_piece->module->multi_name);
2263 dt_control_log(_(
"The `%s` module is trying to reuse a mask from disabled module `%s`.\n"
2264 "Disabled modules cannot provide their masks to other modules.\n"
2265 "Masking in `%s` will be disabled until `%s` is re-enabled."),
2266 target_name, source_name, target_name, source_name);
2268 fprintf(stderr,
"[raster masks] module %s trying to reuse a mask from disabled instance of %s\n",
2269 target_name, source_name);
2271 g_free(clean_source_name);
2272 g_free(source_name);
2276 g_free(clean_target_name);
2277 g_free(target_name);
2283 gboolean *free_mask,
int *
error)
2289 gchar *target_name = g_strdup_printf(
"%s (%s)", clean_target_name, target_module->
multi_name);
2291 if(!raster_mask_source)
2293 fprintf(stderr,
"[raster masks] The source module of the mask for %s was not found\n", target_name);
2294 g_free(clean_target_name);
2295 g_free(target_name);
2300 float *raster_mask = NULL;
2305 GList *source_iter = NULL;
2306 for(source_iter = g_list_last(pipe->
nodes); source_iter; source_iter = g_list_previous(source_iter))
2309 if(candidate->module == target_module)
2311 current_piece = candidate;
2313 else if(candidate->module == raster_mask_source)
2315 source_piece = candidate;
2330 gchar *source_name = g_strdup_printf(
"%s (%s)", clean_source_name, source_piece->module->multi_name);
2331 raster_mask = g_hash_table_lookup(source_piece->
raster_masks, GINT_TO_POINTER(raster_mask_id));
2337 "[raster masks] found in %s mask id %i from %s (%s) for module %s (%s) in pipe %i with hash %" PRIu64
"\n",
2339 raster_mask_id, source_name, source_piece->module->multi_name, target_name, target_module->
multi_name,
2340 pipe->
type, raster_hash);
2348 "[raster masks] mask id %i from %s for module %s could not be found in pipe %i. Pipe re-entry will be attempted.\n",
2349 raster_mask_id, source_name, target_name, pipe->
type);
2358 g_free(clean_target_name);
2359 g_free(target_name);
2364 for(GList *iter = g_list_next(source_iter); iter; iter = g_list_next(iter))
2372 if(module->module->distort_mask
2373 && !(!strcmp(module->module->
op,
"finalscale")
2374 && module->processed_roi_in.width == 0
2375 && module->processed_roi_in.height == 0))
2378 * module->processed_roi_out.height);
2379 if(!transformed_mask)
2381 fprintf(stderr,
"[raster masks] could not allocate memory for transformed mask\n");
2383 g_free(clean_target_name);
2384 g_free(target_name);
2388 module->module->distort_mask(module->module,
2392 &module->processed_roi_in,
2393 &module->processed_roi_out);
2396 raster_mask = transformed_mask;
2397 fprintf(stdout,
"doing transform\n");
2399 else if(!module->module->distort_mask &&
2400 (module->processed_roi_in.width != module->processed_roi_out.width ||
2401 module->processed_roi_in.height != module->processed_roi_out.height ||
2402 module->processed_roi_in.x != module->processed_roi_out.x ||
2403 module->processed_roi_in.y != module->processed_roi_out.y))
2404 fprintf(stderr,
"FIXME: module `%s' changed the roi from %d x %d @ %d / %d to %d x %d | %d / %d but doesn't have "
2405 "distort_mask() implemented!\n", module->module->
op, module->processed_roi_in.width,
2406 module->processed_roi_in.height, module->processed_roi_in.x, module->processed_roi_in.y,
2407 module->processed_roi_out.width, module->processed_roi_out.height, module->processed_roi_out.x,
2408 module->processed_roi_out.y);
2411 if(module->module == target_module)
2421 g_free(clean_target_name);
2422 g_free(target_name);
2437 if(p->rawdetail_mask_data)
2449 if((mask == NULL) || (tmp == NULL))
goto error;
2451 p->rawdetail_mask_data = mask;
2452 memcpy(&p->rawdetail_mask_roi, roi_in,
sizeof(
dt_iop_roi_t));
2454 dt_aligned_pixel_t wb = { piece->
pipe->dsc.temperature.coeffs[0],
2455 piece->
pipe->dsc.temperature.coeffs[1],
2456 piece->
pipe->dsc.temperature.coeffs[2] };
2459 wb[0] = wb[1] = wb[2] = 1.0f;
2467 fprintf(stderr,
"[dt_dev_write_rawdetail_mask] couldn't write detail mask\n");
2479 if(
p->rawdetail_mask_data)
2494 const int devid =
p->devid;
2496 cl_int err = CL_SUCCESS;
2498 if(mask == NULL)
goto error;
2499 out = dt_opencl_alloc_device(devid,
width,
height,
sizeof(
float));
2500 if(out == NULL)
goto error;
2501 tmp = dt_opencl_alloc_device_buffer(devid,
sizeof(
float) *
width *
height);
2502 if(tmp == NULL)
goto error;
2506 dt_aligned_pixel_t wb = { piece->
pipe->dsc.temperature.coeffs[0],
2507 piece->
pipe->dsc.temperature.coeffs[1],
2508 piece->
pipe->dsc.temperature.coeffs[2] };
2511 wb[0] = wb[1] = wb[2] = 1.0f;
2513 size_t sizes[3] = { ROUNDUPDWD(
width, devid), ROUNDUPDHT(
height, devid), 1 };
2522 if(err != CL_SUCCESS)
goto error;
2525 size_t sizes[3] = { ROUNDUPDWD(
width, devid), ROUNDUPDHT(
height, devid), 1 };
2532 if(err != CL_SUCCESS)
goto error;
2536 err = dt_opencl_read_host_from_device(devid, mask, out,
width,
height,
sizeof(
float));
2537 if(err != CL_SUCCESS)
goto error;
2540 p->rawdetail_mask_data =
mask;
2541 memcpy(&
p->rawdetail_mask_roi, roi_in,
sizeof(
dt_iop_roi_t));
2549 fprintf(stderr,
"[dt_dev_write_rawdetail_mask_cl] couldn't write detail mask: %i\n", err);
2563 gboolean valid =
FALSE;
2567 for(source_iter = pipe->
nodes; source_iter; source_iter = g_list_next(source_iter))
2582 if(!valid)
return NULL;
2585 float *resmask = src;
2586 float *inmask = src;
2589 for(GList *iter = source_iter; iter; iter = g_list_next(iter))
2595 if(module->module->distort_mask
2596 && !(!strcmp(module->module->
op,
"finalscale")
2597 && module->processed_roi_in.width == 0
2598 && module->processed_roi_in.height == 0))
2600 float *tmp =
dt_alloc_align_float((
size_t)module->processed_roi_out.width * module->processed_roi_out.height);
2601 dt_vprint(
DT_DEBUG_MASKS,
" %s %ix%i -> %ix%i\n", module->module->
op, module->processed_roi_in.width, module->processed_roi_in.height, module->processed_roi_out.width, module->processed_roi_out.height);
2602 module->module->distort_mask(module->module, module, inmask, tmp, &module->processed_roi_in, &module->processed_roi_out);
2607 else if(!module->module->distort_mask &&
2608 (module->processed_roi_in.width != module->processed_roi_out.width ||
2609 module->processed_roi_in.height != module->processed_roi_out.height ||
2610 module->processed_roi_in.x != module->processed_roi_out.x ||
2611 module->processed_roi_in.y != module->processed_roi_out.y))
2612 fprintf(stderr,
"FIXME: module `%s' changed the roi from %d x %d @ %d / %d to %d x %d | %d / %d but doesn't have "
2613 "distort_mask() implemented!\n", module->module->
op, module->processed_roi_in.width,
2614 module->processed_roi_in.height, module->processed_roi_in.x, module->processed_roi_in.y,
2615 module->processed_roi_out.width, module->processed_roi_out.height, module->processed_roi_out.x,
2616 module->processed_roi_out.y);
2618 if(module->module == target_module)
break;
static void error(char *msg)
Definition ashift_lsd.c:191
#define TRUE
Definition ashift_lsd.c:151
#define FALSE
Definition ashift_lsd.c:147
void dt_atomic_set_int(dt_atomic_int *var, int value)
Definition atomic.h:45
int dt_atomic_get_int(dt_atomic_int *var)
Definition atomic.h:46
int levels(struct dt_imageio_module_data_t *data)
Definition avif.c:685
int width
Definition bilateral.h:1
int height
Definition bilateral.h:1
int dt_develop_blend_process(struct dt_iop_module_t *self, struct dt_dev_pixelpipe_iop_t *piece, const void *const ivoid, void *const ovoid, const struct dt_iop_roi_t *const roi_in, const struct dt_iop_roi_t *const roi_out)
Definition blend.c:426
dt_iop_colorspace_type_t dt_develop_blend_colorspace(const dt_dev_pixelpipe_iop_t *const piece, dt_iop_colorspace_type_t cst)
Definition blend.c:134
void tiling_callback_blendop(struct dt_iop_module_t *self, struct dt_dev_pixelpipe_iop_t *piece, const dt_iop_roi_t *roi_in, const dt_iop_roi_t *roi_out, struct dt_develop_tiling_t *tiling)
Definition blend.c:1363
@ DEVELOP_MASK_DISABLED
Definition blend.h:94
typedef void((*dt_cache_allocate_t)(void *userdata, dt_cache_entry_t *entry))
dt_iop_colorspace_type_t
Definition color_conversion.h:24
@ IOP_CS_RAW
Definition color_conversion.h:26
@ IOP_CS_LCH
Definition color_conversion.h:29
@ IOP_CS_JZCZHZ
Definition color_conversion.h:31
@ IOP_CS_RGB
Definition color_conversion.h:28
@ IOP_CS_HSL
Definition color_conversion.h:30
@ IOP_CS_LAB
Definition color_conversion.h:27
@ IOP_CS_NONE
Definition color_conversion.h:25
void dt_color_picker_helper(const dt_iop_buffer_dsc_t *dsc, const float *const pixel, const dt_iop_roi_t *roi, const int *const box, dt_aligned_pixel_t picked_color, dt_aligned_pixel_t picked_color_min, dt_aligned_pixel_t picked_color_max, const dt_iop_colorspace_type_t image_cst, const dt_iop_colorspace_type_t picker_cst, const dt_iop_order_iccprofile_info_t *const profile)
Definition color_picker.c:605
dt_iop_colorspace_type_t dt_iop_color_picker_get_active_cst(dt_iop_module_t *module)
Definition color_picker_proxy.c:246
static float kernel(const float *x, const float *y)
Definition colorchecker.c:435
@ DT_LIB_COLORPICKER_SIZE_POINT
Definition colorpicker.h:26
@ DT_LIB_COLORPICKER_SIZE_BOX
Definition colorpicker.h:27
dt_iop_color_intent_t
Definition colorspaces.h:43
@ DT_INTENT_LAST
Definition colorspaces.h:48
dt_colorspaces_color_profile_type_t
Definition colorspaces.h:61
@ DT_COLORSPACE_NONE
Definition colorspaces.h:62
void dt_histogram_max_helper(const dt_dev_histogram_stats_t *const histogram_stats, const dt_iop_colorspace_type_t cst, const dt_iop_colorspace_type_t cst_to, uint32_t **histogram, uint32_t *histogram_max)
Definition common/histogram.c:396
void dt_histogram_helper(dt_dev_histogram_collection_params_t *histogram_params, dt_dev_histogram_stats_t *histogram_stats, const dt_iop_colorspace_type_t cst, const dt_iop_colorspace_type_t cst_to, const void *pixel, uint32_t **histogram, const int compensate_middle_grey, const dt_iop_order_iccprofile_info_t *const profile_info)
Definition common/histogram.c:365
gboolean dt_image_is_rawprepare_supported(const dt_image_t *img)
Definition common/image.c:190
int dt_image_is_raw(const dt_image_t *img)
Definition common/image.c:120
void dt_control_log(const char *msg,...)
Definition control.c:424
void dt_control_queue_redraw_widget(GtkWidget *widget)
threadsafe request of redraw of specific widget. Use this function if you need to redraw a specific w...
Definition control.c:550
void dt_vprint(dt_debug_thread_t thread, const char *msg,...)
Definition darktable.c:1440
void dt_show_times(const dt_times_t *start, const char *prefix)
Definition darktable.c:1453
darktable_t darktable
Definition darktable.c:111
void dt_print_mem_usage()
Definition darktable.c:1706
void dt_capabilities_remove(char *capability)
Definition darktable.c:1689
void dt_show_times_f(const dt_times_t *start, const char *prefix, const char *suffix,...)
Definition darktable.c:1467
void dt_print(dt_debug_thread_t thread, const char *msg,...)
Definition darktable.c:1415
#define UNKNOWN_IMAGE
Definition darktable.h:139
@ DT_DEBUG_OPENCL
Definition darktable.h:478
@ DT_DEBUG_PIPE
Definition darktable.h:497
@ DT_DEBUG_NAN
Definition darktable.h:482
@ DT_DEBUG_MEMORY
Definition darktable.h:480
@ DT_DEBUG_DEV
Definition darktable.h:474
@ DT_DEBUG_MASKS
Definition darktable.h:483
@ DT_DEBUG_TILING
Definition darktable.h:495
float dt_boundingbox_t[4]
Definition darktable.h:467
static float * dt_alloc_align_float(size_t pixels)
Definition darktable.h:345
#define dt_free_align_ptr
Definition darktable.h:335
static void dt_get_times(dt_times_t *t)
Definition darktable.h:693
static gchar * delete_underscore(const char *s)
Definition darktable.h:845
static uint64_t dt_hash(uint64_t hash, const char *str, size_t size)
Definition darktable.h:805
#define dt_free_align(A)
Definition darktable.h:334
#define DT_MAX_FILENAME_LEN
Definition darktable.h:814
int32_t dt_dev_get_history_end(struct dt_develop_t *dev)
Definition develop.c:1392
int dt_dev_distort_backtransform_plus(dt_develop_t *dev, dt_dev_pixelpipe_t *pipe, const double iop_order, const int transf_direction, float *points, size_t points_count)
Definition develop.c:1226
gchar * dt_history_item_get_name(const struct dt_iop_module_t *module)
Definition develop.c:1120
@ DT_DEV_PIXELPIPE_DISPLAY_NONE
Definition develop.h:81
@ DT_DEV_TRANSFORM_DIR_FORW_INCL
Definition develop.h:73
@ DT_DEV_TRANSFORM_DIR_FORW_EXCL
Definition develop.h:74
@ DT_DEV_DETAIL_MASK_DEMOSAIC
Definition develop.h:110
@ DT_DEV_DETAIL_MASK_REQUIRED
Definition develop.h:109
@ DT_DEV_DETAIL_MASK_RAWPREPARE
Definition develop.h:111
@ DT_DEV_DETAIL_MASK_NONE
Definition develop.h:108
static int dt_pthread_mutex_unlock(dt_pthread_mutex_t *mutex) RELEASE(mutex) NO_THREAD_SAFETY_ANALYSIS
Definition dtpthread.h:319
static int dt_pthread_mutex_init(dt_pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr)
Definition dtpthread.h:304
static int dt_pthread_mutex_destroy(dt_pthread_mutex_t *mutex)
Definition dtpthread.h:324
static int dt_pthread_mutex_lock(dt_pthread_mutex_t *mutex) ACQUIRE(mutex) NO_THREAD_SAFETY_ANALYSIS
Definition dtpthread.h:309
static float f(const float t, const float c, const float x)
Definition graduatednd.c:173
@ IMAGEIO_RGB
Definition imageio.h:55
@ IMAGEIO_INT8
Definition imageio.h:47
void dt_iop_commit_params(dt_iop_module_t *module, dt_iop_params_t *params, dt_develop_blend_params_t *blendop_params, dt_dev_pixelpipe_t *pipe, dt_dev_pixelpipe_iop_t *piece)
Definition imageop.c:1722
void dt_iop_init_pipe(struct dt_iop_module_t *module, struct dt_dev_pixelpipe_t *pipe, struct dt_dev_pixelpipe_iop_t *piece)
Definition imageop.c:442
void dt_iop_nap(int32_t usec)
Definition imageop.c:2431
@ DT_REQUEST_COLORPICK_OFF
Definition imageop.h:137
@ IOP_FLAGS_SUPPORTS_BLENDING
Definition imageop.h:108
@ IOP_TAG_DISTORT
Definition imageop.h:92
void dt_iop_clip_and_zoom(float *out, const float *const in, const dt_iop_roi_t *const roi_out, const dt_iop_roi_t *const roi_in, const int32_t out_stride, const int32_t in_stride)
Definition imageop_math.c:134
GList * dt_ioppr_iop_order_copy_deep(GList *iop_order_list)
Definition iop_order.c:1444
__DT_CLONE_TARGETS__ void dt_ioppr_transform_image_colorspace(struct dt_iop_module_t *self, const float *const image_in, float *const image_out, const int width, const int height, const int cst_from, const int cst_to, int *converted_cst, const dt_iop_order_iccprofile_info_t *const profile_info)
Definition iop_profile.c:1017
dt_iop_order_iccprofile_info_t * dt_ioppr_get_pipe_current_profile_info(dt_iop_module_t *module, struct dt_dev_pixelpipe_t *pipe)
Definition iop_profile.c:902
dt_iop_order_iccprofile_info_t * dt_ioppr_get_pipe_work_profile_info(struct dt_dev_pixelpipe_t *pipe)
Definition iop_profile.c:887
GList * dt_masks_dup_forms_deep(GList *forms, dt_masks_form_t *form)
Definition develop/masks/masks.c:71
void dt_masks_free_form(dt_masks_form_t *form)
Definition develop/masks/masks.c:982
void dt_masks_calc_rawdetail_mask(float *const src, float *const out, float *const tmp, const int width, const int height, const dt_aligned_pixel_t wb)
size_t size
Definition mipmap_cache.c:3
#define dt_mipmap_cache_get(A, B, C, D, E, F)
Definition mipmap_cache.h:110
@ DT_MIPMAP_BLOCKING
Definition mipmap_cache.h:50
#define dt_mipmap_cache_release(A, B)
Definition mipmap_cache.h:132
dt_mipmap_size_t
Definition mipmap_cache.h:30
mask
Definition dtstyle_to_xmp.py:54
static int dt_opencl_enqueue_kernel_2d(const int dev, const int kernel, const size_t *sizes)
Definition opencl.h:560
static size_t dt_opencl_get_device_available(const int devid)
Definition opencl.h:589
static int dt_opencl_set_kernel_arg(const int dev, const int kernel, const size_t size, const void *arg)
Definition opencl.h:556
static void dt_opencl_events_reset(const int devid)
Definition opencl.h:608
static void dt_opencl_unlock_device(const int dev)
Definition opencl.h:524
static int dt_opencl_update_settings(void)
Definition opencl.h:580
static void dt_opencl_check_tuning(const int devid)
Definition opencl.h:593
static int dt_opencl_is_inited(void)
Definition opencl.h:569
#define DT_OPENCL_MAX_ERRORS
Definition opencl.h:30
static int dt_opencl_lock_device(const int dev)
Definition opencl.h:520
static int dt_opencl_events_flush(const int devid, const int reset)
Definition opencl.h:614
static gboolean dt_opencl_image_fits_device(const int devid, const size_t width, const size_t height, const unsigned bpp, const float factor, const size_t overhead)
Definition opencl.h:584
static gboolean dt_opencl_finish(const int devid)
Definition opencl.h:512
static void dt_opencl_release_mem_object(void *mem)
Definition opencl.h:601
@ DT_REQUEST_ON
Definition pixelpipe.h:42
@ DT_REQUEST_ONLY_IN_GUI
Definition pixelpipe.h:43
@ DT_DEV_PIXELPIPE_THUMBNAIL
Definition pixelpipe.h:33
@ DT_DEV_PIXELPIPE_ANY
Definition pixelpipe.h:34
@ DT_DEV_PIXELPIPE_EXPORT
Definition pixelpipe.h:30
@ DT_DEV_PIXELPIPE_PREVIEW
Definition pixelpipe.h:32
@ DT_DEV_PIXELPIPE_FULL
Definition pixelpipe.h:31
int dt_dev_pixelpipe_cache_remove(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, const gboolean force, dt_pixel_cache_entry_t *cache_entry)
Arbitrarily remove the cache entry matching hash. Entries having a reference count > 0 (inter-thread ...
Definition pixelpipe_cache.c:113
void dt_dev_pixelpipe_cache_ref_count_entry(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, gboolean lock, dt_pixel_cache_entry_t *cache_entry)
Increase/Decrease the reference count on the cache line as to prevent LRU item removal....
Definition pixelpipe_cache.c:483
void dt_dev_pixelpipe_cache_rdlock_entry(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, gboolean lock, dt_pixel_cache_entry_t *cache_entry)
Lock or release the read lock on the entry.
Definition pixelpipe_cache.c:514
void dt_dev_pixelpipe_cache_wrlock_entry(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, gboolean lock, dt_pixel_cache_entry_t *cache_entry)
Lock or release the write lock on the entry.
Definition pixelpipe_cache.c:492
void dt_dev_pixelpipe_cache_print(dt_dev_pixelpipe_cache_t *cache)
Definition pixelpipe_cache.c:564
void dt_dev_pixel_pipe_cache_auto_destroy_apply(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, const int id, dt_pixel_cache_entry_t *cache_entry)
Definition pixelpipe_cache.c:548
uint64_t dt_dev_pixelpipe_cache_get_hash_data(dt_dev_pixelpipe_cache_t *cache, void *data, dt_pixel_cache_entry_t **entry)
Find the hash of the cache entry holding the buffer data.
Definition pixelpipe_cache.c:435
void dt_dev_pixelpipe_cache_flag_auto_destroy(dt_dev_pixelpipe_cache_t *cache, uint64_t hash, dt_pixel_cache_entry_t *cache_entry)
Flag the cache entry matching hash as "auto_destroy". This is useful for short-lived/disposable cache...
Definition pixelpipe_cache.c:536
int dt_dev_pixelpipe_cache_get_existing(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, void **data, dt_iop_buffer_dsc_t **dsc, dt_pixel_cache_entry_t **entry)
Get an existing cache line from the cache. This is similar to dt_dev_pixelpipe_cache_get,...
Definition pixelpipe_cache.c:351
int dt_dev_pixelpipe_cache_get(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, const size_t size, const char *name, const int id, void **data, dt_iop_buffer_dsc_t **dsc, dt_pixel_cache_entry_t **entry)
Get a cache line from the cache.
Definition pixelpipe_cache.c:296
static uint64_t _node_hash(dt_dev_pixelpipe_t *pipe, const dt_dev_pixelpipe_iop_t *piece, const dt_iop_roi_t *roi_out, const int pos)
Definition pixelpipe_hb.c:412
void dt_dev_pixelpipe_disable_before(dt_dev_pixelpipe_t *pipe, const char *op)
Definition pixelpipe_hb.c:1933
int dt_dev_pixelpipe_init_preview(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:160
void dt_dev_pixelpipe_set_input(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, int32_t imgid, int width, int height, dt_mipmap_size_t size)
Definition pixelpipe_hb.c:231
static void _sample_all(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, void *input, void **output, const dt_iop_roi_t *roi_in, const dt_iop_roi_t *roi_out, dt_iop_buffer_dsc_t *input_format, dt_iop_buffer_dsc_t **output_format, dt_iop_module_t *module, dt_dev_pixelpipe_iop_t *piece, const uint64_t input_hash, const uint64_t hash, const size_t in_bpp, const size_t bpp, dt_pixel_cache_entry_t *const input_entry, dt_pixel_cache_entry_t *const output_entry)
Definition pixelpipe_hb.c:1640
static void collect_histogram_on_CPU(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, float *input, const dt_iop_roi_t *roi_in, dt_iop_buffer_dsc_t *input_format, dt_iop_module_t *module, dt_dev_pixelpipe_iop_t *piece)
Definition pixelpipe_hb.c:969
gboolean _commit_history_to_node(dt_dev_pixelpipe_t *pipe, dt_dev_pixelpipe_iop_t *piece, dt_dev_history_item_t *hist)
Definition pixelpipe_hb.c:498
void dt_dev_pixelpipe_reset_reentry(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:315
static dt_iop_colorspace_type_t _transform_for_picker(dt_iop_module_t *self, const dt_iop_colorspace_type_t cst)
Definition pixelpipe_hb.c:944
int dt_dev_pixelpipe_init_cached(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:181
void dt_dev_pixelpipe_get_roi_out(dt_dev_pixelpipe_t *pipe, struct dt_develop_t *dev, const int width_in, const int height_in, int *width, int *height)
Definition pixelpipe_hb.c:2129
gboolean dt_dev_pixelpipe_has_reentry(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:310
float * dt_dev_distort_detail_mask(const dt_dev_pixelpipe_t *pipe, float *src, const dt_iop_module_t *target_module)
Definition pixelpipe_hb.c:2560
dt_pixelpipe_flow_t
Definition pixelpipe_hb.c:51
@ PIXELPIPE_FLOW_HISTOGRAM_ON_GPU
Definition pixelpipe_hb.c:55
@ PIXELPIPE_FLOW_HISTOGRAM_NONE
Definition pixelpipe_hb.c:53
@ PIXELPIPE_FLOW_PROCESSED_ON_CPU
Definition pixelpipe_hb.c:56
@ PIXELPIPE_FLOW_PROCESSED_WITH_TILING
Definition pixelpipe_hb.c:58
@ PIXELPIPE_FLOW_PROCESSED_ON_GPU
Definition pixelpipe_hb.c:57
@ PIXELPIPE_FLOW_NONE
Definition pixelpipe_hb.c:52
@ PIXELPIPE_FLOW_BLENDED_ON_CPU
Definition pixelpipe_hb.c:59
@ PIXELPIPE_FLOW_HISTOGRAM_ON_CPU
Definition pixelpipe_hb.c:54
@ PIXELPIPE_FLOW_BLENDED_ON_GPU
Definition pixelpipe_hb.c:60
void dt_dev_pixelpipe_synch_top(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev)
Definition pixelpipe_hb.c:593
gboolean dt_dev_write_rawdetail_mask(dt_dev_pixelpipe_iop_t *piece, float *const rgb, const dt_iop_roi_t *const roi_in, const int mode)
Definition pixelpipe_hb.c:2432
void dt_dev_pixelpipe_disable_after(dt_dev_pixelpipe_t *pipe, const char *op)
Definition pixelpipe_hb.c:1919
void dt_dev_pixelpipe_synch_all_real(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, const char *caller_func)
Find the last history item matching each pipeline node (module), in the order of pipeline execution....
Definition pixelpipe_hb.c:544
dt_backbuf_t * _get_backuf(dt_develop_t *dev, const char *op)
Definition pixelpipe_hb.c:739
static void pixelpipe_picker(dt_iop_module_t *module, dt_dev_pixelpipe_iop_t *piece, dt_iop_buffer_dsc_t *dsc, const float *pixel, const dt_iop_roi_t *roi, float *picked_color, float *picked_color_min, float *picked_color_max, const dt_iop_colorspace_type_t image_cst, dt_pixelpipe_picker_source_t picker_source)
Definition pixelpipe_hb.c:890
static void _print_perf_debug(dt_dev_pixelpipe_t *pipe, const dt_pixelpipe_flow_t pixelpipe_flow, dt_dev_pixelpipe_iop_t *piece, dt_iop_module_t *module, dt_times_t *start)
Definition pixelpipe_hb.c:1451
void dt_dev_pixelpipe_synch(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, GList *history)
Definition pixelpipe_hb.c:517
dt_pixelpipe_picker_source_t
Definition pixelpipe_hb.c:64
@ PIXELPIPE_PICKER_INPUT
Definition pixelpipe_hb.c:65
@ PIXELPIPE_PICKER_OUTPUT
Definition pixelpipe_hb.c:66
static gboolean _transform_for_blend(const dt_iop_module_t *const self, const dt_dev_pixelpipe_iop_t *const piece)
Definition pixelpipe_hb.c:930
static gboolean _dt_dev_raster_mask_check(dt_dev_pixelpipe_iop_t *source_piece, dt_dev_pixelpipe_iop_t *current_piece, const dt_iop_module_t *target_module)
Checks the validity of the raster mask source and target modules, outputs errors if necessary....
Definition pixelpipe_hb.c:2215
static void _print_nan_debug(dt_dev_pixelpipe_t *pipe, void *cl_mem_output, void *output, const dt_iop_roi_t *roi_out, dt_iop_buffer_dsc_t *out_format, dt_iop_module_t *module, const size_t bpp)
Definition pixelpipe_hb.c:1480
#define KILL_SWITCH_ABORT
Definition pixelpipe_hb.c:1001
void dt_dev_pixelpipe_set_icc(dt_dev_pixelpipe_t *pipe, dt_colorspaces_color_profile_type_t icc_type, const gchar *icc_filename, dt_iop_color_intent_t icc_intent)
Definition pixelpipe_hb.c:244
void dt_dev_pixelpipe_create_nodes(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev)
Definition pixelpipe_hb.c:352
static void _print_opencl_errors(int error, dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:1962
static dt_dev_pixelpipe_iop_t * _last_node_in_pipe(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:1103
int dt_dev_pixelpipe_init_export(dt_dev_pixelpipe_t *pipe, int32_t width, int32_t height, int levels, gboolean store_masks)
Definition pixelpipe_hb.c:136
void dt_dev_pixelpipe_get_roi_in(dt_dev_pixelpipe_t *pipe, struct dt_develop_t *dev, const struct dt_iop_roi_t roi_out)
Definition pixelpipe_hb.c:2166
static int pixelpipe_process_on_CPU(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, float *input, dt_iop_buffer_dsc_t *input_format, const dt_iop_roi_t *roi_in, void **output, dt_iop_buffer_dsc_t **out_format, const dt_iop_roi_t *roi_out, dt_iop_module_t *module, dt_dev_pixelpipe_iop_t *piece, dt_develop_tiling_t *tiling, dt_pixelpipe_flow_t *pixelpipe_flow, dt_pixel_cache_entry_t *input_entry)
Definition pixelpipe_hb.c:1030
static int dt_dev_pixelpipe_process_rec(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, void **output, void **cl_mem_output, dt_iop_buffer_dsc_t **out_format, const dt_iop_roi_t *roi_out, GList *modules, GList *pieces, int pos)
Definition pixelpipe_hb.c:1672
int dt_dev_pixelpipe_init_dummy(dt_dev_pixelpipe_t *pipe, int32_t width, int32_t height)
Definition pixelpipe_hb.c:153
static void get_output_format(dt_iop_module_t *module, dt_dev_pixelpipe_t *pipe, dt_dev_pixelpipe_iop_t *piece, dt_develop_t *dev, dt_iop_buffer_dsc_t *dsc)
Definition pixelpipe_hb.c:698
static char * _pipe_type_to_str(int pipe_type)
Definition pixelpipe_hb.c:74
static void _sample_color_picker(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, float *input, dt_iop_buffer_dsc_t *input_format, const dt_iop_roi_t *roi_in, void **output, dt_iop_buffer_dsc_t **out_format, const dt_iop_roi_t *roi_out, dt_iop_module_t *module, dt_dev_pixelpipe_iop_t *piece)
Definition pixelpipe_hb.c:1114
float * dt_dev_get_raster_mask(dt_dev_pixelpipe_t *pipe, const dt_iop_module_t *raster_mask_source, const int raster_mask_id, const dt_iop_module_t *target_module, gboolean *free_mask, int *error)
Definition pixelpipe_hb.c:2281
static uint64_t _default_pipe_hash(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:406
#define KILL_SWITCH_PIPE
Definition pixelpipe_hb.c:1947
void dt_dev_pixelpipe_cleanup(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:253
gboolean dt_dev_pixelpipe_unset_reentry(dt_dev_pixelpipe_t *pipe, uint64_t hash)
Remove the re-entry pipeline flag, only if the object identifier is the one that set it....
Definition pixelpipe_hb.c:297
static void histogram_collect(dt_dev_pixelpipe_iop_t *piece, const void *pixel, const dt_iop_roi_t *roi, uint32_t **histogram, uint32_t *histogram_max)
Definition pixelpipe_hb.c:715
static void _copy_buffer(const char *const restrict input, char *const restrict output, const size_t height, const size_t o_width, const size_t i_width, const size_t x_offset, const size_t y_offset, const size_t stride, const size_t bpp)
Definition pixelpipe_hb.c:98
gboolean dt_dev_pixelpipe_activemodule_disables_currentmodule(struct dt_develop_t *dev, struct dt_iop_module_t *current_module)
Definition pixelpipe_hb.c:2120
int dt_dev_pixelpipe_init_thumbnail(dt_dev_pixelpipe_t *pipe, int32_t width, int32_t height)
Definition pixelpipe_hb.c:146
int dt_dev_pixelpipe_init(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:171
static void _uint8_to_float(const uint8_t *const input, float *const output, const size_t width, const size_t height, const size_t chan)
Definition pixelpipe_hb.c:115
#define KILL_SWITCH_AND_FLUSH_CACHE
Definition pixelpipe_hb.c:1016
static void pixelpipe_get_histogram_backbuf(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, void *output, const dt_iop_roi_t *roi, dt_iop_module_t *module, dt_dev_pixelpipe_iop_t *piece, const uint64_t hash, const size_t bpp)
Definition pixelpipe_hb.c:751
gboolean dt_dev_pixelpipe_set_reentry(dt_dev_pixelpipe_t *pipe, uint64_t hash)
Set the re-entry pipeline flag, only if no object is already capturing it. Re-entered pipelines run w...
Definition pixelpipe_hb.c:283
void dt_dev_pixelpipe_change(dt_dev_pixelpipe_t *pipe, struct dt_develop_t *dev)
Definition pixelpipe_hb.c:644
static int pixelpipe_picker_helper(dt_iop_module_t *module, const dt_iop_roi_t *roi, dt_aligned_pixel_t picked_color, dt_aligned_pixel_t picked_color_min, dt_aligned_pixel_t picked_color_max, dt_pixelpipe_picker_source_t picker_source, int *box)
Definition pixelpipe_hb.c:831
void dt_pixelpipe_get_global_hash(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev)
Definition pixelpipe_hb.c:430
static int _init_base_buffer(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, void **output, void **cl_mem_output, dt_iop_buffer_dsc_t **out_format, dt_iop_roi_t *roi_in, const dt_iop_roi_t *roi_out, const uint64_t hash, const gboolean bypass_cache, const size_t bufsize, const size_t bpp)
Definition pixelpipe_hb.c:1551
void dt_dev_clear_rawdetail_mask(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:2426
int dt_dev_pixelpipe_process(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, int x, int y, int width, int height, double scale)
Definition pixelpipe_hb.c:1981
void dt_dev_pixelpipe_cleanup_nodes(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:323
dt_dev_pixelpipe_change_t
Definition pixelpipe_hb.h:102
@ DT_DEV_PIPE_SYNCH
Definition pixelpipe_hb.h:106
@ DT_DEV_PIPE_TOP_CHANGED
Definition pixelpipe_hb.h:104
@ DT_DEV_PIPE_REMOVE
Definition pixelpipe_hb.h:105
@ DT_DEV_PIPE_UNCHANGED
Definition pixelpipe_hb.h:103
#define dt_dev_pixelpipe_synch_all(pipe, dev)
Definition pixelpipe_hb.h:287
@ DT_DEV_PIXELPIPE_DIRTY
Definition pixelpipe_hb.h:113
void output_format(dt_iop_module_t *self, dt_dev_pixelpipe_t *pipe, dt_dev_pixelpipe_iop_t *piece, dt_iop_buffer_dsc_t *dsc)
Definition rawprepare.c:274
#define DT_DEBUG_CONTROL_SIGNAL_RAISE(ctlsig, signal,...)
Definition signal.h:276
@ DT_SIGNAL_CONTROL_PICKERDATA_READY
This signal is raised when new color picker data are available in the pixelpipe. 1 module 2 piece no ...
Definition signal.h:229
unsigned __int64 uint64_t
Definition strptime.c:71
struct dt_lib_t * lib
Definition darktable.h:537
struct dt_dev_pixelpipe_cache_t * pixelpipe_cache
Definition darktable.h:556
struct dt_mipmap_cache_t * mipmap_cache
Definition darktable.h:542
struct dt_control_signal_t * signals
Definition darktable.h:540
struct dt_opencl_t * opencl
Definition darktable.h:551
int32_t unmuted
Definition darktable.h:526
struct dt_develop_t * develop
Definition darktable.h:536
size_t height
Definition develop.h:135
uint64_t hash
Definition develop.h:136
size_t width
Definition develop.h:134
void * buffer
Definition develop.h:133
size_t bpp
Definition develop.h:138
Definition colorpicker.h:42
dt_lib_colorpicker_size_t size
Definition colorpicker.h:49
dt_boundingbox_t box
Definition colorpicker.h:48
float point[2]
Definition colorpicker.h:47
Definition pixelpipe.h:48
const struct dt_histogram_roi_t * roi
Definition pixelpipe.h:50
uint32_t bins_count
Definition pixelpipe.h:61
Definition dev_history.h:30
uint64_t hash
Definition dev_history.h:42
dt_iop_params_t * params
Definition dev_history.h:33
char multi_name[128]
Definition dev_history.h:38
struct dt_develop_blend_params_t * blend_params
Definition dev_history.h:34
struct dt_iop_module_t *gboolean enabled
Definition dev_history.h:31
Definition pixelpipe_hb.h:46
gboolean enabled
Definition pixelpipe_hb.h:62
uint32_t histogram_max[4]
Definition pixelpipe_hb.h:68
dt_dev_request_flags_t request_histogram
Definition pixelpipe_hb.h:64
uint64_t blendop_hash
Definition pixelpipe_hb.h:74
struct dt_iop_module_t *struct dt_dev_pixelpipe_t * pipe
Definition pixelpipe_hb.h:48
uint64_t global_hash
Definition pixelpipe_hb.h:78
uint64_t hash
Definition pixelpipe_hb.h:73
dt_iop_buffer_dsc_t dsc_in
Definition pixelpipe_hb.h:93
uint32_t * histogram
Definition pixelpipe_hb.h:66
dt_dev_histogram_stats_t histogram_stats
Definition pixelpipe_hb.h:67
uint64_t global_mask_hash
Definition pixelpipe_hb.h:81
dt_iop_roi_t planned_roi_out
Definition pixelpipe_hb.h:88
gboolean bypass_cache
Definition pixelpipe_hb.h:96
int process_tiling_ready
Definition pixelpipe_hb.h:90
GHashTable * raster_masks
Definition pixelpipe_hb.h:98
dt_dev_histogram_collection_params_t histogram_params
Definition pixelpipe_hb.h:65
void * data
Definition pixelpipe_hb.h:49
void * blendop_data
Definition pixelpipe_hb.h:61
dt_iop_roi_t planned_roi_in
Definition pixelpipe_hb.h:88
Definition pixelpipe_hb.h:126
dt_colorspaces_color_profile_type_t icc_type
Definition pixelpipe_hb.h:198
struct dt_iop_order_iccprofile_info_t * work_profile_info
Definition pixelpipe_hb.h:144
struct dt_iop_order_iccprofile_info_t * input_profile_info
Definition pixelpipe_hb.h:146
int iwidth
Definition pixelpipe_hb.h:132
int want_detail_mask
Definition pixelpipe_hb.h:169
float backbuf_zoom_x
Definition pixelpipe_hb.h:158
GList * iop
Definition pixelpipe_hb.h:202
int opencl_error
Definition pixelpipe_hb.h:181
struct dt_iop_order_iccprofile_info_t * output_profile_info
Definition pixelpipe_hb.h:148
int running
Definition pixelpipe_hb.h:175
uint64_t backbuf_hash
Definition pixelpipe_hb.h:159
gchar * icc_filename
Definition pixelpipe_hb.h:199
int processed_width
Definition pixelpipe_hb.h:135
dt_dev_pixelpipe_change_t changed
Definition pixelpipe_hb.h:153
uint64_t last_history_hash
Definition pixelpipe_hb.h:213
dt_pthread_mutex_t busy_mutex
Definition pixelpipe_hb.h:160
gboolean flush_cache
Definition pixelpipe_hb.h:231
int mask_display
Definition pixelpipe_hb.h:185
float backbuf_scale
Definition pixelpipe_hb.h:157
GList * nodes
Definition pixelpipe_hb.h:151
dt_dev_pixelpipe_status_t status
Definition pixelpipe_hb.h:141
dt_imageio_levels_t levels
Definition pixelpipe_hb.h:192
gboolean reentry
Definition pixelpipe_hb.h:219
dt_mipmap_size_t size
Definition pixelpipe_hb.h:129
dt_iop_color_intent_t icc_intent
Definition pixelpipe_hb.h:200
dt_image_t image
Definition pixelpipe_hb.h:196
float * rawdetail_mask_data
Definition pixelpipe_hb.h:167
dt_atomic_int shutdown
Definition pixelpipe_hb.h:177
int output_backbuf_width
Definition pixelpipe_hb.h:163
dt_iop_buffer_dsc_t dsc
Definition pixelpipe_hb.h:139
uint64_t reentry_hash
Definition pixelpipe_hb.h:225
int opencl_enabled
Definition pixelpipe_hb.h:179
float backbuf_zoom_y
Definition pixelpipe_hb.h:158
int output_backbuf_height
Definition pixelpipe_hb.h:163
uint8_t * output_backbuf
Definition pixelpipe_hb.h:162
dt_dev_pixelpipe_type_t type
Definition pixelpipe_hb.h:190
int processed_height
Definition pixelpipe_hb.h:135
int32_t imgid
Definition pixelpipe_hb.h:128
size_t backbuf_width
Definition pixelpipe_hb.h:156
gboolean store_all_raster_masks
Definition pixelpipe_hb.h:208
dt_pthread_mutex_t backbuf_mutex
Definition pixelpipe_hb.h:160
int bypass_blendif
Definition pixelpipe_hb.h:187
int tiling
Definition pixelpipe_hb.h:183
int iheight
Definition pixelpipe_hb.h:132
struct dt_iop_roi_t rawdetail_mask_roi
Definition pixelpipe_hb.h:168
GList * forms
Definition pixelpipe_hb.h:206
void * backbuf
Definition pixelpipe_hb.h:155
int devid
Definition pixelpipe_hb.h:194
int processing
Definition pixelpipe_hb.h:173
int output_imgid
Definition pixelpipe_hb.h:171
GList * iop_order_list
Definition pixelpipe_hb.h:204
size_t backbuf_height
Definition pixelpipe_hb.h:156
int input_timestamp
Definition pixelpipe_hb.h:189
uint32_t mask_mode
Definition blend.h:183
float details
Definition blend.h:209
int32_t gui_attached
Definition develop.h:144
GList * iop_order_list
Definition develop.h:179
dt_image_t image_storage
Definition develop.h:164
dt_backbuf_t display_histogram
Definition develop.h:209
GList * iop
Definition develop.h:173
dt_backbuf_t output_histogram
Definition develop.h:208
struct dt_iop_module_t * gui_module
Definition develop.h:150
struct dt_dev_pixelpipe_t * preview_pipe
Definition develop.h:156
GList * history
Definition develop.h:169
dt_pthread_mutex_t history_mutex
Definition develop.h:167
dt_backbuf_t raw_histogram
Definition develop.h:207
GList * forms
Definition develop.h:189
float factor
Definition tiling.h:32
unsigned overhead
Definition tiling.h:40
float maxbuf
Definition tiling.h:36
Definition histogram.h:35
int width
Definition histogram.h:36
Definition common/image.h:195
dt_iop_buffer_dsc_t buf_dsc
Definition common/image.h:234
char filename[DT_MAX_FILENAME_LEN]
Definition common/image.h:218
Definition develop/format.h:36
int cst
Definition develop/format.h:62
unsigned int channels
Definition develop/format.h:38
dt_iop_buffer_type_t datatype
Definition develop/format.h:40
dt_aligned_pixel_t processed_maximum
Definition develop/format.h:59
dt_dev_request_colorpick_flags_t request_color_pick
Definition imageop.h:200
dt_aligned_pixel_t picked_output_color_min
Definition imageop.h:212
GtkWidget * widget
Definition imageop.h:268
char multi_name[128]
Definition imageop.h:294
struct dt_develop_t * dev
Definition imageop.h:227
GModule *dt_dev_operation_t op
Definition imageop.h:192
dt_dev_request_flags_t request_histogram
Definition imageop.h:202
int iop_order
Definition imageop.h:196
dt_aligned_pixel_t picked_output_color_max
Definition imageop.h:212
uint32_t histogram_max[4]
Definition imageop.h:218
dt_aligned_pixel_t picked_output_color
Definition imageop.h:212
gboolean enabled
Definition imageop.h:229
dt_aligned_pixel_t picked_color_min
Definition imageop.h:210
dt_aligned_pixel_t picked_color_max
Definition imageop.h:210
uint32_t * histogram
Definition imageop.h:214
dt_aligned_pixel_t picked_color
Definition imageop.h:210
Definition iop_profile.h:41
int x
Definition imageop.h:33
double scale
Definition imageop.h:34
int width
Definition imageop.h:33
int height
Definition imageop.h:33
int y
Definition imageop.h:33
struct dt_iop_color_picker_t * picker_proxy
Definition libs/lib.h:54
struct dt_lib_module_t *struct dt_colorpicker_sample_t * primary_sample
Definition libs/lib.h:53
struct dt_lib_t::@51 proxy
struct dt_lib_t::@51::@52 colorpicker
Definition mipmap_cache.h:58
int32_t height
Definition mipmap_cache.h:61
uint8_t * buf
Definition mipmap_cache.h:63
int32_t width
Definition mipmap_cache.h:61
int error_count
Definition opencl.h:498
int stopped
Definition opencl.h:497
Definition pixelpipe_cache.c:30
Definition darktable.h:605
#define dt_alloc_align(B)
Definition tests/cache.c:22
#define MIN(a, b)
Definition thinplate.c:23
#define MAX(a, b)
Definition thinplate.c:20
int dt_tiling_piece_fits_host_memory(const size_t width, const size_t height, const unsigned bpp, const float factor, const size_t overhead)
Definition tiling.c:2045