File: syncque.h

package info (click to toggle)
osptoolkit 4.13.0-1.1
  • links: PTS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,376 kB
  • sloc: ansic: 42,300; makefile: 265; sh: 49
file content (65 lines) | stat: -rw-r--r-- 2,699 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/**************************************************************************
*** COPYRIGHT (c) 2002 by TransNexus, Inc.                              ***
***                                                                     ***
*** This software is property of TransNexus, Inc.                       ***
*** This software is freely available under license from TransNexus.    ***
*** The license terms and conditions for free use of this software by   ***
*** third parties are defined in the OSP Toolkit Software License       ***
*** Agreement (LICENSE.txt).  Any use of this software by third         ***
*** parties, which does not comply with the terms and conditions of the ***
*** OSP Toolkit Software License Agreement is prohibited without        ***
*** the prior, express, written consent of TransNexus, Inc.             ***
***                                                                     ***
*** Thank you for using the OSP ToolKit(TM).  Please report any bugs,   ***
*** suggestions or feedback to support@transnexus.com                   ***
***                                                                     ***
**************************************************************************/

/*
 *  syncque.h - Structures and prototypes for sync queue object.
 *
 *  This module implements a MT Safe Queue.  It provides a non-blocking
 *  method - SyncQueueAddTransaction - for producers to add transactions
 *  to the queue, and a blocking method - SyncQueueRemoveTransaction -
 *  for consumers to remove transactions from the queue.
 *  SyncQueueBlockWhileNotEmpty - allows the caller to wait while all
 *  transactions have been processed by consumers.
 *
 *  The queue is implemented using a linked list - OSPTLIST.
 *  This implementation assumes that the first member of the transaction
 *  structure is of type OSPTLISTLINK.  This member is used by OSPTLIST
 *  and must not be used by consumers or producers.
 */
#ifndef _SYNCQUE_H
#define _SYNCQUE_H

#include "osp/osp.h"
#include "osp/osplist.h"

/*
 * sync queue typedef
 */
typedef struct _SYNCQUEUE {
    unsigned NumberOfTransactions;
    OSPTMUTEX Mutex;
    OSPTCONDVAR CondVarNotEmpty;
    OSPTCONDVAR CondVarEmpty;
    OSPTLIST PayloadList;
} SYNCQUEUE;

#ifdef __cplusplus
extern "C" {
#endif

    int SyncQueueNew(SYNCQUEUE **);
    void SyncQueueDelete(SYNCQUEUE **);
    unsigned SyncQueueGetNumberOfTransactions(SYNCQUEUE *);
    int SyncQueueBlockWhileNotEmpty(SYNCQUEUE *);
    int SyncQueueAddTransaction(SYNCQUEUE *, void *);       //  non-blocking
    int SyncQueueRemoveTransaction(SYNCQUEUE *, void **);   //  blocks if the queue is emtpy

#ifdef __cplusplus
}
#endif

#endif /* _SYNCQUE_H */