![]() |
Ansel 0.0
A darktable fork - bloat + design vision
|
#include <inttypes.h>#include <stdint.h>#include <glib.h>
Include dependency graph for dev_pixelpipe.h:
This graph shows which files directly or indirectly include this file:Go to the source code of this file.
Data Structures | |
| struct | dt_dev_pixelpipe_cache_wait_t |
Typedefs | |
| typedef void(* | dt_dev_pixelpipe_cache_ready_callback_t) (gpointer user_data) |
| typedef struct dt_dev_pixelpipe_cache_wait_t | dt_dev_pixelpipe_cache_wait_t |
| #define dt_dev_pixelpipe_rebuild_all | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_rebuild_all_real, (dev)) |
Definition at line 34 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_resync_history_all | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_resync_history_all_real, (dev)) |
Definition at line 63 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_resync_history_main | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_resync_history_main_real, (dev)) |
Definition at line 68 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_resync_history_preview | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_resync_history_preview_real, (dev)) |
Definition at line 73 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_update_history_all | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_update_history_all_real, (dev)) |
Definition at line 48 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_update_history_main | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_update_history_main_real, (dev)) |
Definition at line 40 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_update_history_preview | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_update_history_preview_real, (dev)) |
Definition at line 44 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_update_zoom_main | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_update_zoom_main_real, (dev)) |
Definition at line 53 of file dev_pixelpipe.h.
| #define dt_dev_pixelpipe_update_zoom_preview | ( | dev | ) | DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_pixelpipe_update_zoom_preview_real, (dev)) |
Definition at line 58 of file dev_pixelpipe.h.
| typedef void(* dt_dev_pixelpipe_cache_ready_callback_t) (gpointer user_data) |
Definition at line 150 of file dev_pixelpipe.h.
| typedef struct dt_dev_pixelpipe_cache_wait_t dt_dev_pixelpipe_cache_wait_t |
| gboolean dt_dev_pixelpipe_activemodule_disables_currentmodule | ( | struct dt_develop_t * | dev, |
| struct dt_iop_module_t * | current_module | ||
| ) |
Definition at line 488 of file dev_pixelpipe.c.
References dt_iop_get_cache_bypass(), dt_develop_t::gui_attached, and dt_develop_t::gui_module.
Referenced by call_distort_transform(), dt_dev_distort_detail_mask(), dt_dev_get_raster_mask(), dt_dev_pixelpipe_get_roi_in(), dt_dev_pixelpipe_get_roi_out(), and dt_pixelpipe_get_global_hash().
| gboolean dt_dev_pixelpipe_cache_peek_gui | ( | dt_dev_pixelpipe_t * | pipe, |
| const struct dt_dev_pixelpipe_iop_t * | piece, | ||
| void ** | data, | ||
| struct dt_pixel_cache_entry_t ** | cache_entry, | ||
| dt_dev_pixelpipe_cache_wait_t * | wait, | ||
| dt_dev_pixelpipe_cache_ready_callback_t | restart, | ||
| gpointer | restart_data | ||
| ) |
Reopen one GUI-visible host cacheline, or queue the minimal pipe recompute needed to publish it.
GUI samplers only consume host-visible buffers. This wrapper first tries to reopen the requested cacheline:
piece output if piece is not NULL,piece is NULL.If that cacheline does not exist yet, or only exists as a device-side OpenCL payload, the wrapper schedules one dedicated pipe run:
The request uses a dedicated pipe state instead of pretending history changed, so the worker can rerun just enough of the current synchronized graph to satisfy the GUI reader.
| pipe | Current live pipe. |
| piece | Target module piece, or NULL for the final backbuffer. |
| data | Returned host-visible pixel buffer on success. |
| cache_entry | Returned cache entry owning data on success. |
| wait | Optional one-shot cacheline-ready watcher owned by the caller. |
| restart | Optional restart callback used with wait when the cacheline must be published asynchronously. |
| restart_data | Opaque pointer forwarded to restart. |
| void dt_dev_pixelpipe_cache_wait_cleanup | ( | dt_dev_pixelpipe_cache_wait_t * | wait, |
| const char * | reason | ||
| ) |
Cancel one pending GUI cache wait request and clear its runtime state.
This removes wait from the shared pending queue (if connected), emits a lifecycle debug log and resets the wait object to an inert state. Callers should pass a short static reason string to make cancellations traceable in logs.
| wait | Caller-owned wait object. |
| reason | Short static cancellation context label for debug traces. |
Definition at line 913 of file dev_pixelpipe.c.
References _cache_wait_cursor_restore(), _cache_wait_manager, _cache_wait_manager_remove_wait_locked(), _dt_dev_pixelpipe_cache_wait_ready_callback(), dt_dev_pixelpipe_cache_wait_manager_t::cancelled_requests, dt_dev_pixelpipe_cache_wait_manager_t::connected, dt_dev_pixelpipe_cache_wait_t::connected, darktable, DT_DEBUG_CONTROL_SIGNAL_DISCONNECT, DT_DEBUG_PIPECACHE, dt_free, DT_PIXELPIPE_CACHE_HASH_INVALID, dt_print(), dt_pthread_mutex_lock(), dt_pthread_mutex_unlock(), FALSE, dt_dev_pixelpipe_cache_wait_t::hash, IS_NULL_PTR, dt_dev_pixelpipe_cache_wait_manager_t::lock, MAX, dt_dev_pixelpipe_cache_wait_t::owner_tag, dt_dev_pixelpipe_cache_wait_manager_t::pending, dt_dev_pixelpipe_cache_wait_t::pipe, dt_dev_pixelpipe_cache_wait_record_t::queued_at_us, dt_dev_pixelpipe_cache_wait_t::request_id, dt_dev_pixelpipe_cache_wait_t::restart, darktable_t::signals, TRUE, dt_dev_pixelpipe_cache_wait_t::user_data, and dt_dev_pixelpipe_cache_wait_manager_t::wait_cursor_active.
Referenced by _color_picker_callback_button_press(), _refresh_preview_cursor_sample(), _release_expose_source_caches(), cleanup(), dt_dev_pixelpipe_cache_peek_gui(), dt_iop_autoset_advance(), dt_iop_autoset_build_list(), dt_iop_color_picker_reset(), gui_cleanup(), gui_cleanup(), gui_focus(), leave(), and view_leave().
| void dt_dev_pixelpipe_cache_wait_dump_pending | ( | const char * | reason | ) |
Dump pending GUI cache wait requests for lifecycle debugging.
This reports the current queue of not-yet-served cache wait requests, with ownership tags, request ids and target hashes. Callers should use it right before teardown phases (view leave / app shutdown) to identify abandoned waits that never received a cacheline-ready event.
| reason | Short caller-provided context label for the log entry. |
Definition at line 105 of file dev_pixelpipe.c.
References _cache_wait_manager, dt_dev_pixelpipe_cache_wait_manager_t::cancelled_requests, dt_dev_pixelpipe_cache_wait_t::connected, DT_DEBUG_PIPECACHE, dt_print(), dt_pthread_mutex_trylock(), dt_pthread_mutex_unlock(), dt_dev_pixelpipe_cache_wait_t::hash, dt_dev_pixelpipe_cache_wait_manager_t::immediate_hits, IS_NULL_PTR, dt_dev_pixelpipe_cache_wait_manager_t::lock, MAX, dt_dev_pixelpipe_cache_wait_manager_t::misses, dt_dev_pixelpipe_cache_wait_t::owner_tag, dt_dev_pixelpipe_cache_wait_manager_t::pending, dt_dev_pixelpipe_cache_wait_record_t::queued_at_us, dt_dev_pixelpipe_cache_wait_manager_t::queued_requests, dt_dev_pixelpipe_cache_wait_t::request_id, dt_dev_pixelpipe_cache_wait_manager_t::served_requests, and dt_dev_pixelpipe_cache_wait_record_t::wait.
Referenced by dt_cleanup(), and leave().
| void dt_dev_pixelpipe_cache_wait_set_owner | ( | dt_dev_pixelpipe_cache_wait_t * | wait, |
| const char * | owner_tag, | ||
| gpointer | owner_object | ||
| ) |
Attach debug ownership metadata to one cache wait request.
The cache wait manager tracks heterogeneous GUI consumers (pickers, histograms, autoset, darkroom surfaces) in a shared pending queue. This setter lets each caller stamp the wait object with:
owner_tag) used in logs,owner_object) used to correlate repeated requests from the same caller.Ownership metadata does not affect scheduling or locking decisions. It only improves traceability when diagnosing missed/served requests and UI/pipeline desynchronization.
| wait | Caller-owned wait object to annotate. |
| owner_tag | Short static owner label for debug traces. |
| owner_object | Caller instance pointer associated with the request. |
Definition at line 967 of file dev_pixelpipe.c.
References IS_NULL_PTR, dt_dev_pixelpipe_cache_wait_t::owner_object, and dt_dev_pixelpipe_cache_wait_t::owner_tag.
Referenced by _lib_navigation_draw_callback(), _lib_navigation_history_resync_callback(), _lock_pipe_surface(), _pixelpipe_pick_from_image(), _process_histogram(), _process_vectorscope(), _refresh_preview_cursor_sample(), _refresh_preview_module_histogram_for_hash(), _sample_picker_from_cache(), and dt_iop_autoset_advance().
| void dt_dev_pixelpipe_change | ( | struct dt_dev_pixelpipe_t * | pipe | ) |
Consume and clear pending change flags in one atomic step.
The previous get-then-store sequence could lose updates when another thread OR-ed a new flag between the load and the reset. That made history resync requests randomly disappear, especially under fast GUI actions such as toggles or consecutive parameter commits.
Definition at line 1527 of file dev_pixelpipe.c.
References _get_debug_pipe_name(), _refresh_pipe_detail_mask_state(), _seal_opencl_cache_policy(), _sync_focused_in_place(), dt_dev_pixelpipe_t::bypass_blendif, dt_dev_pixelpipe_t::changed, dt_dev_pixelpipe_t::dev, dt_atomic_exch_int(), DT_DEBUG_DEV, DT_DEV_DETAIL_MASK_NONE, dt_dev_get_history_hash(), DT_DEV_PIPE_CACHE_REQUEST, DT_DEV_PIPE_REENTRY, DT_DEV_PIPE_REMOVE, DT_DEV_PIPE_SYNCH, DT_DEV_PIPE_TOP_CHANGED, DT_DEV_PIPE_UNCHANGED, DT_DEV_PIPE_ZOOMED, dt_dev_pixelpipe_cleanup_nodes(), dt_dev_pixelpipe_create_nodes(), DT_DEV_PIXELPIPE_DISPLAY_NONE, dt_dev_pixelpipe_get_roi_out(), dt_dev_pixelpipe_propagate_formats(), dt_dev_pixelpipe_set_history_hash(), dt_dev_pixelpipe_sync_no_history(), dt_dev_pixelpipe_synch_all, dt_dev_pixelpipe_synch_top(), dt_free, dt_get_times(), dt_print(), dt_pthread_rwlock_rdlock, dt_pthread_rwlock_unlock, dt_show_times_f(), FALSE, dt_develop_t::history_mutex, dt_dev_pixelpipe_t::iheight, dt_dev_pixelpipe_t::iwidth, dt_dev_pixelpipe_t::mask_display, dt_dev_pixelpipe_t::nodes, dt_dev_pixelpipe_t::processed_height, dt_dev_pixelpipe_t::processed_width, TRUE, type, and dt_dev_pixelpipe_t::want_detail_mask.
Referenced by _resync_pipe_with_history(), _sync_virtual_pipe(), and dt_dev_get_thumbnail_size().
| void dt_dev_pixelpipe_change_zoom_main | ( | struct dt_develop_t * | dev | ) |
Definition at line 468 of file dev_pixelpipe.c.
References darktable, dt_atomic_set_int(), dt_control_navigation_redraw(), dt_dev_pixelpipe_set_realtime(), dt_dev_pixelpipe_update_zoom_main, dt_dev_update_mouse_effect_radius(), dt_ui_center(), FALSE, darktable_t::gui, dt_develop_t::gui_attached, IS_NULL_PTR, dt_develop_t::pipe, dt_dev_pixelpipe_t::shutdown, TRUE, and dt_gui_gtk_t::ui.
Referenced by _change_scaling(), _darkroom_edge_pan_apply(), _key_scroll(), _lib_navigation_set_position(), _toggle_side_borders_accel_callback(), _tree_selection_change(), _zoom_preset_change(), display_borders_callback(), dt_masks_center_view_on_form(), full_screen_callback(), and mouse_moved().
| const struct dt_dev_pixelpipe_iop_t * dt_dev_pixelpipe_get_module_piece | ( | const struct dt_dev_pixelpipe_t * | pipe, |
| const struct dt_iop_module_t * | module | ||
| ) |
Return the enabled piece owned by module in pipe.
GUI-side cache readers must resolve the current live piece from the current pipe graph every time they sample. Piece pointers are not stable across history resyncs or pipe rebuilds, so callers should never persist them.
| pipe | Current pipe graph. |
| module | Module instance to look up. |
module, or NULL if none exists in the current pipe graph. | const struct dt_dev_pixelpipe_iop_t * dt_dev_pixelpipe_get_prev_enabled_piece | ( | const struct dt_dev_pixelpipe_t * | pipe, |
| const struct dt_dev_pixelpipe_iop_t * | piece | ||
| ) |
Return the closest enabled piece located immediately before piece in pipe.
Cache readers that need the input buffer of one module must reopen the previous enabled module output, not simply the previous list node, because disabled pieces keep their place in pipe->nodes while not producing any cacheline. This utility keeps that rule centralized at the pixelpipe level.
| pipe | Current pipe graph. |
| piece | Reference piece inside pipe. |
piece is the first enabled node or if either input is invalid. | void dt_dev_pixelpipe_get_roi_in | ( | struct dt_dev_pixelpipe_t * | pipe, |
| const struct dt_iop_roi_t | roi_out | ||
| ) |
Definition at line 550 of file dev_pixelpipe.c.
References _get_debug_pipe_name(), dt_iop_buffer_dsc_t::channels, dt_iop_buffer_dsc_t::cst, darktable, dt_dev_pixelpipe_iop_t::data, dt_dev_pixelpipe_t::dev, dt_image_t::dsc, dt_dev_pixelpipe_iop_t::dsc_in, dt_dev_pixelpipe_iop_t::dsc_out, DT_DEBUG_PIPE, dt_dev_pixelpipe_activemodule_disables_currentmodule(), dt_free, dt_print(), dt_dev_pixelpipe_iop_t::enabled, FALSE, dt_iop_buffer_dsc_t::filters, dt_iop_roi_t::height, dt_develop_t::image_storage, IOP_CS_RAW, dt_dev_pixelpipe_t::nodes, dt_dev_pixelpipe_iop_t::roi_in, dt_dev_pixelpipe_iop_t::roi_out, dt_iop_roi_t::scale, darktable_t::unmuted, dt_iop_roi_t::width, dt_iop_roi_t::x, dt_iop_buffer_dsc_t::xtrans, and dt_iop_roi_t::y.
Referenced by _resync_pipe_with_history(), and dt_dev_pixelpipe_process().
| void dt_dev_pixelpipe_get_roi_out | ( | struct dt_dev_pixelpipe_t * | pipe, |
| const int | width_in, | ||
| const int | height_in, | ||
| int * | width, | ||
| int * | height | ||
| ) |
Definition at line 502 of file dev_pixelpipe.c.
References _get_debug_pipe_name(), dt_dev_pixelpipe_iop_t::buf_in, dt_dev_pixelpipe_iop_t::buf_out, darktable, dt_dev_pixelpipe_iop_t::data, dt_dev_pixelpipe_t::dev, DT_DEBUG_PIPE, dt_dev_pixelpipe_activemodule_disables_currentmodule(), dt_free, dt_print(), dt_dev_pixelpipe_iop_t::enabled, FALSE, height, dt_iop_roi_t::height, dt_dev_pixelpipe_t::nodes, dt_iop_roi_t::scale, darktable_t::unmuted, width, dt_iop_roi_t::width, dt_iop_roi_t::x, and dt_iop_roi_t::y.
Referenced by _lib_snapshots_refresh_pipe_image(), dt_dev_get_thumbnail_size(), dt_dev_pixelpipe_change(), dt_focus_draw_clusters(), and dt_imageio_export_with_flags().
| gboolean dt_dev_pixelpipe_is_backbufer_valid | ( | struct dt_dev_pixelpipe_t * | pipe | ) |
Definition at line 1660 of file dev_pixelpipe.c.
References dt_dev_pixelpipe_t::backbuf, dt_dev_pixelpipe_t::dev, dt_dev_backbuf_get_hash(), dt_dev_backbuf_get_history_hash(), dt_dev_get_history_hash(), dt_dev_pixelpipe_get_hash(), and DT_PIXELPIPE_CACHE_HASH_INVALID.
Referenced by _lib_navigation_draw_callback(), and dt_dev_darkroom_pipeline().
| gboolean dt_dev_pixelpipe_is_pipeline_valid | ( | struct dt_dev_pixelpipe_t * | pipe | ) |
Definition at line 1668 of file dev_pixelpipe.c.
References dt_dev_pixelpipe_t::dev, dt_dev_get_history_hash(), and dt_dev_pixelpipe_get_history_hash().
| uint64_t dt_dev_pixelpipe_node_hash | ( | struct dt_dev_pixelpipe_t * | pipe, |
| const struct dt_dev_pixelpipe_iop_t * | piece, | ||
| const struct dt_iop_roi_t | , | ||
| const int | pos | ||
| ) |
| void dt_dev_pixelpipe_propagate_formats | ( | struct dt_dev_pixelpipe_t * | pipe | ) |
Definition at line 1076 of file dev_pixelpipe.c.
References _dsc_cst_name(), _get_debug_pipe_name(), dt_dev_pixelpipe_iop_t::blendop_hash, dt_iop_buffer_dsc_t::bpp, dt_iop_buffer_dsc_t::channels, dt_iop_buffer_dsc_t::cst, darktable, dt_dev_pixelpipe_iop_t::data, dt_dev_pixelpipe_t::dev, dt_image_t::dsc, dt_dev_pixelpipe_iop_t::dsc_in, dt_dev_pixelpipe_iop_t::dsc_out, dt_control_log(), DT_DEBUG_PIPE, dt_free, dt_iop_buffer_dsc_update_bpp(), DT_PIXELPIPE_CACHE_HASH_INVALID, dt_print(), dt_dev_pixelpipe_iop_t::enabled, FALSE, dt_iop_buffer_dsc_t::filters, dt_dev_pixelpipe_iop_t::global_hash, dt_dev_pixelpipe_iop_t::global_mask_hash, dt_dev_pixelpipe_iop_t::hash, dt_develop_t::image_storage, IS_NULL_PTR, dt_dev_pixelpipe_t::nodes, and darktable_t::unmuted.
Referenced by _lib_snapshots_refresh_pipe_image(), _sync_focused_in_place(), dt_dev_pixelpipe_change(), and dt_imageio_export_with_flags().
| void dt_dev_pixelpipe_rebuild_all_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 391 of file dev_pixelpipe.c.
References _change_pipe(), _sync_virtual_pipe(), DT_DEV_PIPE_REMOVE, dt_develop_t::gui_attached, IS_NULL_PTR, dt_develop_t::pipe, and dt_develop_t::preview_pipe.
| void dt_dev_pixelpipe_reset_all | ( | struct dt_develop_t * | dev | ) |
Definition at line 461 of file dev_pixelpipe.c.
References darktable, dt_dev_pixelpipe_cache_flush(), dt_dev_pixelpipe_rebuild_all, darktable_t::gui, dt_develop_t::gui_attached, IS_NULL_PTR, darktable_t::pixelpipe_cache, and dt_gui_gtk_t::reset.
Referenced by clear_caches_callback().
| void dt_dev_pixelpipe_resync_history_all_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 413 of file dev_pixelpipe.c.
References dt_dev_pixelpipe_resync_history_main, dt_dev_pixelpipe_resync_history_preview, dt_develop_t::gui_attached, and IS_NULL_PTR.
| void dt_dev_pixelpipe_resync_history_main_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 399 of file dev_pixelpipe.c.
References _change_pipe(), DT_DEV_PIPE_SYNCH, dt_develop_t::gui_attached, IS_NULL_PTR, and dt_develop_t::pipe.
| void dt_dev_pixelpipe_resync_history_preview_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 405 of file dev_pixelpipe.c.
References _change_pipe(), _sync_virtual_pipe(), DT_DEV_PIPE_SYNCH, dt_develop_t::gui_attached, IS_NULL_PTR, and dt_develop_t::preview_pipe.
| void dt_dev_pixelpipe_sync_virtual | ( | struct dt_develop_t * | dev, |
| dt_dev_pixelpipe_change_t | flag | ||
| ) |
Definition at line 1655 of file dev_pixelpipe.c.
References _sync_virtual_pipe(), and flag.
Referenced by _enter_edit_mode(), do_crop(), gui_post_expose(), and gui_post_expose().
| void dt_dev_pixelpipe_update_history_all_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 434 of file dev_pixelpipe.c.
References dt_dev_pixelpipe_update_history_main, dt_dev_pixelpipe_update_history_preview, dt_develop_t::gui_attached, and IS_NULL_PTR.
| void dt_dev_pixelpipe_update_history_main_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 420 of file dev_pixelpipe.c.
References _change_pipe(), DT_DEV_PIPE_TOP_CHANGED, dt_develop_t::gui_attached, IS_NULL_PTR, and dt_develop_t::pipe.
| void dt_dev_pixelpipe_update_history_preview_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 426 of file dev_pixelpipe.c.
References _change_pipe(), _sync_virtual_pipe(), DT_DEV_PIPE_TOP_CHANGED, dt_develop_t::gui_attached, IS_NULL_PTR, and dt_develop_t::preview_pipe.
| void dt_dev_pixelpipe_update_zoom_main_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 449 of file dev_pixelpipe.c.
References _change_pipe(), _sync_virtual_pipe(), DT_DEV_PIPE_ZOOMED, dt_dev_pixelpipe_set_realtime(), FALSE, dt_develop_t::gui_attached, IS_NULL_PTR, and dt_develop_t::pipe.
| void dt_dev_pixelpipe_update_zoom_preview_real | ( | struct dt_develop_t * | dev | ) |
Definition at line 441 of file dev_pixelpipe.c.
References _change_pipe(), _sync_virtual_pipe(), DT_DEV_PIPE_ZOOMED, dt_develop_t::gui_attached, IS_NULL_PTR, and dt_develop_t::preview_pipe.
| void dt_pixelpipe_get_global_hash | ( | struct dt_dev_pixelpipe_t * | pipe | ) |
Definition at line 1295 of file dev_pixelpipe.c.
References _default_pipe_hash(), _get_debug_pipe_name(), dt_dev_pixelpipe_iop_t::blendop_hash, dt_iop_buffer_dsc_t::bpp, dt_dev_pixelpipe_iop_t::bypass_cache, dt_dev_pixelpipe_t::bypass_cache, darktable, dt_dev_pixelpipe_iop_t::data, dt_dev_pixelpipe_t::dev, dt_dev_pixelpipe_iop_t::dsc_in, dt_dev_pixelpipe_iop_t::dsc_out, dt_atomic_get_int(), DT_DEBUG_PIPE, DT_DEBUG_VERBOSE, dt_dev_pixelpipe_activemodule_disables_currentmodule(), DT_DEV_PIXELPIPE_DISPLAY_NONE, DT_DEV_PIXELPIPE_FULL, dt_dev_pixelpipe_set_hash(), dt_free, dt_hash(), dt_print(), dt_dev_pixelpipe_iop_t::enabled, FALSE, dt_dev_pixelpipe_iop_t::global_hash, dt_dev_pixelpipe_iop_t::global_mask_hash, dt_develop_t::gui_attached, dt_develop_t::gui_module, dt_dev_pixelpipe_iop_t::hash, IOP_TAG_DISTORT, dt_develop_t::mask_preview_settings_revision, dt_dev_pixelpipe_t::nodes, dt_dev_pixelpipe_iop_t::roi_in, dt_dev_pixelpipe_iop_t::roi_out, TRUE, type, dt_dev_pixelpipe_t::type, and darktable_t::unmuted.
Referenced by _resync_pipe_with_history(), _sync_focused_in_place(), and dt_dev_pixelpipe_process().