Build Packages / Unit tests (push) Successful in 1h31m59s
Build Packages / build:rpm (rocky8_nocuda) (push) Successful in 8m43s
Build Packages / build:rpm (rocky9_nocuda) (push) Successful in 10m5s
Build Packages / build:rpm (ubuntu2204_nocuda) (push) Successful in 9m27s
Build Packages / build:rpm (ubuntu2404_nocuda) (push) Successful in 8m56s
Build Packages / build:rpm (rocky8_sls9) (push) Successful in 9m24s
Build Packages / build:rpm (rocky9_sls9) (push) Successful in 10m27s
Build Packages / build:rpm (rocky8) (push) Successful in 9m20s
Build Packages / build:rpm (rocky9) (push) Successful in 10m50s
Build Packages / build:rpm (ubuntu2204) (push) Successful in 9m54s
Build Packages / build:rpm (ubuntu2404) (push) Successful in 8m38s
Build Packages / DIALS test (push) Successful in 12m13s
Build Packages / XDS test (durin plugin) (push) Successful in 7m8s
Build Packages / XDS test (JFJoch plugin) (push) Successful in 7m8s
Build Packages / XDS test (neggia plugin) (push) Successful in 7m50s
Build Packages / Generate python client (push) Successful in 16s
Build Packages / Build documentation (push) Successful in 50s
Build Packages / Create release (push) Skipped
This is an UNSTABLE release. It includes many experimental features, as well as many AI generated fixes. We recommend using rc.152 for production use. * jfjoch_broker: Add EXPERIMENTAL pixelrefine mode for image processing * jfjoch_broker: Allow to load user mask from 8-bit and 16-bit TIFF files * jfjoch_broker: Add ROI calculation in non-FPGA workflow * jfjoch_broker: Fixes to TCP image pusher * jfjoch_broker: Remove NUMA bindings * jfjoch_broker: Improvements to indexing * jfjoch_broker: For PSI EIGER, trimming energies are taken from the detector configuration (now compulsory) instead of hardcoded values * jfjoch_writer: Save ROI definitions and the per-pixel ROI bitmap in the master file; azimuthal ROIs support phi (angular) sectors * jfjoch_viewer: Major redesign with dockable panels and saved layouts, plus on-canvas creation/move/resize of box, circle and azimuthal ROIs * jfjoch_viewer: Run jfjoch_process reprocessing jobs from inside the GUI and overlay per-run results Reviewed-on: #63
94 lines
2.6 KiB
C
94 lines
2.6 KiB
C
/*
|
|
* IOchain - Distribute a chain of dependent IO events among threads.
|
|
*
|
|
* This file is part of Bitshuffle
|
|
* Author: Kiyoshi Masui <kiyo@physics.ubc.ca>
|
|
* Website: https://www.github.com/kiyo-masui/bitshuffle
|
|
* Created: 2014
|
|
*
|
|
* See LICENSE file for details about copyright and rights to use.
|
|
*
|
|
*
|
|
* Header File
|
|
*
|
|
* Similar in concept to a queue. Each task includes reading an input
|
|
* and writing output, but the location of the input/output (the pointers)
|
|
* depend on the previous item in the chain.
|
|
*
|
|
* This is designed for parallelizing blocked compression/decompression IO,
|
|
* where the destination of a compressed block depends on the compressed size
|
|
* of all previous blocks.
|
|
*
|
|
* Implemented with OpenMP locks.
|
|
*
|
|
*
|
|
* Usage
|
|
* -----
|
|
* - Call `ioc_init` in serial block.
|
|
* - Each thread should create a local variable *size_t this_iter* and
|
|
* pass its address to all function calls. Its value will be set
|
|
* inside the functions and is used to identify the thread.
|
|
* - Each thread must call each of the `ioc_get*` and `ioc_set*` methods
|
|
* exactly once per iteration, starting with `ioc_get_in` and ending
|
|
* with `ioc_set_next_out`.
|
|
* - The order (`ioc_get_in`, `ioc_set_next_in`, *work*, `ioc_get_out`,
|
|
* `ioc_set_next_out`, *work*) is most efficient.
|
|
* - Have each thread call `ioc_end_pop`.
|
|
* - `ioc_get_in` is blocked until the previous entry's
|
|
* `ioc_set_next_in` is called.
|
|
* - `ioc_get_out` is blocked until the previous entry's
|
|
* `ioc_set_next_out` is called.
|
|
* - There are no blocks on the very first iteration.
|
|
* - Call `ioc_destroy` in serial block.
|
|
* - Safe for num_threads >= IOC_SIZE (but less efficient).
|
|
*
|
|
*/
|
|
|
|
|
|
#ifndef IOCHAIN_H
|
|
#define IOCHAIN_H
|
|
|
|
|
|
#include <stdlib.h>
|
|
#ifdef _OPENMP
|
|
#include <omp.h>
|
|
#endif
|
|
|
|
|
|
#define IOC_SIZE 33
|
|
|
|
|
|
typedef struct ioc_ptr_and_lock {
|
|
#ifdef _OPENMP
|
|
omp_lock_t lock;
|
|
#endif
|
|
void *ptr;
|
|
} ptr_and_lock;
|
|
|
|
typedef struct ioc_const_ptr_and_lock {
|
|
#ifdef _OPENMP
|
|
omp_lock_t lock;
|
|
#endif
|
|
const void *ptr;
|
|
} const_ptr_and_lock;
|
|
|
|
|
|
typedef struct ioc_chain {
|
|
#ifdef _OPENMP
|
|
omp_lock_t next_lock;
|
|
#endif
|
|
size_t next;
|
|
const_ptr_and_lock in_pl[IOC_SIZE];
|
|
ptr_and_lock out_pl[IOC_SIZE];
|
|
} ioc_chain;
|
|
|
|
|
|
void ioc_init(ioc_chain *C, const void *in_ptr_0, void *out_ptr_0);
|
|
void ioc_destroy(ioc_chain *C);
|
|
const void * ioc_get_in(ioc_chain *C, size_t *this_iter);
|
|
void ioc_set_next_in(ioc_chain *C, size_t* this_iter, void* in_ptr);
|
|
void * ioc_get_out(ioc_chain *C, size_t *this_iter);
|
|
void ioc_set_next_out(ioc_chain *C, size_t *this_iter, void* out_ptr);
|
|
|
|
#endif // IOCHAIN_H
|