1/* 2 * nghttp3 3 * 4 * Copyright (c) 2022 nghttp3 contributors 5 * Copyright (c) 2022 ngtcp2 contributors 6 * 7 * Permission is hereby granted, free of charge, to any person obtaining 8 * a copy of this software and associated documentation files (the 9 * "Software"), to deal in the Software without restriction, including 10 * without limitation the rights to use, copy, modify, merge, publish, 11 * distribute, sublicense, and/or sell copies of the Software, and to 12 * permit persons to whom the Software is furnished to do so, subject to 13 * the following conditions: 14 * 15 * The above copyright notice and this permission notice shall be 16 * included in all copies or substantial portions of the Software. 17 * 18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 19 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 21 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE 22 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION 23 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION 24 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 25 */ 26#ifndef NGHTTP3_BALLOC_H 27#define NGHTTP3_BALLOC_H 28 29#ifdef HAVE_CONFIG_H 30# include <config.h> 31#endif /* HAVE_CONFIG_H */ 32 33#include <nghttp3/nghttp3.h> 34 35#include "nghttp3_buf.h" 36 37typedef struct nghttp3_memblock_hd nghttp3_memblock_hd; 38 39/* 40 * nghttp3_memblock_hd is the header of memory block. 41 */ 42struct nghttp3_memblock_hd { 43 nghttp3_memblock_hd *next; 44}; 45 46/* 47 * nghttp3_balloc is a custom memory allocator. It allocates |blklen| 48 * bytes of memory at once on demand, and returns its slice when the 49 * allocation is requested. 50 */ 51typedef struct nghttp3_balloc { 52 /* mem is the underlying memory allocator. */ 53 const nghttp3_mem *mem; 54 /* blklen is the size of memory block. */ 55 size_t blklen; 56 /* head points to the list of memory block allocated so far. */ 57 nghttp3_memblock_hd *head; 58 /* buf wraps the current memory block for allocation requests. */ 59 nghttp3_buf buf; 60} nghttp3_balloc; 61 62/* 63 * nghttp3_balloc_init initializes |balloc| with |blklen| which is the 64 * size of memory block. 65 */ 66void nghttp3_balloc_init(nghttp3_balloc *balloc, size_t blklen, 67 const nghttp3_mem *mem); 68 69/* 70 * nghttp3_balloc_free releases all allocated memory blocks. 71 */ 72void nghttp3_balloc_free(nghttp3_balloc *balloc); 73 74/* 75 * nghttp3_balloc_get allocates |n| bytes of memory and assigns its 76 * pointer to |*pbuf|. 77 * 78 * It returns 0 if it succeeds, or one of the following negative error 79 * codes: 80 * 81 * NGHTTP3_ERR_NOMEM 82 * Out of memory. 83 */ 84int nghttp3_balloc_get(nghttp3_balloc *balloc, void **pbuf, size_t n); 85 86/* 87 * nghttp3_balloc_clear releases all allocated memory blocks and 88 * initializes its state. 89 */ 90void nghttp3_balloc_clear(nghttp3_balloc *balloc); 91 92#endif /* NGHTTP3_BALLOC_H */ 93