Motr  M0
varr.h
Go to the documentation of this file.
1 /* -*- C -*- */
2 /*
3  * Copyright (c) 2013-2020 Seagate Technology LLC and/or its Affiliates
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * For any questions about this software or licensing,
18  * please email opensource@seagate.com or cortx-questions@seagate.com.
19  *
20  */
21 
22 
23 #pragma once
24 
25 #ifndef __MOTR_LIB_VIRTUAL_ARRAY_H__
26 #define __MOTR_LIB_VIRTUAL_ARRAY_H__
27 
28 #include "lib/assert.h"
29 #include "lib/misc.h"
30 
90  M0_VA_TNODEPTR_SIZE = sizeof(void *),
95 };
97 
103  uint32_t vp_idx;
104  uint32_t vp_width;
105  void *vp_buf;
106 };
107 
109  struct m0_varr *vc_arr;
110  uint32_t vc_depth;
112  uint64_t vc_done;
119 };
120 
121 struct m0_varr {
123  uint64_t va_nr;
125  uint64_t va_buff_nr;
126  size_t va_obj_size;
128  uint8_t va_obj_shift;
133  size_t va_bufsize;
135  uint8_t va_buf_shift;
136 
138  uint32_t va_depth;
139 
148  uint64_t va_bufptr_nr;
150 
163  uint64_t va_magic;
164 };
165 
176 M0_INTERNAL int m0_varr_init(struct m0_varr *arr, uint64_t nr, size_t size,
177  size_t bufsize);
178 
183 M0_INTERNAL void m0_varr_fini(struct m0_varr *arr);
184 
193 M0_INTERNAL void * m0_varr_ele_get(struct m0_varr *arr, uint64_t index);
194 
196 M0_INTERNAL uint64_t m0_varr_size(const struct m0_varr *arr);
197 
208 M0_INTERNAL int m0_varr_cursor_init(struct m0_varr_cursor *cursor,
209  const struct m0_varr *arr, uint32_t depth);
214 M0_INTERNAL void *m0_varr_cursor_get(struct m0_varr_cursor *cursor);
220 M0_INTERNAL int m0_varr_cursor_next(struct m0_varr_cursor *cursor);
228 M0_INTERNAL int m0_varr_cursor_move(struct m0_varr_cursor *cursor,
229  uint64_t inc);
234 #define m0_varr_iter(arr, type, idx, obj, start, end, inc) \
235 ({ \
236  uint64_t idx = (start); \
237  uint64_t __end = (end); \
238  uint64_t __inc = (inc); \
239  struct m0_varr *__arr = (arr); \
240  type *obj; \
241  int __rc; \
242  struct m0_varr_cursor __cursor; \
243  \
244  M0_PRE(idx < __arr->va_nr && __end <= __arr->va_nr); \
245  M0_PRE(ergo(__arr->va_obj_shift > 0, \
246  sizeof *obj > M0_BITS(__arr->va_obj_shift - 1) && \
247  sizeof *obj <= M0_BITS(__arr->va_obj_shift))); \
248  \
249  __rc = m0_varr_cursor_init(&__cursor, __arr, __arr->va_depth); \
250  M0_ASSERT(__rc == 0); \
251  m0_varr_cursor_move(&__cursor, idx); \
252  for (obj = m0_varr_cursor_get(&__cursor); idx < __end; \
253  idx += __inc, m0_varr_cursor_move(&__cursor, __inc), \
254  obj = m0_varr_cursor_get(&__cursor)) { \
255 
256 #define m0_varr_enditer } } )
257 
259 #define m0_varr_for(arr, type, idx, obj) \
260 ({ \
261  struct m0_varr *__arr__ = (arr); \
262  m0_varr_iter(__arr__, type, idx, obj, 0, m0_varr_size(__arr__), 1)
263 
264 #define m0_varr_endfor m0_varr_enditer; })
265 
267 #endif /* __MOTR_LIB_VIRTUAL_ARRAY_H__ */
268 
269 /*
270  * Local variables:
271  * c-indentation-style: "K&R"
272  * c-basic-offset: 8
273  * tab-width: 8
274  * fill-column: 80
275  * scroll-step: 1
276  * End:
277  */
M0_INTERNAL int m0_varr_cursor_init(struct m0_varr_cursor *cursor, const struct m0_varr *arr, uint32_t depth)
Definition: varr.c:263
static size_t nr
Definition: dump.c:1505
uint64_t va_buff_nr
Definition: varr.h:125
uint64_t vc_done
Definition: varr.h:112
uint32_t vc_depth
Definition: varr.h:110
struct m0_varr * vc_arr
Definition: varr.h:109
void * va_tree[M0_VA_TNODE_NR]
Definition: varr.h:157
struct m0_varr_path_element vc_path[M0_VA_DEPTH_MAX]
Definition: varr.h:118
size_t va_obj_size
Definition: varr.h:126
M0_INTERNAL int m0_varr_cursor_move(struct m0_varr_cursor *cursor, uint64_t inc)
Definition: varr.c:327
#define M0_BITS(...)
Definition: misc.h:236
struct varr_cache * va_cache
Definition: varr.h:159
M0_BASSERT(M0_VA_TNODE_NR==M0_BITS(M0_VA_TNODE_NR_SHIFT))
static unsigned depth
Definition: base.c:377
uint64_t va_bufptr_nr
Definition: varr.h:148
m0_varr_tree_char
Definition: varr.h:86
M0_INTERNAL uint64_t m0_varr_size(const struct m0_varr *arr)
Definition: varr.c:567
uint32_t va_depth
Definition: varr.h:138
M0_INTERNAL void * m0_varr_cursor_get(struct m0_varr_cursor *cursor)
Definition: varr.c:316
uint32_t vp_idx
Definition: varr.h:103
M0_INTERNAL int m0_varr_init(struct m0_varr *arr, uint64_t nr, size_t size, size_t bufsize)
Definition: varr.c:114
M0_INTERNAL int m0_varr_cursor_next(struct m0_varr_cursor *cursor)
Definition: varr.c:322
uint32_t va_failure_depth
Definition: varr.h:161
M0_INTERNAL void m0_varr_fini(struct m0_varr *arr)
Definition: varr.c:486
uint8_t va_buf_shift
Definition: varr.h:135
m0_bcount_t size
Definition: di.c:39
uint8_t va_bufptr_nr_shift
Definition: varr.h:149
uint64_t va_magic
Definition: varr.h:163
uint32_t vp_width
Definition: varr.h:104
Definition: varr.h:121
size_t va_bufsize
Definition: varr.h:133
uint64_t va_nr
Definition: varr.h:123
M0_INTERNAL void * m0_varr_ele_get(struct m0_varr *arr, uint64_t index)
Definition: varr.c:505
uint8_t va_obj_shift
Definition: varr.h:128