Commit | Line | Data |
---|---|---|
294d3396 MD |
1 | /* |
2 | * wfstack.c | |
3 | * | |
edac6b69 | 4 | * Userspace RCU library - Stack with wait-free push, blocking traversal. |
294d3396 | 5 | * |
f4b7d3c9 | 6 | * Copyright 2010-2012 - Mathieu Desnoyers <mathieu.desnoyers@efficios.com> |
294d3396 MD |
7 | * |
8 | * This library is free software; you can redistribute it and/or | |
9 | * modify it under the terms of the GNU Lesser General Public | |
10 | * License as published by the Free Software Foundation; either | |
11 | * version 2.1 of the License, or (at your option) any later version. | |
12 | * | |
13 | * This library is distributed in the hope that it will be useful, | |
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
16 | * Lesser General Public License for more details. | |
17 | * | |
18 | * You should have received a copy of the GNU Lesser General Public | |
19 | * License along with this library; if not, write to the Free Software | |
20 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
21 | */ | |
22 | ||
23 | /* Do not #define _LGPL_SOURCE to ensure we can emit the wrapper symbols */ | |
24 | #include "urcu/wfstack.h" | |
af7c2dbe | 25 | #include "urcu/static/wfstack.h" |
294d3396 | 26 | |
eaf2c3f4 MD |
27 | /* |
28 | * library wrappers to be used by non-LGPL compatible source code. | |
29 | */ | |
30 | ||
16aa9ee8 | 31 | void cds_wfs_node_init(struct cds_wfs_node *node) |
294d3396 | 32 | { |
16aa9ee8 | 33 | _cds_wfs_node_init(node); |
294d3396 MD |
34 | } |
35 | ||
16aa9ee8 | 36 | void cds_wfs_init(struct cds_wfs_stack *s) |
294d3396 | 37 | { |
16aa9ee8 | 38 | _cds_wfs_init(s); |
294d3396 MD |
39 | } |
40 | ||
718eb63e EW |
41 | void __cds_wfs_init(struct __cds_wfs_stack *s) |
42 | { | |
43 | ___cds_wfs_init(s); | |
44 | } | |
45 | ||
711ff0f9 | 46 | bool cds_wfs_empty(cds_wfs_stack_ptr_t u_stack) |
edac6b69 | 47 | { |
711ff0f9 | 48 | return _cds_wfs_empty(u_stack); |
edac6b69 MD |
49 | } |
50 | ||
711ff0f9 | 51 | int cds_wfs_push(cds_wfs_stack_ptr_t u_stack, struct cds_wfs_node *node) |
294d3396 | 52 | { |
711ff0f9 | 53 | return _cds_wfs_push(u_stack, node); |
294d3396 MD |
54 | } |
55 | ||
edac6b69 MD |
56 | struct cds_wfs_node *cds_wfs_pop_blocking(struct cds_wfs_stack *s) |
57 | { | |
58 | return _cds_wfs_pop_blocking(s); | |
59 | } | |
60 | ||
c8975b94 MD |
61 | struct cds_wfs_node * |
62 | cds_wfs_pop_with_state_blocking(struct cds_wfs_stack *s, int *state) | |
63 | { | |
64 | return _cds_wfs_pop_with_state_blocking(s, state); | |
65 | } | |
66 | ||
edac6b69 MD |
67 | struct cds_wfs_head *cds_wfs_pop_all_blocking(struct cds_wfs_stack *s) |
68 | { | |
69 | return _cds_wfs_pop_all_blocking(s); | |
70 | } | |
71 | ||
c7ba06ba | 72 | struct cds_wfs_node *cds_wfs_first(struct cds_wfs_head *head) |
edac6b69 | 73 | { |
c7ba06ba | 74 | return _cds_wfs_first(head); |
edac6b69 MD |
75 | } |
76 | ||
77 | struct cds_wfs_node *cds_wfs_next_blocking(struct cds_wfs_node *node) | |
78 | { | |
79 | return _cds_wfs_next_blocking(node); | |
80 | } | |
81 | ||
af67624d MD |
82 | struct cds_wfs_node *cds_wfs_next_nonblocking(struct cds_wfs_node *node) |
83 | { | |
84 | return _cds_wfs_next_nonblocking(node); | |
85 | } | |
86 | ||
edac6b69 MD |
87 | void cds_wfs_pop_lock(struct cds_wfs_stack *s) |
88 | { | |
89 | _cds_wfs_pop_lock(s); | |
90 | } | |
91 | ||
92 | void cds_wfs_pop_unlock(struct cds_wfs_stack *s) | |
93 | { | |
94 | _cds_wfs_pop_unlock(s); | |
95 | } | |
96 | ||
711ff0f9 | 97 | struct cds_wfs_node *__cds_wfs_pop_blocking(cds_wfs_stack_ptr_t u_stack) |
294d3396 | 98 | { |
711ff0f9 | 99 | return ___cds_wfs_pop_blocking(u_stack); |
294d3396 MD |
100 | } |
101 | ||
c8975b94 | 102 | struct cds_wfs_node * |
711ff0f9 MD |
103 | __cds_wfs_pop_with_state_blocking(cds_wfs_stack_ptr_t u_stack, |
104 | int *state) | |
c8975b94 | 105 | { |
711ff0f9 | 106 | return ___cds_wfs_pop_with_state_blocking(u_stack, state); |
c8975b94 MD |
107 | } |
108 | ||
711ff0f9 | 109 | struct cds_wfs_node *__cds_wfs_pop_nonblocking(cds_wfs_stack_ptr_t u_stack) |
af67624d | 110 | { |
711ff0f9 | 111 | return ___cds_wfs_pop_nonblocking(u_stack); |
af67624d MD |
112 | } |
113 | ||
c8975b94 | 114 | struct cds_wfs_node * |
711ff0f9 | 115 | __cds_wfs_pop_with_state_nonblocking(cds_wfs_stack_ptr_t u_stack, |
c8975b94 MD |
116 | int *state) |
117 | { | |
711ff0f9 | 118 | return ___cds_wfs_pop_with_state_nonblocking(u_stack, state); |
c8975b94 MD |
119 | } |
120 | ||
718eb63e | 121 | struct cds_wfs_head *__cds_wfs_pop_all(cds_wfs_stack_ptr_t u_stack) |
294d3396 | 122 | { |
718eb63e | 123 | return ___cds_wfs_pop_all(u_stack); |
294d3396 | 124 | } |