13124c3e0SJohn Polstra /*- 2e6209940SPedro F. Giffuni * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 3e6209940SPedro F. Giffuni * 43124c3e0SJohn Polstra * Copyright 1996-1998 John D. Polstra. 53124c3e0SJohn Polstra * All rights reserved. 63124c3e0SJohn Polstra * 73124c3e0SJohn Polstra * Redistribution and use in source and binary forms, with or without 83124c3e0SJohn Polstra * modification, are permitted provided that the following conditions 93124c3e0SJohn Polstra * are met: 103124c3e0SJohn Polstra * 1. Redistributions of source code must retain the above copyright 113124c3e0SJohn Polstra * notice, this list of conditions and the following disclaimer. 123124c3e0SJohn Polstra * 2. Redistributions in binary form must reproduce the above copyright 133124c3e0SJohn Polstra * notice, this list of conditions and the following disclaimer in the 143124c3e0SJohn Polstra * documentation and/or other materials provided with the distribution. 153124c3e0SJohn Polstra * 163124c3e0SJohn Polstra * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 173124c3e0SJohn Polstra * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 183124c3e0SJohn Polstra * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 193124c3e0SJohn Polstra * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 203124c3e0SJohn Polstra * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 213124c3e0SJohn Polstra * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 223124c3e0SJohn Polstra * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 233124c3e0SJohn Polstra * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 243124c3e0SJohn Polstra * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 253124c3e0SJohn Polstra * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 263124c3e0SJohn Polstra * 277f3dea24SPeter Wemm * $FreeBSD$ 283124c3e0SJohn Polstra */ 293124c3e0SJohn Polstra 303124c3e0SJohn Polstra #include <stddef.h> 313124c3e0SJohn Polstra #include <stdlib.h> 323124c3e0SJohn Polstra #include <string.h> 330e9a2605SKonstantin Belousov #include <unistd.h> 340e9a2605SKonstantin Belousov #include "rtld.h" 350e9a2605SKonstantin Belousov #include "rtld_printf.h" 361a3b2ebfSKonstantin Belousov #include "rtld_malloc.h" 37*b54a59f3SAlex Richardson #include "rtld_libc.h" 383124c3e0SJohn Polstra 393124c3e0SJohn Polstra void * 40758ffbfaSKonstantin Belousov xcalloc(size_t number, size_t size) 413124c3e0SJohn Polstra { 42758ffbfaSKonstantin Belousov void *p; 43758ffbfaSKonstantin Belousov 441a3b2ebfSKonstantin Belousov p = __crt_calloc(number, size); 45758ffbfaSKonstantin Belousov if (p == NULL) { 46758ffbfaSKonstantin Belousov rtld_fdputstr(STDERR_FILENO, "Out of memory\n"); 47758ffbfaSKonstantin Belousov _exit(1); 48758ffbfaSKonstantin Belousov } 49758ffbfaSKonstantin Belousov return (p); 503124c3e0SJohn Polstra } 513124c3e0SJohn Polstra 523124c3e0SJohn Polstra void * 533124c3e0SJohn Polstra xmalloc(size_t size) 543124c3e0SJohn Polstra { 551a3b2ebfSKonstantin Belousov 561a3b2ebfSKonstantin Belousov void *p; 571a3b2ebfSKonstantin Belousov 581a3b2ebfSKonstantin Belousov p = __crt_malloc(size); 590e9a2605SKonstantin Belousov if (p == NULL) { 600e9a2605SKonstantin Belousov rtld_fdputstr(STDERR_FILENO, "Out of memory\n"); 610e9a2605SKonstantin Belousov _exit(1); 620e9a2605SKonstantin Belousov } 631a3b2ebfSKonstantin Belousov return (p); 643124c3e0SJohn Polstra } 653124c3e0SJohn Polstra 663124c3e0SJohn Polstra char * 67f7b34303SKonstantin Belousov xstrdup(const char *str) 683124c3e0SJohn Polstra { 69f7b34303SKonstantin Belousov char *copy; 70f7b34303SKonstantin Belousov size_t len; 71f7b34303SKonstantin Belousov 72f7b34303SKonstantin Belousov len = strlen(str) + 1; 73f7b34303SKonstantin Belousov copy = xmalloc(len); 74f7b34303SKonstantin Belousov memcpy(copy, str, len); 75f7b34303SKonstantin Belousov return (copy); 763124c3e0SJohn Polstra } 77dfe296c4SKonstantin Belousov 78dfe296c4SKonstantin Belousov void * 79dfe296c4SKonstantin Belousov malloc_aligned(size_t size, size_t align) 80dfe296c4SKonstantin Belousov { 81dfe296c4SKonstantin Belousov void *mem, *res; 82dfe296c4SKonstantin Belousov 83eab68f79SDavid Xu if (align < sizeof(void *)) 84eab68f79SDavid Xu align = sizeof(void *); 85209782e0SDavid Xu 86209782e0SDavid Xu mem = xmalloc(size + sizeof(void *) + align - 1); 87209782e0SDavid Xu res = (void *)round((uintptr_t)mem + sizeof(void *), align); 88dfe296c4SKonstantin Belousov *(void **)((uintptr_t)res - sizeof(void *)) = mem; 89dfe296c4SKonstantin Belousov return (res); 90dfe296c4SKonstantin Belousov } 91dfe296c4SKonstantin Belousov 92dfe296c4SKonstantin Belousov void 93dfe296c4SKonstantin Belousov free_aligned(void *ptr) 94dfe296c4SKonstantin Belousov { 95dfe296c4SKonstantin Belousov void *mem; 96dfe296c4SKonstantin Belousov uintptr_t x; 97dfe296c4SKonstantin Belousov 98dfe296c4SKonstantin Belousov if (ptr == NULL) 99dfe296c4SKonstantin Belousov return; 100dfe296c4SKonstantin Belousov x = (uintptr_t)ptr; 101dfe296c4SKonstantin Belousov x -= sizeof(void *); 102dfe296c4SKonstantin Belousov mem = *(void **)x; 103dfe296c4SKonstantin Belousov free(mem); 104dfe296c4SKonstantin Belousov } 105