1303095Ssobomax/* 2303095Ssobomax * Copyright (c) 2016 Maxim Sobolev <sobomax@FreeBSD.org> 3303095Ssobomax * All rights reserved. 4303095Ssobomax * 5303095Ssobomax * Redistribution and use in source and binary forms, with or without 6303095Ssobomax * modification, are permitted provided that the following conditions 7303095Ssobomax * are met: 8303095Ssobomax * 1. Redistributions of source code must retain the above copyright 9303095Ssobomax * notice, this list of conditions and the following disclaimer. 10303095Ssobomax * 2. Redistributions in binary form must reproduce the above copyright 11303095Ssobomax * notice, this list of conditions and the following disclaimer in the 12303095Ssobomax * documentation and/or other materials provided with the distribution. 13303095Ssobomax * 14303095Ssobomax * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15303095Ssobomax * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16303095Ssobomax * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17303095Ssobomax * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18303095Ssobomax * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19303095Ssobomax * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20303095Ssobomax * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21303095Ssobomax * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22303095Ssobomax * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23303095Ssobomax * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24303095Ssobomax * SUCH DAMAGE. 25303095Ssobomax * 26303095Ssobomax * $FreeBSD$ 27303095Ssobomax */ 28303095Ssobomax 29303095Ssobomaxstruct mkuz_fifo_queue; 30303095Ssobomax 31303095Ssobomax#define ITEMS_PER_WORKER 4 32303095Ssobomax 33303095Ssobomax#define MAX_WORKERS_AUTO 24 34303095Ssobomax 35303095Ssobomaxstruct mkuz_conveyor { 36303095Ssobomax /* 37303095Ssobomax * Work items are places in here, and picked up by workers in a FIFO 38303095Ssobomax * fashion. 39303095Ssobomax */ 40303095Ssobomax struct mkuz_fifo_queue *wrk_queue; 41303095Ssobomax /* 42303095Ssobomax * Results are dropped into this FIFO and consumer is buzzed to pick them 43303095Ssobomax * up 44303095Ssobomax */ 45303095Ssobomax struct mkuz_fifo_queue *results; 46303095Ssobomax 47303095Ssobomax pthread_t wthreads[]; 48303095Ssobomax}; 49303095Ssobomax 50303095Ssobomaxstruct mkuz_cfg; 51303095Ssobomax 52303095Ssobomaxstruct mkuz_conveyor *mkuz_conveyor_ctor(struct mkuz_cfg *); 53