/src/libxml2/include/private/memory.h
Line | Count | Source |
1 | | #ifndef XML_MEMORY_H_PRIVATE__ |
2 | | #define XML_MEMORY_H_PRIVATE__ |
3 | | |
4 | | #include "../../libxml.h" |
5 | | |
6 | | #include <limits.h> |
7 | | #include <stddef.h> |
8 | | |
9 | | #ifndef SIZE_MAX |
10 | | #define SIZE_MAX ((size_t) -1) |
11 | | #endif |
12 | | |
13 | 828k | #define XML_MAX_ITEMS 1000000000 /* 1 billion */ |
14 | | |
15 | | XML_HIDDEN void |
16 | | xmlInitMemoryInternal(void); |
17 | | XML_HIDDEN void |
18 | | xmlCleanupMemoryInternal(void); |
19 | | |
20 | | /** |
21 | | * @array: pointer to array |
22 | | * @capacity: pointer to capacity (in/out) |
23 | | * @elemSize: size of an element in bytes |
24 | | * @min: elements in initial allocation |
25 | | * @max: maximum elements in the array |
26 | | * |
27 | | * Grow an array by at least one element, checking for overflow. |
28 | | * |
29 | | * Returns the new array size on success, -1 on failure. |
30 | | */ |
31 | | static XML_INLINE int |
32 | 654k | xmlGrowCapacity(int capacity, size_t elemSize, int min, int max) { |
33 | 654k | int extra; |
34 | | |
35 | 654k | if (capacity <= 0) { |
36 | 140k | #ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION |
37 | 140k | (void) min; |
38 | 140k | return(1); |
39 | | #else |
40 | | return(min); |
41 | | #endif |
42 | 140k | } |
43 | | |
44 | 514k | if ((capacity >= max) || |
45 | 513k | ((size_t) capacity > SIZE_MAX / 2 / elemSize)) |
46 | 615 | return(-1); |
47 | | |
48 | | /* Grow by 50% */ |
49 | 513k | extra = (capacity + 1) / 2; |
50 | | |
51 | 513k | if (capacity > max - extra) |
52 | 635 | return(max); |
53 | | |
54 | 513k | return(capacity + extra); |
55 | 513k | } Line | Count | Source | 32 | 419k | xmlGrowCapacity(int capacity, size_t elemSize, int min, int max) { | 33 | 419k | int extra; | 34 | | | 35 | 419k | if (capacity <= 0) { | 36 | 49.6k | #ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION | 37 | 49.6k | (void) min; | 38 | 49.6k | return(1); | 39 | | #else | 40 | | return(min); | 41 | | #endif | 42 | 49.6k | } | 43 | | | 44 | 370k | if ((capacity >= max) || | 45 | 369k | ((size_t) capacity > SIZE_MAX / 2 / elemSize)) | 46 | 615 | return(-1); | 47 | | | 48 | | /* Grow by 50% */ | 49 | 369k | extra = (capacity + 1) / 2; | 50 | | | 51 | 369k | if (capacity > max - extra) | 52 | 635 | return(max); | 53 | | | 54 | 368k | return(capacity + extra); | 55 | 369k | } |
Unexecuted instantiation: parserInternals.c:xmlGrowCapacity Unexecuted instantiation: threads.c:xmlGrowCapacity Line | Count | Source | 32 | 66.8k | xmlGrowCapacity(int capacity, size_t elemSize, int min, int max) { | 33 | 66.8k | int extra; | 34 | | | 35 | 66.8k | if (capacity <= 0) { | 36 | 28.3k | #ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION | 37 | 28.3k | (void) min; | 38 | 28.3k | return(1); | 39 | | #else | 40 | | return(min); | 41 | | #endif | 42 | 28.3k | } | 43 | | | 44 | 38.4k | if ((capacity >= max) || | 45 | 38.4k | ((size_t) capacity > SIZE_MAX / 2 / elemSize)) | 46 | 0 | return(-1); | 47 | | | 48 | | /* Grow by 50% */ | 49 | 38.4k | extra = (capacity + 1) / 2; | 50 | | | 51 | 38.4k | if (capacity > max - extra) | 52 | 0 | return(max); | 53 | | | 54 | 38.4k | return(capacity + extra); | 55 | 38.4k | } |
Line | Count | Source | 32 | 21.9k | xmlGrowCapacity(int capacity, size_t elemSize, int min, int max) { | 33 | 21.9k | int extra; | 34 | | | 35 | 21.9k | if (capacity <= 0) { | 36 | 0 | #ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION | 37 | 0 | (void) min; | 38 | 0 | return(1); | 39 | | #else | 40 | | return(min); | 41 | | #endif | 42 | 0 | } | 43 | | | 44 | 21.9k | if ((capacity >= max) || | 45 | 21.9k | ((size_t) capacity > SIZE_MAX / 2 / elemSize)) | 46 | 0 | return(-1); | 47 | | | 48 | | /* Grow by 50% */ | 49 | 21.9k | extra = (capacity + 1) / 2; | 50 | | | 51 | 21.9k | if (capacity > max - extra) | 52 | 0 | return(max); | 53 | | | 54 | 21.9k | return(capacity + extra); | 55 | 21.9k | } |
Line | Count | Source | 32 | 929 | xmlGrowCapacity(int capacity, size_t elemSize, int min, int max) { | 33 | 929 | int extra; | 34 | | | 35 | 929 | if (capacity <= 0) { | 36 | 696 | #ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION | 37 | 696 | (void) min; | 38 | 696 | return(1); | 39 | | #else | 40 | | return(min); | 41 | | #endif | 42 | 696 | } | 43 | | | 44 | 233 | if ((capacity >= max) || | 45 | 233 | ((size_t) capacity > SIZE_MAX / 2 / elemSize)) | 46 | 0 | return(-1); | 47 | | | 48 | | /* Grow by 50% */ | 49 | 233 | extra = (capacity + 1) / 2; | 50 | | | 51 | 233 | if (capacity > max - extra) | 52 | 0 | return(max); | 53 | | | 54 | 233 | return(capacity + extra); | 55 | 233 | } |
Unexecuted instantiation: xmlmemory.c:xmlGrowCapacity Unexecuted instantiation: catalog.c:xmlGrowCapacity Unexecuted instantiation: HTMLparser.c:xmlGrowCapacity xmlregexp.c:xmlGrowCapacity Line | Count | Source | 32 | 145k | xmlGrowCapacity(int capacity, size_t elemSize, int min, int max) { | 33 | 145k | int extra; | 34 | | | 35 | 145k | if (capacity <= 0) { | 36 | 61.9k | #ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION | 37 | 61.9k | (void) min; | 38 | 61.9k | return(1); | 39 | | #else | 40 | | return(min); | 41 | | #endif | 42 | 61.9k | } | 43 | | | 44 | 83.5k | if ((capacity >= max) || | 45 | 83.5k | ((size_t) capacity > SIZE_MAX / 2 / elemSize)) | 46 | 0 | return(-1); | 47 | | | 48 | | /* Grow by 50% */ | 49 | 83.5k | extra = (capacity + 1) / 2; | 50 | | | 51 | 83.5k | if (capacity > max - extra) | 52 | 0 | return(max); | 53 | | | 54 | 83.5k | return(capacity + extra); | 55 | 83.5k | } |
Unexecuted instantiation: xmlschemas.c:xmlGrowCapacity Unexecuted instantiation: xpath.c:xmlGrowCapacity Unexecuted instantiation: encoding.c:xmlGrowCapacity Unexecuted instantiation: pattern.c:xmlGrowCapacity Unexecuted instantiation: xmlreader.c:xmlGrowCapacity Unexecuted instantiation: xinclude.c:xmlGrowCapacity |
56 | | |
57 | | #endif /* XML_MEMORY_H_PRIVATE__ */ |