93 const char *phase,
const char *slot,
const uint64_t requested_hash,
95 const gboolean verbose)
101 "[pixelpipe_owner] pipe=%s module=%s phase=%s slot=%s req=%" PRIu64
102 " entry=%" PRIu64
"/%" PRIu64
" refs=%i auto=%i data=%p buf=%p name=%s\n",
104 module ? module->op : "base",
108 entry ? entry->hash : DT_PIXELPIPE_CACHE_HASH_INVALID,
109 entry ? entry->serial : 0,
110 entry ? dt_atomic_get_int((dt_atomic_int *)&entry->refcount) : -1,
111 entry ? entry->auto_destroy : -1,
112 entry ? entry->data : NULL,
114 (entry && entry->name) ? entry->name : "-");
119 const char *phase,
const void *buffer,
127 const size_t pixels = (size_t)roi->
width * (
size_t)roi->
height;
128 const unsigned int channels = format->
channels;
132 const float *in = (
const float *)buffer;
133 float minv[4] = { FLT_MAX, FLT_MAX, FLT_MAX, FLT_MAX };
134 float maxv[4] = { -FLT_MAX, -FLT_MAX, -FLT_MAX, -FLT_MAX };
135 size_t nonfinite = 0;
136 size_t near_black = 0;
138 for(
size_t k = 0;
k < pixels;
k++, in += channels)
140 gboolean finite =
TRUE;
141 for(
unsigned int c = 0; c <
MIN(channels, 4U); c++)
148 minv[c] = fminf(minv[c], in[c]);
149 maxv[c] = fmaxf(maxv[c], in[c]);
158 const float energy = fabsf(in[0]) + ((channels > 1) ? fabsf(in[1]) : 0.0f)
159 + ((channels > 2) ? fabsf(in[2]) : 0.0f);
160 if(energy < 1e-6f) near_black++;
164 "[pixelpipe_stats] pipe=%s module=%s phase=%s type=float ch=%u roi=%dx%d "
165 "rgb_min=(%g,%g,%g) rgb_max=(%g,%g,%g) a_min=%g a_max=%g near_black=%" G_GSIZE_FORMAT
"/%" G_GSIZE_FORMAT
" nonfinite=%" G_GSIZE_FORMAT
"\n",
168 minv[0], (channels > 1) ? minv[1] : 0.0f, (channels > 2) ? minv[2] : 0.0f,
169 maxv[0], (channels > 1) ? maxv[1] : 0.0f, (channels > 2) ? maxv[2] : 0.0f,
170 (channels > 3) ? minv[3] : 0.0f, (channels > 3) ? maxv[3] : 0.0f,
171 near_black, pixels, nonfinite);
175 const uint8_t *in = (
const uint8_t *)buffer;
176 int minv[4] = { 255, 255, 255, 255 };
177 int maxv[4] = { 0, 0, 0, 0 };
178 size_t near_black = 0;
180 for(
size_t k = 0;
k < pixels;
k++, in += channels)
182 for(
unsigned int c = 0; c <
MIN(channels, 4U); c++)
184 minv[c] =
MIN(minv[c], in[c]);
185 maxv[c] =
MAX(maxv[c], in[c]);
188 const int energy = in[0] + ((channels > 1) ? in[1] : 0) + ((channels > 2) ? in[2] : 0);
189 if(energy == 0) near_black++;
193 "[pixelpipe_stats] pipe=%s module=%s phase=%s type=u8 ch=%u roi=%dx%d "
194 "rgb_min=(%d,%d,%d) rgb_max=(%d,%d,%d) a_min=%d a_max=%d near_black=%" G_GSIZE_FORMAT
"/%" G_GSIZE_FORMAT
"\n",
197 minv[0], (channels > 1) ? minv[1] : 0, (channels > 2) ? minv[2] : 0,
198 maxv[0], (channels > 1) ? maxv[1] : 0, (channels > 2) ? maxv[2] : 0,
199 (channels > 3) ? minv[3] : 0, (channels > 3) ? maxv[3] : 0,
207 const uint64_t output_hash,
void **output,
212 output ? *output : NULL, output_entry,
FALSE);
230 if(output) *output = NULL;
243 && pipe->
realtime && dev &&
module && dev->gui_module == module;
281 const size_t width,
const size_t height,
const size_t chan)
286 const size_t index =
k * chan;
288 output[index + 0] = (float)input[index + 2] / 255.f;
289 output[index + 1] = (float)input[index + 1] / 255.f;
290 output[index + 2] = (float)input[index + 0] / 255.f;
291 output[index + 3] = 0.f;
306 return "display-rgb";
337 const gboolean is_cl,
340 const size_t in_bpp,
const size_t out_bpp,
341 const int cst_before,
const int cst_after)
345 const char *module_name =
module ? module->op : "base";
347 const char *stage_name = stage ? stage :
"process";
352 "[pixelpipe] %s %s %s %s: in cst=%s->%s ch=%d type=%s bpp=%" G_GSIZE_FORMAT
" roi=%dx%d | "
353 "out cst=%s ch=%d type=%s bpp=%" G_GSIZE_FORMAT
" roi=%dx%d\n",
354 pipe_name, module_name, is_cl ?
"cl" :
"cpu", stage_name,
357 roi_in ? roi_in->
width : 0, roi_in ? roi_in->
height : 0,
359 out_bpp, roi_out ? roi_out->
width : 0, roi_out ? roi_out->
height : 0);
364 "[pixelpipe] %s %s %s %s: out cst=%s ch=%d type=%s bpp=%" G_GSIZE_FORMAT
" roi=%dx%d\n",
365 pipe_name, module_name, is_cl ?
"cl" :
"cpu", stage_name,
367 out_bpp, roi_out ? roi_out->
width : 0, roi_out ? roi_out->
height : 0);
482 pipe->
icc_filename = g_strdup(icc_filename ? icc_filename :
"");
507 if(old_backbuf_entry)
574 for(GList *nodes = g_list_first(pipe->
nodes); nodes; nodes = g_list_next(nodes))
583 g_list_free(pipe->
nodes);
599 for(GList *modules = g_list_first(pipe->
dev->
iop); modules; modules = g_list_next(modules))
604 piece->
enabled =
module->enabled;
606 piece->histogram_params.bins_count = 256;
607 piece->iwidth = pipe->
iwidth;
608 piece->iheight = pipe->
iheight;
609 piece->module =
module;
615 piece->cache_output_on_ram =
TRUE;
619 piece->dsc_mask.channels = 1;
625 pipe->
nodes = g_list_append(pipe->
nodes, piece);
643 if(output_dsc->
cst != blend_cst
650#define KILL_SWITCH_ABORT \
651 if(dt_dev_pixelpipe_has_shutdown(pipe)) \
653 if(!IS_NULL_PTR(cl_mem_output)) \
655 dt_dev_pixelpipe_cache_release_cl_buffer(&cl_mem_output, NULL, NULL, FALSE); \
662#define KILL_SWITCH_AND_FLUSH_CACHE \
663 if(dt_dev_pixelpipe_has_shutdown(pipe)) \
665 return _abort_module_shutdown_cleanup(pipe, piece, module, input_hash, input, input_entry, hash, &output, \
666 &cl_mem_output, output_entry); \
671 const gboolean recycled_output_cacheline,
dt_times_t *start)
673 char histogram_log[32] =
"";
676 snprintf(histogram_log,
sizeof(histogram_log),
", collected histogram on %s",
684 start,
"[dev_pixelpipe]",
"processed `%s' on %s%s%s%s, blended on %s [%s]", module_label,
689 recycled_output_cacheline ?
", recycled cacheline" :
"",
713 int hasinf = 0, hasnan = 0;
721 float f = ((
float *)(output))[
k];
724 else if(!isfinite(
f))
734 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs NaNs! [%s]\n", module_label,
737 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs non-finite floats! [%s]\n", module_label,
739 fprintf(stderr,
"[dev_pixelpipe] module `%s' min: (%f; %f; %f) max: (%f; %f; %f) [%s]\n", module_label,
744 int hasinf = 0, hasnan = 0;
750 float f = ((
float *)(output))[
k];
753 else if(!isfinite(
f))
762 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs NaNs! [%s]\n", module_label,
765 fprintf(stderr,
"[dev_pixelpipe] module `%s' outputs non-finite floats! [%s]\n", module_label,
767 fprintf(stderr,
"[dev_pixelpipe] module `%s' min: (%f) max: (%f) [%s]\n", module_label,
min,
max,
777 GList *pieces,
int pos)
784 void *cl_mem_output = NULL;
804 module = piece->module;
818 void *existing_output = NULL;
819 const gboolean exact_output_cache_hit
825 if(exact_output_cache_hit)
845 "[pipeline] module=%s child recursion failed input_hash=%" PRIu64
" output_hash=%" PRIu64
"\n",
846 module->op, input_hash, hash);
863 "[pipeline] module=%s input cache entry missing input_hash=%" PRIu64
" output_hash=%" PRIu64
864 " prev_module=%s prev_hash=%" PRIu64
"\n",
865 module->op, input_hash, hash,
866 !
IS_NULL_PTR(previous_piece) ? previous_piece->module->op :
"",
874 const size_t bufsize = (size_t)piece->dsc_out.bpp * piece->roi_out.width * piece->roi_out.height;
889 && (piece->dsc_in.bpp == piece->dsc_out.bpp)
890 && !memcmp(&piece->roi_in, &piece->roi_out,
sizeof(
struct dt_iop_roi_t)))
897 *out_hash = input_hash;
898 *out_piece = previous_piece;
906 darktable.
main_message = g_strdup_printf(_(
"Processing module `%s` for pipeline %s (%ix%i px @ %0.f%%)..."),
908 piece->roi_out.width, piece->roi_out.height, piece->roi_out.scale * 100.f);
918 gchar *
name = g_strdup_printf(
"module %s (%s) for pipe %s", module->op, module->multi_name,
type);
919 gboolean cache_ram_output = piece->cache_output_on_ram && !
_bypass_cache(pipe, piece);
927 cache_ram_output, allow_rekey_reuse,
929 &output, &output_entry);
942 "[pipeline] module=%s exact-hit entry missing output_hash=%" PRIu64
"\n",
967 "[pipeline] module=%s writable output acquisition failed output_hash=%" PRIu64
968 " acquire_status=%d\n",
969 module->op, hash, acquire_status);
976 : (new_entry ?
"acquire-new" :
"acquire-existing"),
977 "output", hash, output, output_entry,
FALSE);
982 module->tiling_callback(module, pipe, piece, &tiling);
1006 assert(
tiling.factor > 0.0f);
1007 assert(
tiling.factor_cl > 0.0f);
1019 input_entry, output_entry);
1023 input_entry, output_entry);
1037 "[pipeline] module=%s backend processing failed input_hash=%" PRIu64
" output_hash=%" PRIu64
1038 " input_cst=%d output_cst=%d roi_in=%dx%d roi_out=%dx%d\n",
1039 module->op, input_hash, hash, piece->dsc_in.cst, piece->dsc_out.cst,
1040 piece->roi_in.width, piece->roi_in.height, piece->roi_out.width, piece->roi_out.height);
1066 piece->cache_entry = *output_entry;
1120 _print_nan_debug(pipe, cl_mem_output, output, &piece->roi_out, &piece->dsc_out, module);
1133 GList *nodes = g_list_last(pipe->
nodes);
1135 while(strcmp(piece->module->op, op))
1139 nodes = g_list_previous(nodes);
1147 GList *nodes = pipe->
nodes;
1149 while(strcmp(piece->module->op, op))
1153 nodes = g_list_next(nodes);
1159#define KILL_SWITCH_PIPE \
1160 if(dt_dev_pixelpipe_has_shutdown(pipe)) \
1162 if(pipe->devid >= 0) \
1164 dt_opencl_unlock_device(pipe->devid); \
1169 g_list_free_full(pipe->forms, (void (*)(void *))dt_masks_free_form); \
1170 pipe->forms = NULL; \
1172 dt_pthread_mutex_unlock(&darktable.pipeline_threadsafe); \
1187 "[opencl] Too many opencl errors; disabling opencl for this session!\n");
1188 dt_control_log(_(
"Ansel discovered problems with your OpenCL setup; disabling OpenCL for this session!"));
1201 entry ? entry->
data : NULL, entry,
FALSE);
1205 || entry_hash != requested_hash)
1239 int current_pos = 1;
1240 for(GList *node = g_list_first(pipe->
nodes); node; node = g_list_next(node), current_pos++)
1243 if(piece && piece->
enabled && piece->module == module)
1245 if(pos) *pos = current_pos;
1262 fprintf(stderr,
"[memory] before pixelpipe process\n");
1279 const guint pos = g_list_length(pipe->
dev->
iop);
1285 GList *requested_pieces = g_list_last(pipe->
nodes);
1286 int requested_pos = (int)pos;
1288 gboolean requested_backbuf =
TRUE;
1293 if(requested_pieces)
1295 requested_piece = requested_pieces->
data;
1296 requested_backbuf =
FALSE;
1300 dt_print(
DT_DEBUG_DEV,
"[pixelpipe/gui] requested module cache target disappeared pipe=%s module=%s\n",
1320 if(requested_backbuf)
1334 GList *pieces = g_list_last(pipe->
nodes);
1353 gboolean keep_running =
TRUE;
1355 int opencl_error = 0;
1358 while(keep_running && runs < 3)
1378 requested_backbuf ? pieces : requested_pieces,
1379 requested_backbuf ? pos : requested_pos);
1391 keep_running = (oclerr || (err && pipe->
opencl_error));
1418 void *final_buf = NULL;
1419 if(!requested_backbuf)
1424 &final_entry, pipe->
devid, NULL)
1433 "[picker/rec] final output cache missing pipe=%s hash=%" PRIu64
" history=%" PRIu64
1434 " devid=%d err=%d\n",
1453 if(pipe->
devid >= 0)
static void error(char *msg)
Definition ashift_lsd.c:202
#define TRUE
Definition ashift_lsd.c:162
#define FALSE
Definition ashift_lsd.c:158
void dt_atomic_set_int(dt_atomic_int *var, int value)
int dt_atomic_get_int(dt_atomic_int *var)
atomic_int dt_atomic_int
Definition atomic.h:66
int levels(struct dt_imageio_module_data_t *data)
Definition avif.c:635
int width
Definition bilateral.h:1
int height
Definition bilateral.h:1
void tiling_callback_blendop(struct dt_iop_module_t *self, const struct dt_dev_pixelpipe_t *pipe, const struct dt_dev_pixelpipe_iop_t *piece, struct dt_develop_tiling_t *tiling)
Definition blend.c:1487
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:186
@ DEVELOP_MASK_DISABLED
Definition blend.h:112
dt_iop_colorspace_type_t
Definition color_conversion.h:30
@ IOP_CS_RAW
Definition color_conversion.h:32
@ IOP_CS_LCH
Definition color_conversion.h:35
@ IOP_CS_JZCZHZ
Definition color_conversion.h:37
@ IOP_CS_RGB
Definition color_conversion.h:34
@ IOP_CS_HSL
Definition color_conversion.h:36
@ IOP_CS_LAB
Definition color_conversion.h:33
@ IOP_CS_NONE
Definition color_conversion.h:31
dt_iop_color_intent_t
Definition colorspaces.h:63
@ DT_INTENT_LAST
Definition colorspaces.h:68
dt_colorspaces_color_profile_type_t
Definition colorspaces.h:81
@ DT_COLORSPACE_NONE
Definition colorspaces.h:82
const dt_aligned_pixel_t f
Definition colorspaces_inline_conversions.h:102
const float d
Definition colorspaces_inline_conversions.h:680
static const float const float const float min
Definition colorspaces_inline_conversions.h:438
const float max
Definition colorspaces_inline_conversions.h:490
typedef void((*dt_cache_allocate_t)(void *userdata, dt_cache_entry_t *entry))
void dt_control_log(const char *msg,...)
Definition control.c:530
void dt_control_queue_redraw_center()
request redraw of center window. This redraws the center view within a gdk critical section to preven...
Definition control.c:630
void dt_show_times(const dt_times_t *start, const char *prefix)
Definition darktable.c:1486
darktable_t darktable
Definition darktable.c:173
void dt_print_mem_usage()
Definition darktable.c:1707
void dt_capabilities_remove(char *capability)
Definition darktable.c:1690
void dt_show_times_f(const dt_times_t *start, const char *prefix, const char *suffix,...)
Definition darktable.c:1500
void dt_print(dt_debug_thread_t thread, const char *msg,...)
Definition darktable.c:1448
#define UNKNOWN_IMAGE
Definition darktable.h:182
@ DT_DEBUG_OPENCL
Definition darktable.h:721
@ DT_DEBUG_PIPE
Definition darktable.h:740
@ DT_DEBUG_PIPECACHE
Definition darktable.h:719
@ DT_DEBUG_NAN
Definition darktable.h:725
@ DT_DEBUG_MEMORY
Definition darktable.h:723
@ DT_DEBUG_VERBOSE
Definition darktable.h:742
@ DT_DEBUG_DEV
Definition darktable.h:717
@ DT_DEBUG_NOCACHE_REUSE
Definition darktable.h:744
static void dt_free_gpointer(gpointer ptr)
Definition darktable.h:463
#define dt_free(ptr)
Definition darktable.h:456
static void dt_get_times(dt_times_t *t)
Definition darktable.h:920
#define __OMP_FOR_SIMD__(...)
Definition darktable.h:260
#define IS_NULL_PTR(p)
C is way too permissive with !=, == and if(var) checks, which can mean too many things depending on w...
Definition darktable.h:281
uint64_t dt_dev_pixelpipe_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 dev_pixelpipe.c:489
void dt_pixelpipe_get_global_hash(dt_dev_pixelpipe_t *pipe)
Definition dev_pixelpipe.c:854
void dt_dev_pixelpipe_get_roi_in(dt_dev_pixelpipe_t *pipe, const struct dt_iop_roi_t roi_out)
Definition dev_pixelpipe.c:403
void dt_dev_set_backbuf(dt_backbuf_t *backbuf, const int width, const int height, const size_t bpp, const int64_t hash, const int64_t history_hash)
Definition develop.c:1747
gchar * dt_history_item_get_name(const struct dt_iop_module_t *module)
Definition develop.c:1356
@ DT_DEV_PIXELPIPE_DISPLAY_NONE
Definition develop.h:117
static int dt_pthread_mutex_unlock(dt_pthread_mutex_t *mutex) RELEASE(mutex) NO_THREAD_SAFETY_ANALYSIS
Definition dtpthread.h:374
static int dt_pthread_mutex_init(dt_pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr)
Definition dtpthread.h:359
static int dt_pthread_mutex_destroy(dt_pthread_mutex_t *mutex)
Definition dtpthread.h:379
#define dt_pthread_rwlock_unlock
Definition dtpthread.h:392
static int dt_pthread_mutex_lock(dt_pthread_mutex_t *mutex) ACQUIRE(mutex) NO_THREAD_SAFETY_ANALYSIS
Definition dtpthread.h:364
#define dt_pthread_rwlock_rdlock
Definition dtpthread.h:393
@ IMAGEIO_RGB
Definition imageio.h:70
@ IMAGEIO_INT8
Definition imageio.h:62
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:526
void dt_iop_cleanup_pipe(struct dt_iop_module_t *module, struct dt_dev_pixelpipe_t *pipe, struct dt_dev_pixelpipe_iop_t *piece)
Definition imageop.c:533
static gboolean dt_iop_colorspace_is_rgb(const dt_iop_colorspace_type_t cst)
Definition imageop.h:213
@ IOP_FLAGS_SUPPORTS_BLENDING
Definition imageop.h:167
@ IOP_FLAGS_TAKE_NO_INPUT
Definition imageop.h:176
@ IOP_FLAGS_CPU_WRITES_OPENCL
Definition imageop.h:180
@ IOP_CS_RGB_DISPLAY
Definition imageop.h:210
@ IOP_TAG_DISTORT
Definition imageop.h:151
GList * dt_ioppr_iop_order_copy_deep(GList *iop_order_list)
Deep-copy an order list.
Definition iop_order.c:1935
float *const restrict const size_t k
Definition luminance_mask.h:78
GList * dt_masks_dup_forms_deep(GList *forms, dt_masks_form_t *form)
Duplicate the list of forms, replacing a single item by formid match.
Definition develop/masks/masks.c:719
void dt_masks_free_form(dt_masks_form_t *form)
Definition develop/masks/masks.c:2068
float iscale
Definition mipmap_cache.c:2
size_t size
Definition mipmap_cache.c:3
dt_mipmap_size_t
Definition mipmap_cache.h:41
float dt_aligned_pixel_t[4]
Definition noiseprofile.c:28
void dt_opencl_unlock_device(const int dev)
Definition opencl.c:1463
void dt_opencl_events_reset(const int devid)
Definition opencl.c:2705
cl_int dt_opencl_events_flush(const int devid, const int reset)
Definition opencl.c:2782
int dt_opencl_lock_device(const int pipetype)
Definition opencl.c:1378
void dt_opencl_check_tuning(const int devid)
Definition opencl.c:2462
int dt_opencl_update_settings(void)
Definition opencl.c:2568
#define DT_OPENCL_MAX_ERRORS
Definition opencl.h:49
void dt_pixelpipe_raster_cleanup(GHashTable *raster_masks)
Definition pixelpipe.c:70
GHashTable * dt_pixelpipe_raster_alloc()
Definition pixelpipe.c:58
void dt_dev_clear_rawdetail_mask(dt_dev_pixelpipe_t *pipe)
Release the side-band detail mask cache reference currently owned by the pipeline.
Definition pixelpipe.c:63
@ DT_REQUEST_ON
Definition pixelpipe.h:48
@ DT_REQUEST_ONLY_IN_GUI
Definition pixelpipe.h:49
dt_dev_pixelpipe_type_t
Definition pixelpipe.h:36
@ DT_DEV_PIXELPIPE_THUMBNAIL
Definition pixelpipe.h:41
@ DT_DEV_PIXELPIPE_EXPORT
Definition pixelpipe.h:38
@ DT_DEV_PIXELPIPE_PREVIEW
Definition pixelpipe.h:40
@ DT_DEV_PIXELPIPE_FULL
Definition pixelpipe.h:39
void * dt_pixel_cache_entry_get_data(dt_pixel_cache_entry_t *entry)
Definition pixelpipe_cache.c:1495
void dt_dev_pixelpipe_cache_ref_count_entry(dt_dev_pixelpipe_cache_t *cache, 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:2225
void dt_dev_pixelpipe_cache_print(dt_dev_pixelpipe_cache_t *cache)
Definition pixelpipe_cache.c:2426
void dt_dev_pixelpipe_cache_unref_hash(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash)
Find the entry matching hash, and decrease its ref_count if found.
Definition pixelpipe_cache.c:2326
void dt_dev_pixelpipe_cache_flag_auto_destroy(dt_dev_pixelpipe_cache_t *cache, dt_pixel_cache_entry_t *cache_entry)
Flag the cache entry as "auto_destroy". This is useful for short-lived/disposable cache entries,...
Definition pixelpipe_cache.c:2268
void dt_dev_pixelpipe_cache_auto_destroy_apply(dt_dev_pixelpipe_cache_t *cache, dt_pixel_cache_entry_t *cache_entry)
Free the entry if it has the flag "auto_destroy". See dt_dev_pixelpipe_cache_flag_auto_destroy()....
Definition pixelpipe_cache.c:2284
void dt_dev_pixelpipe_cache_release_cl_buffer(void **cl_mem_buffer, dt_pixel_cache_entry_t *cache_entry, void *host_ptr, const gboolean cache_device)
Release or cache an OpenCL image associated with a host cache line.
Definition pixelpipe_cache.c:1017
gboolean dt_dev_pixelpipe_cache_peek(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, void **data, dt_pixel_cache_entry_t **entry, const int preferred_devid, void **cl_mem_output)
Non-owning lookup of an existing cache line.
Definition pixelpipe_cache.c:2052
void dt_dev_pixelpipe_cache_flush_entry_clmem(dt_pixel_cache_entry_t *entry)
Flush all reusable OpenCL payloads cached on one cache entry.
Definition pixelpipe_cache.c:731
dt_pixel_cache_entry_t * dt_dev_pixelpipe_cache_get_entry(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash)
Get an internal reference to the cache entry matching hash. If you are going to access this entry mor...
Definition pixelpipe_cache.c:144
int dt_dev_pixelpipe_cache_remove(dt_dev_pixelpipe_cache_t *cache, 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:255
dt_dev_pixelpipe_cache_writable_status_t dt_dev_pixelpipe_cache_get_writable(dt_dev_pixelpipe_cache_t *cache, const uint64_t hash, const size_t size, const char *name, const int id, const gboolean alloc, const gboolean allow_rekey_reuse, const dt_pixel_cache_entry_t *reuse_hint, void **data, dt_pixel_cache_entry_t **entry)
Definition pixelpipe_cache.c:1917
void dt_dev_pixelpipe_cache_wrlock_entry(dt_dev_pixelpipe_cache_t *cache, gboolean lock, dt_pixel_cache_entry_t *cache_entry)
Lock or release the write lock on the entry.
Definition pixelpipe_cache.c:2234
size_t dt_pixel_cache_entry_get_size(dt_pixel_cache_entry_t *entry)
Peek the size (in bytes) reserved for the host buffer of a cache entry.
Definition pixelpipe_cache.c:1500
void dt_dev_pixelpipe_cache_rdlock_entry(dt_dev_pixelpipe_cache_t *cache, gboolean lock, dt_pixel_cache_entry_t *cache_entry)
Lock or release the read lock on the entry.
Definition pixelpipe_cache.c:2252
void dt_dev_pixelpipe_cache_flush_clmem(dt_dev_pixelpipe_cache_t *cache, const int devid)
Release cached OpenCL buffers for a device (-1 for all).
Definition pixelpipe_cache.c:444
const char * dt_pixelpipe_cache_set_current_module(const char *module)
Set the current module name for cache diagnostics (thread-local).
Definition pixelpipe_cache.c:78
Pixelpipe cache for storing intermediate results in the pixelpipe.
#define DT_PIXELPIPE_CACHE_HASH_INVALID
Definition pixelpipe_cache.h:42
dt_dev_pixelpipe_cache_writable_status_t
Definition pixelpipe_cache.h:70
@ DT_DEV_PIXELPIPE_CACHE_WRITABLE_REKEYED
Definition pixelpipe_cache.h:74
@ DT_DEV_PIXELPIPE_CACHE_WRITABLE_CREATED
Definition pixelpipe_cache.h:73
@ DT_DEV_PIXELPIPE_CACHE_WRITABLE_EXACT_HIT
Definition pixelpipe_cache.h:72
int pixelpipe_process_on_CPU(dt_dev_pixelpipe_t *pipe, const dt_dev_pixelpipe_iop_t *piece, const dt_dev_pixelpipe_iop_t *previous_piece, dt_develop_tiling_t *tiling, dt_pixelpipe_flow_t *pixelpipe_flow, gboolean *const cache_output, dt_pixel_cache_entry_t *input_entry, dt_pixel_cache_entry_t *output_entry)
Definition pixelpipe_cpu.c:15
int pixelpipe_process_on_GPU(dt_dev_pixelpipe_t *pipe, const dt_dev_pixelpipe_iop_t *piece, const dt_dev_pixelpipe_iop_t *previous_piece, dt_develop_tiling_t *tiling, dt_pixelpipe_flow_t *pixelpipe_flow, gboolean *const cache_output, dt_pixel_cache_entry_t *input_entry, dt_pixel_cache_entry_t *output_entry)
Definition pixelpipe_gpu.c:187
void dt_dev_pixelpipe_gpu_flush_host_pinned_images(dt_dev_pixelpipe_t *pipe, void *host_ptr, dt_pixel_cache_entry_t *cache_entry, const char *reason)
Definition pixelpipe_gpu.c:16
void dt_dev_pixelpipe_set_input(dt_dev_pixelpipe_t *pipe, int32_t imgid, int width, int height, float iscale, dt_mipmap_size_t size)
Definition pixelpipe_hb.c:466
dt_pixelpipe_blend_transform_t dt_dev_pixelpipe_transform_for_blend(const dt_iop_module_t *const self, const dt_dev_pixelpipe_iop_t *const piece, const dt_iop_buffer_dsc_t *const output_dsc)
Definition pixelpipe_hb.c:629
static void _trace_buffer_content(const dt_dev_pixelpipe_t *pipe, const dt_iop_module_t *module, const char *phase, const void *buffer, const dt_iop_buffer_dsc_t *format, const dt_iop_roi_t *roi)
Definition pixelpipe_hb.c:118
void dt_dev_pixelpipe_disable_before(dt_dev_pixelpipe_t *pipe, const char *op)
Definition pixelpipe_hb.c:1145
int dt_dev_pixelpipe_init_dummy(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev)
Definition pixelpipe_hb.c:392
static gboolean _is_focused_realtime_gui_module(const dt_dev_pixelpipe_t *pipe, const dt_develop_t *dev, const dt_iop_module_t *module)
Definition pixelpipe_hb.c:238
void dt_dev_pixelpipe_reset_reentry(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:564
int dt_dev_pixelpipe_init_cached(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:425
static void _update_backbuf_cache_reference(dt_dev_pixelpipe_t *pipe, dt_iop_roi_t roi, dt_pixel_cache_entry_t *entry)
Definition pixelpipe_hb.c:1195
gboolean dt_dev_pixelpipe_has_reentry(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:559
void dt_dev_pixelpipe_disable_after(dt_dev_pixelpipe_t *pipe, const char *op)
Definition pixelpipe_hb.c:1131
int dt_dev_pixelpipe_init(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev)
Definition pixelpipe_hb.c:414
gboolean dt_dev_pixelpipe_cache_gpu_device_buffer(const dt_dev_pixelpipe_t *pipe, const dt_pixel_cache_entry_t *cache_entry)
Definition pixelpipe_hb.c:247
gboolean dt_dev_pixelpipe_get_realtime(const dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:461
static const char * _debug_type_to_string(const dt_iop_buffer_type_t type)
Definition pixelpipe_hb.c:320
static const char * _debug_cst_to_string(const int cst)
Definition pixelpipe_hb.c:295
#define KILL_SWITCH_ABORT
Definition pixelpipe_hb.c:650
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:477
static int _abort_module_shutdown_cleanup(dt_dev_pixelpipe_t *pipe, dt_dev_pixelpipe_iop_t *piece, dt_iop_module_t *module, const uint64_t input_hash, const void *input, dt_pixel_cache_entry_t *input_entry, const uint64_t output_hash, void **output, void **cl_mem_output, dt_pixel_cache_entry_t *output_entry)
Definition pixelpipe_hb.c:204
static int dt_dev_pixelpipe_process_rec(dt_dev_pixelpipe_t *pipe, uint64_t *out_hash, const dt_dev_pixelpipe_iop_t **out_piece, GList *pieces, int pos)
Definition pixelpipe_hb.c:775
char * dt_pixelpipe_get_pipe_name(dt_dev_pixelpipe_type_t pipe_type)
Definition pixelpipe_hb.c:255
static void _print_opencl_errors(int error, dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:1177
static void _trace_cache_owner(const dt_dev_pixelpipe_t *pipe, const dt_iop_module_t *module, const char *phase, const char *slot, const uint64_t requested_hash, const void *buffer, const dt_pixel_cache_entry_t *entry, const gboolean verbose)
Definition pixelpipe_hb.c:92
static GList * _get_requested_piece_node(const dt_dev_pixelpipe_t *pipe, const dt_iop_module_t *module, int *pos)
Definition pixelpipe_hb.c:1234
int dt_dev_pixelpipe_init_preview(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev)
Definition pixelpipe_hb.c:401
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)
Definition pixelpipe_hb.c:701
void dt_dev_pixelpipe_create_nodes(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:591
int dt_dev_pixelpipe_init_thumbnail(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev)
Definition pixelpipe_hb.c:383
int dt_dev_pixelpipe_init_export(dt_dev_pixelpipe_t *pipe, dt_develop_t *dev, int levels, gboolean store_masks)
Definition pixelpipe_hb.c:372
#define KILL_SWITCH_PIPE
Definition pixelpipe_hb.c:1159
void dt_dev_pixelpipe_cleanup(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:486
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:546
int dt_dev_pixelpipe_process(dt_dev_pixelpipe_t *pipe, dt_iop_roi_t roi)
Definition pixelpipe_hb.c:1253
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, const gboolean recycled_output_cacheline, dt_times_t *start)
Definition pixelpipe_hb.c:669
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:280
void dt_dev_pixelpipe_debug_dump_module_io(dt_dev_pixelpipe_t *pipe, dt_iop_module_t *module, const char *stage, const gboolean is_cl, const dt_iop_buffer_dsc_t *in_dsc, const dt_iop_buffer_dsc_t *out_dsc, const dt_iop_roi_t *roi_in, const dt_iop_roi_t *roi_out, const size_t in_bpp, const size_t out_bpp, const int cst_before, const int cst_after)
Definition pixelpipe_hb.c:336
#define KILL_SWITCH_AND_FLUSH_CACHE
Definition pixelpipe_hb.c:662
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:532
void dt_dev_pixelpipe_set_realtime(dt_dev_pixelpipe_t *pipe, gboolean state)
Definition pixelpipe_hb.c:455
void dt_dev_pixelpipe_cleanup_nodes(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.c:571
static dt_dev_pixelpipe_cache_request_t dt_dev_pixelpipe_get_cache_request(const dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.h:408
static void dt_dev_pixelpipe_set_hash(dt_dev_pixelpipe_t *pipe, const uint64_t hash)
Definition pixelpipe_hb.h:378
static const struct dt_iop_module_t * dt_dev_pixelpipe_get_cache_request_module(const dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.h:414
static uint64_t dt_dev_pixelpipe_get_hash(const dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.h:373
static void dt_dev_pixelpipe_reset_cache_request(dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.h:428
@ DT_DEV_PIPE_UNCHANGED
Definition pixelpipe_hb.h:166
static uint64_t dt_dev_pixelpipe_get_history_hash(const dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.h:383
static void dt_dev_pixelpipe_set_history_hash(dt_dev_pixelpipe_t *pipe, const uint64_t history_hash)
Definition pixelpipe_hb.h:388
static uint64_t dt_dev_backbuf_get_hash(const dt_backbuf_t *backbuf)
Definition pixelpipe_hb.h:197
dt_dev_pixelpipe_cache_request_t
Definition pixelpipe_hb.h:176
@ DT_DEV_PIXELPIPE_CACHE_REQUEST_MODULE
Definition pixelpipe_hb.h:179
static void dt_dev_pixelpipe_set_changed(dt_dev_pixelpipe_t *pipe, const dt_dev_pixelpipe_change_t v)
Definition pixelpipe_hb.h:398
static gboolean dt_dev_pixelpipe_has_shutdown(const dt_dev_pixelpipe_t *pipe)
Definition pixelpipe_hb.h:462
dt_pixelpipe_flow_t
Definition pixelpipe_process.h:14
@ PIXELPIPE_FLOW_HISTOGRAM_ON_GPU
Definition pixelpipe_process.h:18
@ PIXELPIPE_FLOW_HISTOGRAM_NONE
Definition pixelpipe_process.h:16
@ PIXELPIPE_FLOW_PROCESSED_ON_CPU
Definition pixelpipe_process.h:19
@ PIXELPIPE_FLOW_PROCESSED_WITH_TILING
Definition pixelpipe_process.h:21
@ PIXELPIPE_FLOW_PROCESSED_ON_GPU
Definition pixelpipe_process.h:20
@ PIXELPIPE_FLOW_NONE
Definition pixelpipe_process.h:15
@ PIXELPIPE_FLOW_BLENDED_ON_CPU
Definition pixelpipe_process.h:22
@ PIXELPIPE_FLOW_HISTOGRAM_ON_CPU
Definition pixelpipe_process.h:17
@ PIXELPIPE_FLOW_BLENDED_ON_GPU
Definition pixelpipe_process.h:23
static void _reset_piece_cache_entry(dt_dev_pixelpipe_iop_t *piece)
Drop the writable-reuse snapshot attached to a pipeline piece.
Definition pixelpipe_process.h:59
static gboolean _bypass_cache(const dt_dev_pixelpipe_t *pipe, const dt_dev_pixelpipe_iop_t *piece)
Tell whether the current pipeline state forbids keeping this module output in cache.
Definition pixelpipe_process.h:45
dt_pixelpipe_blend_transform_t
Definition pixelpipe_process.h:27
@ DT_DEV_PIXELPIPE_BLEND_TRANSFORM_INPUT
Definition pixelpipe_process.h:29
@ DT_DEV_PIXELPIPE_BLEND_TRANSFORM_NONE
Definition pixelpipe_process.h:28
@ DT_DEV_PIXELPIPE_BLEND_TRANSFORM_OUTPUT
Definition pixelpipe_process.h:30
Raster-mask retrieval and transport through already-processed pipeline nodes.
Raw-detail mask transport helpers.
const float uint32_t state[4]
Definition src/develop/noise_generator.h:72
const float r
Definition src/develop/noise_generator.h:101
unsigned __int64 uint64_t
Definition strptime.c:75
struct dt_dev_pixelpipe_cache_t * pixelpipe_cache
Definition darktable.h:789
struct dt_opencl_t * opencl
Definition darktable.h:784
int32_t unmuted
Definition darktable.h:759
dt_pthread_mutex_t pipeline_threadsafe
Definition darktable.h:807
char * main_message
Definition darktable.h:836
Definition pixelpipe_hb.h:96
gboolean enabled
Definition pixelpipe_hb.h:111
dt_dev_request_flags_t request_histogram
Definition pixelpipe_hb.h:114
uint64_t global_hash
Definition pixelpipe_hb.h:125
dt_iop_buffer_dsc_t dsc_in
Definition pixelpipe_hb.h:142
struct dt_iop_module_t *void * data
Definition pixelpipe_hb.h:97
GHashTable * raster_masks
Definition pixelpipe_hb.h:161
void * blendop_data
Definition pixelpipe_hb.h:110
Definition pixelpipe_hb.h:218
dt_colorspaces_color_profile_type_t icc_type
Definition pixelpipe_hb.h:310
int iwidth
Definition pixelpipe_hb.h:227
int opencl_error
Definition pixelpipe_hb.h:291
gboolean gui_observable_source
Definition pixelpipe_hb.h:304
gchar * icc_filename
Definition pixelpipe_hb.h:311
uint64_t last_history_hash
Definition pixelpipe_hb.h:323
dt_pthread_mutex_t busy_mutex
Definition pixelpipe_hb.h:259
gboolean flush_cache
Definition pixelpipe_hb.h:354
int mask_display
Definition pixelpipe_hb.h:295
GList * nodes
Definition pixelpipe_hb.h:245
dt_imageio_levels_t levels
Definition pixelpipe_hb.h:306
dt_atomic_int realtime
Definition pixelpipe_hb.h:287
dt_backbuf_t backbuf
Definition pixelpipe_hb.h:250
gboolean reentry
Definition pixelpipe_hb.h:342
dt_mipmap_size_t size
Definition pixelpipe_hb.h:224
dt_iop_color_intent_t icc_intent
Definition pixelpipe_hb.h:312
dt_atomic_int shutdown
Definition pixelpipe_hb.h:276
uint64_t reentry_hash
Definition pixelpipe_hb.h:348
int opencl_enabled
Definition pixelpipe_hb.h:289
dt_dev_pixelpipe_type_t type
Definition pixelpipe_hb.h:300
float iscale
Definition pixelpipe_hb.h:232
int32_t imgid
Definition pixelpipe_hb.h:223
gboolean no_cache
Definition pixelpipe_hb.h:362
gboolean store_all_raster_masks
Definition pixelpipe_hb.h:318
uint64_t rawdetail_mask_hash
Definition pixelpipe_hb.h:266
int iheight
Definition pixelpipe_hb.h:227
GList * forms
Definition pixelpipe_hb.h:316
int devid
Definition pixelpipe_hb.h:308
int output_imgid
Definition pixelpipe_hb.h:270
struct dt_develop_t * dev
Definition pixelpipe_hb.h:220
GList * iop_order_list
Definition pixelpipe_hb.h:314
int32_t gui_attached
Definition develop.h:162
GList * iop_order_list
Definition develop.h:274
dt_image_t image_storage
Definition develop.h:248
struct dt_develop_t::@19 color_picker
Authoritative darkroom color-picker state.
GList * iop
Definition develop.h:268
struct dt_iop_module_t * pending_module
Definition develop.h:376
int completed
Definition develop.h:462
struct dt_dev_pixelpipe_t * pending_pipe
Definition develop.h:377
dt_pthread_rwlock_t masks_mutex
Definition develop.h:304
struct dt_develop_t::@26 progress
uint64_t piece_hash
Definition develop.h:372
int total
Definition develop.h:462
GList * forms
Definition develop.h:292
float factor
Definition tiling.h:41
unsigned overhead
Definition tiling.h:49
float maxbuf
Definition tiling.h:45
int cst
Definition format.h:88
unsigned int channels
Definition format.h:54
dt_iop_buffer_type_t datatype
Definition format.h:56
GModule *dt_dev_operation_t op
Definition imageop.h:256
Region of interest passed through the pixelpipe.
Definition imageop.h:72
int width
Definition imageop.h:73
int height
Definition imageop.h:73
int error_count
Definition opencl.h:226
int stopped
Definition opencl.h:224
Definition pixelpipe_cache.h:87
uint64_t hash
Definition pixelpipe_cache.h:88
void * data
Definition pixelpipe_cache.h:90
Definition darktable.h:840
#define MIN(a, b)
Definition thinplate.c:32
#define MAX(a, b)
Definition thinplate.c:29