blob: d5172500e787bf5e18df1e300e7ad7559b929617 (
plain)
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
66
67
68
69
70
71
72
|
/*
Copyright (c) 2012 Gluster, Inc. <http://www.gluster.com>
This file is part of GlusterFS.
GlusterFS is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published
by the Free Software Foundation; either version 3 of the License,
or (at your option) any later version.
GlusterFS is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see
<http://www.gnu.org/licenses/>.
*/
#ifndef _CB_H
#define _CB_H
#include "common-utils.h"
#include "logging.h"
#include "mem-types.h"
#define BUFFER_SIZE 10
#define TOTAL_SIZE BUFFER_SIZE + 1
struct _circular_buffer {
struct timeval tv;
void *data;
};
typedef struct _circular_buffer circular_buffer_t;
struct _buffer {
unsigned int w_index;
size_t size_buffer;
gf_boolean_t use_once;
/* This variable is assigned the proper value at the time of initing */
/* the buffer. It indicates, whether the buffer should be used once */
/* it becomes full. */
int used_len;
/* indicates the amount of circular buffer used. */
circular_buffer_t **cb;
pthread_mutex_t lock;
};
typedef struct _buffer buffer_t;
int
cb_add_entry_buffer (buffer_t *buffer, void *item);
void
cb_buffer_show (buffer_t *buffer);
buffer_t *
cb_buffer_new (size_t buffer_size,gf_boolean_t use_buffer_once);
void
cb_buffer_destroy (buffer_t *buffer);
void
cb_buffer_dump (buffer_t *buffer, void *data,
int (fn) (circular_buffer_t *buffer, void *data));
#endif /* _CB_H */
|