source: mainline/uspace/lib/c/generic/adt/circ_buf.c@ 3061bc1

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 3061bc1 was b7fd2a0, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 7 years ago

Use errno_t in all uspace and kernel code.

Change type of every variable, parameter and return value that holds an
<errno.h> constant to either errno_t (the usual case), or sys_errno_t
(some places in kernel). This is for the purpose of self-documentation,
as well as for type-checking with a bit of type definition hackery.

Although this is a massive commit, it is a simple text replacement, and thus
is very easy to verify. Simply do the following:

`
git checkout <this commit's hash>
git reset HEAD
git add .
tools/srepl '\berrno_t\b' int
git add .
tools/srepl '\bsys_errno_t\b' sysarg_t
git reset
git diff
`

While this doesn't ensure that the replacements are correct, it does ensure
that the commit doesn't do anything except those replacements. Since errno_t
is typedef'd to int in the usual case (and sys_errno_t to sysarg_t), even if
incorrect, this commit cannot change behavior.

  • Property mode set to 100644
File size: 3.2 KB
Line 
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 */
32
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 */
84errno_t circ_buf_push(circ_buf_t *cbuf, const void *data)
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 */
101errno_t circ_buf_pop(circ_buf_t *cbuf, void *datab)
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.