e5fcad3 by Lars Knoll at 2009-03-23 1
/****************************************************************************
2
**
89c08c0 by Jason McDonald at 2012-01-11 3
** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
04e3b30 by Jason McDonald at 2009-09-09 4
** All rights reserved.
858c70f by Jason McDonald at 2009-06-16 5
** Contact: Nokia Corporation (qt-info@nokia.com)
e5fcad3 by Lars Knoll at 2009-03-23 6
**
7
** This file is part of the QtCore module of the Qt Toolkit.
8
**
9
** $QT_BEGIN_LICENSE:LGPL$
10
** GNU Lesser General Public License Usage
1eea52e by Jyri Tahtela at 2011-05-13 11
** This file may be used under the terms of the GNU Lesser General Public
12
** License version 2.1 as published by the Free Software Foundation and
13
** appearing in the file LICENSE.LGPL included in the packaging of this
14
** file. Please review the following information to ensure the GNU Lesser
15
** General Public License version 2.1 requirements will be met:
16
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
e5fcad3 by Lars Knoll at 2009-03-23 17
**
04e3b30 by Jason McDonald at 2009-09-09 18
** In addition, as a special exception, Nokia gives you certain additional
1eea52e by Jyri Tahtela at 2011-05-13 19
** rights. These rights are described in the Nokia Qt LGPL Exception
04e3b30 by Jason McDonald at 2009-09-09 20
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
e5fcad3 by Lars Knoll at 2009-03-23 21
**
1eea52e by Jyri Tahtela at 2011-05-13 22
** GNU General Public License Usage
23
** Alternatively, this file may be used under the terms of the GNU General
24
** Public License version 3.0 as published by the Free Software Foundation
25
** and appearing in the file LICENSE.GPL included in the packaging of this
26
** file. Please review the following information to ensure the GNU General
27
** Public License version 3.0 requirements will be met:
28
** http://www.gnu.org/copyleft/gpl.html.
29
**
30
** Other Usage
31
** Alternatively, this file may be used in accordance with the terms and
32
** conditions contained in a signed written agreement between you and Nokia.
309db73 by Jason McDonald at 2009-08-31 33
**
34
**
35
**
36
**
e5fcad3 by Lars Knoll at 2009-03-23 37
**
38
** $QT_END_LICENSE$
39
**
40
****************************************************************************/
41
42
#include "qplatformdefs.h"
43
44
#include <stdlib.h>
ffe49ed by Thiago Macieira at 2009-10-29 45
e5fcad3 by Lars Knoll at 2009-03-23 46
/*
47
    Define the container allocation functions in a separate file, so that our
48
    users can easily override them.
49
*/
50
51
QT_BEGIN_NAMESPACE
52
53
void *qMalloc(size_t size)
54
{
55
    return ::malloc(size);
56
}
57
58
void qFree(void *ptr)
59
{
60
    ::free(ptr);
61
}
62
63
void *qRealloc(void *ptr, size_t size)
64
{
65
    return ::realloc(ptr, size);
66
}
67
3f0b969 by Thiago Macieira at 2009-10-28 68
void *qMallocAligned(size_t size, size_t alignment)
69
{
70
    return qReallocAligned(0, size, 0, alignment);
71
}
72
73
void *qReallocAligned(void *oldptr, size_t newsize, size_t oldsize, size_t alignment)
74
{
75
    // fake an aligned allocation
76
    Q_UNUSED(oldsize);
77
78
    void *actualptr = oldptr ? static_cast<void **>(oldptr)[-1] : 0;
79
    if (alignment <= sizeof(void*)) {
80
        // special, fast case
81
        void **newptr = static_cast<void **>(qRealloc(actualptr, newsize + sizeof(void*)));
82
        if (!newptr)
83
            return 0;
84
        if (newptr == actualptr) {
85
            // realloc succeeded without reallocating
86
            return oldptr;
87
        }
88
89
        *newptr = newptr;
90
        return newptr + 1;
91
    }
92
93
    // qMalloc returns pointers aligned at least at sizeof(size_t) boundaries
94
    // but usually more (8- or 16-byte boundaries).
95
    // So we overallocate by alignment-sizeof(size_t) bytes, so we're guaranteed to find a
96
    // somewhere within the first alignment-sizeof(size_t) that is properly aligned.
97
98
    // However, we need to store the actual pointer, so we need to allocate actually size +
99
    // alignment anyway.
100
fb94cee by Olivier Goffart at 2010-10-29 101
    void *real = qRealloc(actualptr, newsize + alignment);
102
    if (!real)
3f0b969 by Thiago Macieira at 2009-10-28 103
        return 0;
104
fb94cee by Olivier Goffart at 2010-10-29 105
    quintptr faked = reinterpret_cast<quintptr>(real) + alignment;
106
    faked &= ~(alignment - 1);
107
108
    void **faked_ptr = reinterpret_cast<void **>(faked);
3f0b969 by Thiago Macieira at 2009-10-28 109
110
    // now save the value of the real pointer at faked-sizeof(void*)
111
    // by construction, alignment > sizeof(void*) and is a power of 2, so
112
    // faked-sizeof(void*) is properly aligned for a pointer
fb94cee by Olivier Goffart at 2010-10-29 113
    faked_ptr[-1] = real;
3f0b969 by Thiago Macieira at 2009-10-28 114
fb94cee by Olivier Goffart at 2010-10-29 115
    return faked_ptr;
3f0b969 by Thiago Macieira at 2009-10-28 116
}
117
118
void qFreeAligned(void *ptr)
119
{
120
    if (!ptr)
121
        return;
122
    void **ptr2 = static_cast<void **>(ptr);
123
    free(ptr2[-1]);
124
}
125
e5fcad3 by Lars Knoll at 2009-03-23 126
QT_END_NAMESPACE
bc7dca6 by Wolfgang Beck at 2010-02-16 127