Statistics
| Branch: | Revision:

root / qemu-malloc.c @ 7ffa4767

History | View | Annotate | Download (2.1 kB)

1 17e2377a pbrook
/*
2 17e2377a pbrook
 * malloc-like functions for system emulation.
3 17e2377a pbrook
 *
4 17e2377a pbrook
 * Copyright (c) 2006 Fabrice Bellard
5 17e2377a pbrook
 *
6 17e2377a pbrook
 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 17e2377a pbrook
 * of this software and associated documentation files (the "Software"), to deal
8 17e2377a pbrook
 * in the Software without restriction, including without limitation the rights
9 17e2377a pbrook
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 17e2377a pbrook
 * copies of the Software, and to permit persons to whom the Software is
11 17e2377a pbrook
 * furnished to do so, subject to the following conditions:
12 17e2377a pbrook
 *
13 17e2377a pbrook
 * The above copyright notice and this permission notice shall be included in
14 17e2377a pbrook
 * all copies or substantial portions of the Software.
15 17e2377a pbrook
 *
16 17e2377a pbrook
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 17e2377a pbrook
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 17e2377a pbrook
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 17e2377a pbrook
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 17e2377a pbrook
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 17e2377a pbrook
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22 17e2377a pbrook
 * THE SOFTWARE.
23 17e2377a pbrook
 */
24 17e2377a pbrook
#include "qemu-common.h"
25 8a1d02ab aliguori
#include <stdlib.h>
26 8a1d02ab aliguori
27 8a1d02ab aliguori
static void *oom_check(void *ptr)
28 8a1d02ab aliguori
{
29 8a1d02ab aliguori
    if (ptr == NULL)
30 62a3fe29 aliguori
        abort();
31 8a1d02ab aliguori
    return ptr;
32 8a1d02ab aliguori
}
33 17e2377a pbrook
34 17e2377a pbrook
void *get_mmap_addr(unsigned long size)
35 17e2377a pbrook
{
36 17e2377a pbrook
    return NULL;
37 17e2377a pbrook
}
38 17e2377a pbrook
39 17e2377a pbrook
void qemu_free(void *ptr)
40 17e2377a pbrook
{
41 17e2377a pbrook
    free(ptr);
42 17e2377a pbrook
}
43 17e2377a pbrook
44 17e2377a pbrook
void *qemu_malloc(size_t size)
45 17e2377a pbrook
{
46 8a1d02ab aliguori
    return oom_check(malloc(size));
47 17e2377a pbrook
}
48 17e2377a pbrook
49 2137b4cc ths
void *qemu_realloc(void *ptr, size_t size)
50 2137b4cc ths
{
51 322691a5 aliguori
    if (size)
52 322691a5 aliguori
        return oom_check(realloc(ptr, size));
53 322691a5 aliguori
    else
54 322691a5 aliguori
        return realloc(ptr, size);
55 2137b4cc ths
}
56 2137b4cc ths
57 17e2377a pbrook
void *qemu_mallocz(size_t size)
58 17e2377a pbrook
{
59 17e2377a pbrook
    void *ptr;
60 17e2377a pbrook
    ptr = qemu_malloc(size);
61 17e2377a pbrook
    memset(ptr, 0, size);
62 17e2377a pbrook
    return ptr;
63 17e2377a pbrook
}
64 17e2377a pbrook
65 17e2377a pbrook
char *qemu_strdup(const char *str)
66 17e2377a pbrook
{
67 17e2377a pbrook
    char *ptr;
68 363a37d5 blueswir1
    size_t len = strlen(str);
69 363a37d5 blueswir1
    ptr = qemu_malloc(len + 1);
70 ac4b0d0c balrog
    memcpy(ptr, str, len + 1);
71 17e2377a pbrook
    return ptr;
72 17e2377a pbrook
}
73 ac4b0d0c balrog
74 ac4b0d0c balrog
char *qemu_strndup(const char *str, size_t size)
75 ac4b0d0c balrog
{
76 ac4b0d0c balrog
    const char *end = memchr(str, 0, size);
77 ac4b0d0c balrog
    char *new;
78 ac4b0d0c balrog
79 ac4b0d0c balrog
    if (end)
80 ac4b0d0c balrog
        size = end - str;
81 ac4b0d0c balrog
82 ac4b0d0c balrog
    new = qemu_malloc(size + 1);
83 ac4b0d0c balrog
    new[size] = 0;
84 ac4b0d0c balrog
85 ac4b0d0c balrog
    return memcpy(new, str, size);
86 ac4b0d0c balrog
}