/* * include/haproxy/buf-t.h * Simple buffer handling - types definitions. * * Copyright (C) 2000-2020 Willy Tarreau - w@1wt.eu * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. */ #ifndef _HAPROXY_BUF_T_H #define _HAPROXY_BUF_T_H #include /* Structure defining a buffer's head */ struct buffer { size_t size; /* buffer size in bytes */ char *area; /* points to bytes */ size_t data; /* amount of data after head including wrapping */ size_t head; /* start offset of remaining data relative to area */ }; /* A buffer may be in 3 different states : * - unallocated : size == 0, area == 0 (b_is_null() is true) * - waiting : size == 0, area != 0 (b_is_null() is true) * - allocated : size > 0, area > 0 (b_is_null() is false) */ /* initializers for certain buffer states. It is important that the NULL buffer * remains the one with all fields initialized to zero so that a calloc() or a * memset() on a struct automatically sets a NULL buffer. */ #define BUF_NULL ((struct buffer){ }) #define BUF_WANTED ((struct buffer){ .area = (char *)1 }) #define BUF_RING ((struct buffer){ .area = (char *)2 }) /* An element of a buffer list (bl_*). They're all stored in an array. The * holder contains a pointer to that array and a count. The first element * (index zero) builds the free list and may never be used. All owners simply * have a head and a tail index pointing to their own list. In order to ease * initialization, for each allocatable cell, next==0 indicates that all * following cells till the end of the array are free. The end of a list is * marked by next==~0. For the head, next is always valid or is zero when no * more entries are available. The struct element doesn't have holes. It's 24 * bytes in 32 bits and 40 bytes in 64 bits, so offsets are trivially obtained * from indexes. The pointer may be split into two 16 bits fields if * needed in order to make room for something else later, since we don't * expect to make 64k-buffer arrays. The first element's buf stores size, * allocated space and number of users. */ struct bl_elem { struct buffer buf; uint32_t next; uint32_t flags; }; #endif /* _HAPROXY_BUF_T_H */ /* * Local variables: * c-indent-level: 8 * c-basic-offset: 8 * End: */