source: mainline/common/adt/circ_buf.c@ cde067e

Last change on this file since cde067e was ad9178bf, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 20 months ago

Deduplicate ADT

  • Property mode set to 100644
File size: 3.2 KB
RevLine 
[7a6065c]1/*
2 * Copyright (c) 2017 Jiri Svoboda
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup libc
30 * @{
31 */
[a35b458]32
[7a6065c]33/** @file Circular buffer
34 */
35
36#include <adt/circ_buf.h>
37#include <errno.h>
38#include <mem.h>
39#include <stddef.h>
40
41/** Initialize circular buffer.
42 *
43 * @param cbuf Circular buffer
44 * @param buf Buffer for storing data
45 * @param nmemb Number of entries in @a buf
46 * @param size Size of individual buffer entry
47 */
48void circ_buf_init(circ_buf_t *cbuf, void *buf, size_t nmemb, size_t size)
49{
50 cbuf->buf = buf;
51 cbuf->nmemb = nmemb;
52 cbuf->size = size;
53 cbuf->rp = 0;
54 cbuf->wp = 0;
55 cbuf->nused = 0;
56}
57
58/** Return number of free buffer entries.
59 *
60 * @param cbuf Circular buffer
61 * @return Number of free buffer entries
62 */
63size_t circ_buf_nfree(circ_buf_t *cbuf)
64{
65 return cbuf->nmemb - cbuf->nused;
66}
67
68/** Return number of used buffer entries.
69 *
70 * @param cbuf Circular buffer
71 * @return Number of used buffer entries
72 */
73size_t circ_buf_nused(circ_buf_t *cbuf)
74{
75 return cbuf->nused;
76}
77
78/** Push new entry into circular buffer.
79 *
80 * @param cbuf Circular buffer
81 * @param data Pointer to entry data
82 * @return EOK on success, EAGAIN if circular buffer is full
83 */
[b7fd2a0]84errno_t circ_buf_push(circ_buf_t *cbuf, const void *data)
[7a6065c]85{
86 if (circ_buf_nfree(cbuf) == 0)
87 return EAGAIN;
88
89 memcpy(cbuf->buf + cbuf->size * cbuf->wp, data, cbuf->size);
90 cbuf->wp = (cbuf->wp + 1) % cbuf->nmemb;
91 cbuf->nused++;
92 return EOK;
93}
94
95/** Pop entry from circular buffer.
96 *
97 * @param cbuf Circular buffer
98 * @param datab Pointer to data buffer for storing entry
99 * @return EOK on success, EAGAIN if circular buffer is full
100 */
[b7fd2a0]101errno_t circ_buf_pop(circ_buf_t *cbuf, void *datab)
[7a6065c]102{
103 if (cbuf->nused == 0)
104 return EAGAIN;
105
106 memcpy(datab, cbuf->buf + cbuf->size * cbuf->rp, cbuf->size);
107 cbuf->rp = (cbuf->rp + 1) % cbuf->nmemb;
108 cbuf->nused--;
109 return EOK;
110}
111
112/** @}
113 */
Note: See TracBrowser for help on using the repository browser.