wfcqueue: implement mutex-free splice
[urcu.git] / wfcqueue.c
CommitLineData
8ad4ce58
MD
1/*
2 * wfcqueue.c
3 *
f878b49e 4 * Userspace RCU library - Concurrent Queue with Wait-Free Enqueue/Blocking Dequeue
8ad4ce58
MD
5 *
6 * Copyright 2010-2012 - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
7 * Copyright 2011-2012 - Lai Jiangshan <laijs@cn.fujitsu.com>
8 *
9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public
11 * License as published by the Free Software Foundation; either
12 * version 2.1 of the License, or (at your option) any later version.
13 *
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Lesser General Public License for more details.
18 *
19 * You should have received a copy of the GNU Lesser General Public
20 * License along with this library; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 */
23
24/* Do not #define _LGPL_SOURCE to ensure we can emit the wrapper symbols */
25#include "urcu/wfcqueue.h"
26#include "urcu/static/wfcqueue.h"
27
28/*
29 * library wrappers to be used by non-LGPL compatible source code.
30 */
31
32void cds_wfcq_node_init(struct cds_wfcq_node *node)
33{
34 _cds_wfcq_node_init(node);
35}
36
37void cds_wfcq_init(struct cds_wfcq_head *head,
38 struct cds_wfcq_tail *tail)
39{
40 _cds_wfcq_init(head, tail);
41}
42
43bool cds_wfcq_empty(struct cds_wfcq_head *head,
44 struct cds_wfcq_tail *tail)
45
46{
47 return _cds_wfcq_empty(head, tail);
48}
49
23773356 50bool cds_wfcq_enqueue(struct cds_wfcq_head *head,
8ad4ce58
MD
51 struct cds_wfcq_tail *tail,
52 struct cds_wfcq_node *node)
53{
23773356 54 return _cds_wfcq_enqueue(head, tail, node);
8ad4ce58
MD
55}
56
57void cds_wfcq_dequeue_lock(struct cds_wfcq_head *head,
58 struct cds_wfcq_tail *tail)
59{
852a17ad 60 _cds_wfcq_dequeue_lock(head, tail);
8ad4ce58
MD
61}
62
63void cds_wfcq_dequeue_unlock(struct cds_wfcq_head *head,
64 struct cds_wfcq_tail *tail)
65{
852a17ad 66 _cds_wfcq_dequeue_unlock(head, tail);
8ad4ce58
MD
67}
68
69struct cds_wfcq_node *cds_wfcq_dequeue_blocking(
70 struct cds_wfcq_head *head,
71 struct cds_wfcq_tail *tail)
72{
73 return _cds_wfcq_dequeue_blocking(head, tail);
74}
75
23773356 76enum cds_wfcq_ret cds_wfcq_splice_blocking(
8ad4ce58
MD
77 struct cds_wfcq_head *dest_q_head,
78 struct cds_wfcq_tail *dest_q_tail,
79 struct cds_wfcq_head *src_q_head,
80 struct cds_wfcq_tail *src_q_tail)
81{
23773356 82 return _cds_wfcq_splice_blocking(dest_q_head, dest_q_tail,
8ad4ce58
MD
83 src_q_head, src_q_tail);
84}
85
86struct cds_wfcq_node *__cds_wfcq_dequeue_blocking(
87 struct cds_wfcq_head *head,
88 struct cds_wfcq_tail *tail)
89{
90 return ___cds_wfcq_dequeue_blocking(head, tail);
91}
92
47215721
MD
93struct cds_wfcq_node *__cds_wfcq_dequeue_nonblocking(
94 struct cds_wfcq_head *head,
95 struct cds_wfcq_tail *tail)
96{
97 return ___cds_wfcq_dequeue_nonblocking(head, tail);
98}
99
23773356 100enum cds_wfcq_ret __cds_wfcq_splice_blocking(
8ad4ce58
MD
101 struct cds_wfcq_head *dest_q_head,
102 struct cds_wfcq_tail *dest_q_tail,
103 struct cds_wfcq_head *src_q_head,
104 struct cds_wfcq_tail *src_q_tail)
105{
23773356 106 return ___cds_wfcq_splice_blocking(dest_q_head, dest_q_tail,
8ad4ce58
MD
107 src_q_head, src_q_tail);
108}
109
23773356 110enum cds_wfcq_ret __cds_wfcq_splice_nonblocking(
47215721
MD
111 struct cds_wfcq_head *dest_q_head,
112 struct cds_wfcq_tail *dest_q_tail,
113 struct cds_wfcq_head *src_q_head,
114 struct cds_wfcq_tail *src_q_tail)
115{
116 return ___cds_wfcq_splice_nonblocking(dest_q_head, dest_q_tail,
117 src_q_head, src_q_tail);
118}
119
8ad4ce58
MD
120struct cds_wfcq_node *__cds_wfcq_first_blocking(
121 struct cds_wfcq_head *head,
122 struct cds_wfcq_tail *tail)
123{
124 return ___cds_wfcq_first_blocking(head, tail);
125}
126
47215721
MD
127struct cds_wfcq_node *__cds_wfcq_first_nonblocking(
128 struct cds_wfcq_head *head,
129 struct cds_wfcq_tail *tail)
130{
131 return ___cds_wfcq_first_nonblocking(head, tail);
132}
133
8ad4ce58
MD
134struct cds_wfcq_node *__cds_wfcq_next_blocking(
135 struct cds_wfcq_head *head,
136 struct cds_wfcq_tail *tail,
137 struct cds_wfcq_node *node)
138{
139 return ___cds_wfcq_next_blocking(head, tail, node);
140}
47215721
MD
141
142struct cds_wfcq_node *__cds_wfcq_next_nonblocking(
143 struct cds_wfcq_head *head,
144 struct cds_wfcq_tail *tail,
145 struct cds_wfcq_node *node)
146{
147 return ___cds_wfcq_next_nonblocking(head, tail, node);
148}
This page took 0.028436 seconds and 4 git commands to generate.