mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
sys: introduce iolist
This commit is contained in:
parent
b343ff8ac9
commit
dbbdf3f664
87
sys/include/iolist.h
Normal file
87
sys/include/iolist.h
Normal file
@ -0,0 +1,87 @@
|
||||
/*
|
||||
* Copyright (C) 2018 Kaspar Schleiser <kaspar@schleiser.de>
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @defgroup sys_util_iolist iolist scatter / gather IO
|
||||
* @ingroup sys_util
|
||||
* @brief Provides linked-list scatter / gather IO
|
||||
*
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief iolist scatter / gather IO
|
||||
*
|
||||
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
||||
*/
|
||||
|
||||
#ifndef IOLIST_H
|
||||
#define IOLIST_H
|
||||
|
||||
#include <unistd.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/** @brief iolist forward declaration */
|
||||
typedef struct iolist iolist_t;
|
||||
|
||||
/**
|
||||
* @brief iolist structure definition
|
||||
*/
|
||||
struct iolist {
|
||||
iolist_t *iol_next; /**< ptr to next list entry */
|
||||
void *iol_base; /**< ptr to this list entries data */
|
||||
size_t iol_len; /**< size of data pointet to by ptr */
|
||||
};
|
||||
|
||||
/**
|
||||
* @brief Count number of entries in an iolist_t
|
||||
*
|
||||
* @param[in] iolist iolist to count
|
||||
*
|
||||
* @returns number of entries (zero for NULL parameter)
|
||||
*/
|
||||
unsigned iolist_count(const iolist_t *iolist);
|
||||
|
||||
/**
|
||||
* @brief Sum up number of bytes in iolist
|
||||
*
|
||||
* This function returns the summed ip lenght values of all entries in @p
|
||||
* iolist.
|
||||
*
|
||||
* @param[in] iolist iolist to sum up
|
||||
*
|
||||
* @returns summed up number of bytes or zero if @p iolist == NULL
|
||||
*/
|
||||
size_t iolist_size(const iolist_t *iolist);
|
||||
|
||||
/** @brief struct iovec anonymous declaration */
|
||||
struct iovec;
|
||||
|
||||
/**
|
||||
* @brief Create struct iovec from iolist
|
||||
*
|
||||
* This function fills an array of struct iovecs with the contents of @p
|
||||
* iolist. It will write the number of used array entries into @p count.
|
||||
*
|
||||
* The caller *must* ensure that @p iov p points to an array of size >= count!
|
||||
*
|
||||
* @param[in] iolist iolist to read from
|
||||
* @param[out] iov ptr to array of struct iovec that will be filled
|
||||
* @param[out] count number of elements in @p iolist
|
||||
*
|
||||
* @returns iolist_size(iolist)
|
||||
*/
|
||||
size_t iolist_to_iovec(const iolist_t *iolist, struct iovec *iov, unsigned *count);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
#endif /* IOLIST_H */
|
||||
/** @} */
|
1
sys/iolist/Makefile
Normal file
1
sys/iolist/Makefile
Normal file
@ -0,0 +1 @@
|
||||
include $(RIOTBASE)/Makefile.base
|
61
sys/iolist/iolist.c
Normal file
61
sys/iolist/iolist.c
Normal file
@ -0,0 +1,61 @@
|
||||
/*
|
||||
* Copyright (C) 2018 Kaspar Schleiser <kaspar@schleiser.de>
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @ingroup sys_util
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief iolist scatter / gather IO
|
||||
*
|
||||
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
||||
* @}
|
||||
*/
|
||||
|
||||
#include <sys/uio.h>
|
||||
|
||||
#include "iolist.h"
|
||||
|
||||
unsigned iolist_count(const iolist_t *iolist)
|
||||
{
|
||||
unsigned count = 0;
|
||||
while (iolist) {
|
||||
count++;
|
||||
iolist = iolist->iol_next;
|
||||
}
|
||||
return count;
|
||||
}
|
||||
|
||||
size_t iolist_size(const iolist_t *iolist)
|
||||
{
|
||||
size_t result = 0;
|
||||
while (iolist) {
|
||||
result += iolist->iol_len;
|
||||
iolist = iolist->iol_next;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
size_t iolist_to_iovec(const iolist_t *iolist, struct iovec *iov, unsigned *count)
|
||||
{
|
||||
size_t bytes = 0;
|
||||
unsigned _count = 0;
|
||||
|
||||
while (iolist) {
|
||||
iov->iov_base = iolist->iol_base;
|
||||
iov->iov_len = iolist->iol_len;
|
||||
bytes += iov->iov_len;
|
||||
_count++;
|
||||
iolist = iolist->iol_next;
|
||||
iov++;
|
||||
}
|
||||
|
||||
*count = _count;
|
||||
|
||||
return bytes;
|
||||
}
|
Loading…
Reference in New Issue
Block a user