Coverage Report

Created: 2025-11-05 06:12

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/quickjs/cutils.h
Line
Count
Source
1
/*
2
 * C utilities
3
 *
4
 * Copyright (c) 2017 Fabrice Bellard
5
 * Copyright (c) 2018 Charlie Gordon
6
 *
7
 * Permission is hereby granted, free of charge, to any person obtaining a copy
8
 * of this software and associated documentation files (the "Software"), to deal
9
 * in the Software without restriction, including without limitation the rights
10
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
 * copies of the Software, and to permit persons to whom the Software is
12
 * furnished to do so, subject to the following conditions:
13
 *
14
 * The above copyright notice and this permission notice shall be included in
15
 * all copies or substantial portions of the Software.
16
 *
17
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
 * THE SOFTWARE.
24
 */
25
#ifndef CUTILS_H
26
#define CUTILS_H
27
28
#include <stdlib.h>
29
#include <string.h>
30
#include <inttypes.h>
31
32
1.06M
#define likely(x)       __builtin_expect(!!(x), 1)
33
10.6M
#define unlikely(x)     __builtin_expect(!!(x), 0)
34
#define force_inline inline __attribute__((always_inline))
35
#define no_inline __attribute__((noinline))
36
#define __maybe_unused __attribute__((unused))
37
38
#define xglue(x, y) x ## y
39
#define glue(x, y) xglue(x, y)
40
#define stringify(s)    tostring(s)
41
#define tostring(s)     #s
42
43
#ifndef offsetof
44
#define offsetof(type, field) ((size_t) &((type *)0)->field)
45
#endif
46
#ifndef countof
47
2.21M
#define countof(x) (sizeof(x) / sizeof((x)[0]))
48
#endif
49
#ifndef container_of
50
/* return the pointer of type 'type *' containing 'ptr' as field 'member' */
51
#define container_of(ptr, type, member) ((type *)((uint8_t *)(ptr) - offsetof(type, member)))
52
#endif
53
54
#if !defined(_MSC_VER) && defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
55
#define minimum_length(n)  static n
56
#else
57
#define minimum_length(n)  n
58
#endif
59
60
typedef int BOOL;
61
62
#ifndef FALSE
63
enum {
64
    FALSE = 0,
65
    TRUE = 1,
66
};
67
#endif
68
69
void pstrcpy(char *buf, int buf_size, const char *str);
70
char *pstrcat(char *buf, int buf_size, const char *s);
71
int strstart(const char *str, const char *val, const char **ptr);
72
int has_suffix(const char *str, const char *suffix);
73
74
/* Prevent UB when n == 0 and (src == NULL or dest == NULL) */
75
82.0k
static inline void memcpy_no_ub(void *dest, const void *src, size_t n) {
76
82.0k
    if (n)
77
82.0k
        memcpy(dest, src, n);
78
82.0k
}
Unexecuted instantiation: libregexp.c:memcpy_no_ub
cutils.c:memcpy_no_ub
Line
Count
Source
75
82.0k
static inline void memcpy_no_ub(void *dest, const void *src, size_t n) {
76
82.0k
    if (n)
77
82.0k
        memcpy(dest, src, n);
78
82.0k
}
Unexecuted instantiation: libunicode.c:memcpy_no_ub
79
80
static inline int max_int(int a, int b)
81
2.79M
{
82
2.79M
    if (a > b)
83
631k
        return a;
84
2.16M
    else
85
2.16M
        return b;
86
2.79M
}
Unexecuted instantiation: libregexp.c:max_int
Unexecuted instantiation: cutils.c:max_int
libunicode.c:max_int
Line
Count
Source
81
2.79M
{
82
2.79M
    if (a > b)
83
631k
        return a;
84
2.16M
    else
85
2.16M
        return b;
86
2.79M
}
87
88
static inline int min_int(int a, int b)
89
0
{
90
0
    if (a < b)
91
0
        return a;
92
0
    else
93
0
        return b;
94
0
}
Unexecuted instantiation: libregexp.c:min_int
Unexecuted instantiation: cutils.c:min_int
Unexecuted instantiation: libunicode.c:min_int
95
96
static inline uint32_t max_uint32(uint32_t a, uint32_t b)
97
0
{
98
0
    if (a > b)
99
0
        return a;
100
0
    else
101
0
        return b;
102
0
}
Unexecuted instantiation: libregexp.c:max_uint32
Unexecuted instantiation: cutils.c:max_uint32
Unexecuted instantiation: libunicode.c:max_uint32
103
104
static inline uint32_t min_uint32(uint32_t a, uint32_t b)
105
0
{
106
0
    if (a < b)
107
0
        return a;
108
0
    else
109
0
        return b;
110
0
}
Unexecuted instantiation: libregexp.c:min_uint32
Unexecuted instantiation: cutils.c:min_uint32
Unexecuted instantiation: libunicode.c:min_uint32
111
112
static inline int64_t max_int64(int64_t a, int64_t b)
113
0
{
114
0
    if (a > b)
115
0
        return a;
116
0
    else
117
0
        return b;
118
0
}
Unexecuted instantiation: libregexp.c:max_int64
Unexecuted instantiation: cutils.c:max_int64
Unexecuted instantiation: libunicode.c:max_int64
119
120
static inline int64_t min_int64(int64_t a, int64_t b)
121
0
{
122
0
    if (a < b)
123
0
        return a;
124
0
    else
125
0
        return b;
126
0
}
Unexecuted instantiation: libregexp.c:min_int64
Unexecuted instantiation: cutils.c:min_int64
Unexecuted instantiation: libunicode.c:min_int64
127
128
/* WARNING: undefined if a = 0 */
129
static inline int clz32(unsigned int a)
130
0
{
131
0
    return __builtin_clz(a);
132
0
}
Unexecuted instantiation: libregexp.c:clz32
Unexecuted instantiation: cutils.c:clz32
Unexecuted instantiation: libunicode.c:clz32
133
134
/* WARNING: undefined if a = 0 */
135
static inline int clz64(uint64_t a)
136
0
{
137
0
    return __builtin_clzll(a);
138
0
}
Unexecuted instantiation: libregexp.c:clz64
Unexecuted instantiation: cutils.c:clz64
Unexecuted instantiation: libunicode.c:clz64
139
140
/* WARNING: undefined if a = 0 */
141
static inline int ctz32(unsigned int a)
142
0
{
143
0
    return __builtin_ctz(a);
144
0
}
Unexecuted instantiation: libregexp.c:ctz32
Unexecuted instantiation: cutils.c:ctz32
Unexecuted instantiation: libunicode.c:ctz32
145
146
/* WARNING: undefined if a = 0 */
147
static inline int ctz64(uint64_t a)
148
0
{
149
0
    return __builtin_ctzll(a);
150
0
}
Unexecuted instantiation: libregexp.c:ctz64
Unexecuted instantiation: cutils.c:ctz64
Unexecuted instantiation: libunicode.c:ctz64
151
152
struct __attribute__((packed)) packed_u64 {
153
    uint64_t v;
154
};
155
156
struct __attribute__((packed)) packed_u32 {
157
    uint32_t v;
158
};
159
160
struct __attribute__((packed)) packed_u16 {
161
    uint16_t v;
162
};
163
164
static inline uint64_t get_u64(const uint8_t *tab)
165
0
{
166
0
    return ((const struct packed_u64 *)tab)->v;
167
0
}
Unexecuted instantiation: libregexp.c:get_u64
Unexecuted instantiation: cutils.c:get_u64
Unexecuted instantiation: libunicode.c:get_u64
168
169
static inline int64_t get_i64(const uint8_t *tab)
170
0
{
171
0
    return (int64_t)((const struct packed_u64 *)tab)->v;
172
0
}
Unexecuted instantiation: libregexp.c:get_i64
Unexecuted instantiation: cutils.c:get_i64
Unexecuted instantiation: libunicode.c:get_i64
173
174
static inline void put_u64(uint8_t *tab, uint64_t val)
175
0
{
176
0
    ((struct packed_u64 *)tab)->v = val;
177
0
}
Unexecuted instantiation: libregexp.c:put_u64
Unexecuted instantiation: cutils.c:put_u64
Unexecuted instantiation: libunicode.c:put_u64
178
179
static inline uint32_t get_u32(const uint8_t *tab)
180
3.50M
{
181
3.50M
    return ((const struct packed_u32 *)tab)->v;
182
3.50M
}
libregexp.c:get_u32
Line
Count
Source
180
3.50M
{
181
3.50M
    return ((const struct packed_u32 *)tab)->v;
182
3.50M
}
Unexecuted instantiation: cutils.c:get_u32
Unexecuted instantiation: libunicode.c:get_u32
183
184
static inline int32_t get_i32(const uint8_t *tab)
185
0
{
186
0
    return (int32_t)((const struct packed_u32 *)tab)->v;
187
0
}
Unexecuted instantiation: libregexp.c:get_i32
Unexecuted instantiation: cutils.c:get_i32
Unexecuted instantiation: libunicode.c:get_i32
188
189
static inline void put_u32(uint8_t *tab, uint32_t val)
190
128k
{
191
128k
    ((struct packed_u32 *)tab)->v = val;
192
128k
}
libregexp.c:put_u32
Line
Count
Source
190
128k
{
191
128k
    ((struct packed_u32 *)tab)->v = val;
192
128k
}
Unexecuted instantiation: cutils.c:put_u32
Unexecuted instantiation: libunicode.c:put_u32
193
194
static inline uint32_t get_u16(const uint8_t *tab)
195
129M
{
196
129M
    return ((const struct packed_u16 *)tab)->v;
197
129M
}
libregexp.c:get_u16
Line
Count
Source
195
129M
{
196
129M
    return ((const struct packed_u16 *)tab)->v;
197
129M
}
Unexecuted instantiation: cutils.c:get_u16
Unexecuted instantiation: libunicode.c:get_u16
198
199
static inline int32_t get_i16(const uint8_t *tab)
200
0
{
201
0
    return (int16_t)((const struct packed_u16 *)tab)->v;
202
0
}
Unexecuted instantiation: libregexp.c:get_i16
Unexecuted instantiation: cutils.c:get_i16
Unexecuted instantiation: libunicode.c:get_i16
203
204
static inline void put_u16(uint8_t *tab, uint16_t val)
205
6.12M
{
206
6.12M
    ((struct packed_u16 *)tab)->v = val;
207
6.12M
}
libregexp.c:put_u16
Line
Count
Source
205
6.12M
{
206
6.12M
    ((struct packed_u16 *)tab)->v = val;
207
6.12M
}
Unexecuted instantiation: cutils.c:put_u16
Unexecuted instantiation: libunicode.c:put_u16
208
209
static inline uint32_t get_u8(const uint8_t *tab)
210
0
{
211
0
    return *tab;
212
0
}
Unexecuted instantiation: libregexp.c:get_u8
Unexecuted instantiation: cutils.c:get_u8
Unexecuted instantiation: libunicode.c:get_u8
213
214
static inline int32_t get_i8(const uint8_t *tab)
215
0
{
216
0
    return (int8_t)*tab;
217
0
}
Unexecuted instantiation: libregexp.c:get_i8
Unexecuted instantiation: cutils.c:get_i8
Unexecuted instantiation: libunicode.c:get_i8
218
219
static inline void put_u8(uint8_t *tab, uint8_t val)
220
0
{
221
0
    *tab = val;
222
0
}
Unexecuted instantiation: libregexp.c:put_u8
Unexecuted instantiation: cutils.c:put_u8
Unexecuted instantiation: libunicode.c:put_u8
223
224
#ifndef bswap16
225
static inline uint16_t bswap16(uint16_t x)
226
0
{
227
0
    return (x >> 8) | (x << 8);
228
0
}
Unexecuted instantiation: libregexp.c:bswap16
Unexecuted instantiation: cutils.c:bswap16
Unexecuted instantiation: libunicode.c:bswap16
229
#endif
230
231
#ifndef bswap32
232
static inline uint32_t bswap32(uint32_t v)
233
0
{
234
0
    return ((v & 0xff000000) >> 24) | ((v & 0x00ff0000) >>  8) |
235
0
        ((v & 0x0000ff00) <<  8) | ((v & 0x000000ff) << 24);
236
0
}
Unexecuted instantiation: libregexp.c:bswap32
Unexecuted instantiation: cutils.c:bswap32
Unexecuted instantiation: libunicode.c:bswap32
237
#endif
238
239
#ifndef bswap64
240
static inline uint64_t bswap64(uint64_t v)
241
0
{
242
0
    return ((v & ((uint64_t)0xff << (7 * 8))) >> (7 * 8)) |
243
0
        ((v & ((uint64_t)0xff << (6 * 8))) >> (5 * 8)) |
244
0
        ((v & ((uint64_t)0xff << (5 * 8))) >> (3 * 8)) |
245
0
        ((v & ((uint64_t)0xff << (4 * 8))) >> (1 * 8)) |
246
0
        ((v & ((uint64_t)0xff << (3 * 8))) << (1 * 8)) |
247
0
        ((v & ((uint64_t)0xff << (2 * 8))) << (3 * 8)) |
248
0
        ((v & ((uint64_t)0xff << (1 * 8))) << (5 * 8)) |
249
0
        ((v & ((uint64_t)0xff << (0 * 8))) << (7 * 8));
250
0
}
Unexecuted instantiation: libregexp.c:bswap64
Unexecuted instantiation: cutils.c:bswap64
Unexecuted instantiation: libunicode.c:bswap64
251
#endif
252
253
/* XXX: should take an extra argument to pass slack information to the caller */
254
typedef void *DynBufReallocFunc(void *opaque, void *ptr, size_t size);
255
256
typedef struct DynBuf {
257
    uint8_t *buf;
258
    size_t size;
259
    size_t allocated_size;
260
    BOOL error; /* true if a memory allocation error occurred */
261
    DynBufReallocFunc *realloc_func;
262
    void *opaque; /* for realloc_func */
263
} DynBuf;
264
265
void dbuf_init(DynBuf *s);
266
void dbuf_init2(DynBuf *s, void *opaque, DynBufReallocFunc *realloc_func);
267
int dbuf_claim(DynBuf *s, size_t len);
268
int dbuf_put(DynBuf *s, const uint8_t *data, size_t len);
269
int dbuf_put_self(DynBuf *s, size_t offset, size_t len);
270
int dbuf_putstr(DynBuf *s, const char *str);
271
int __dbuf_putc(DynBuf *s, uint8_t c);
272
int __dbuf_put_u16(DynBuf *s, uint16_t val);
273
int __dbuf_put_u32(DynBuf *s, uint32_t val);
274
int __dbuf_put_u64(DynBuf *s, uint64_t val);
275
276
static inline int dbuf_putc(DynBuf *s, uint8_t val)
277
999k
{
278
999k
    if (unlikely((s->allocated_size - s->size) < 1)) {
279
63.1k
        return __dbuf_putc(s, val);
280
936k
    } else {
281
936k
        s->buf[s->size++] = val;
282
936k
        return 0;
283
936k
    }
284
999k
}
libregexp.c:dbuf_putc
Line
Count
Source
277
999k
{
278
999k
    if (unlikely((s->allocated_size - s->size) < 1)) {
279
63.1k
        return __dbuf_putc(s, val);
280
936k
    } else {
281
936k
        s->buf[s->size++] = val;
282
936k
        return 0;
283
936k
    }
284
999k
}
Unexecuted instantiation: cutils.c:dbuf_putc
Unexecuted instantiation: libunicode.c:dbuf_putc
285
286
static inline int dbuf_put_u16(DynBuf *s, uint16_t val)
287
6.14M
{
288
6.14M
    if (unlikely((s->allocated_size - s->size) < 2)) {
289
19.5k
        return __dbuf_put_u16(s, val);
290
6.12M
    } else {
291
6.12M
        put_u16(s->buf + s->size, val);
292
6.12M
        s->size += 2;
293
6.12M
        return 0;
294
6.12M
    }
295
6.14M
}
libregexp.c:dbuf_put_u16
Line
Count
Source
287
6.14M
{
288
6.14M
    if (unlikely((s->allocated_size - s->size) < 2)) {
289
19.5k
        return __dbuf_put_u16(s, val);
290
6.12M
    } else {
291
6.12M
        put_u16(s->buf + s->size, val);
292
6.12M
        s->size += 2;
293
6.12M
        return 0;
294
6.12M
    }
295
6.14M
}
Unexecuted instantiation: cutils.c:dbuf_put_u16
Unexecuted instantiation: libunicode.c:dbuf_put_u16
296
297
static inline int dbuf_put_u32(DynBuf *s, uint32_t val)
298
109k
{
299
109k
    if (unlikely((s->allocated_size - s->size) < 4)) {
300
24.5k
        return __dbuf_put_u32(s, val);
301
84.6k
    } else {
302
84.6k
        put_u32(s->buf + s->size, val);
303
84.6k
        s->size += 4;
304
84.6k
        return 0;
305
84.6k
    }
306
109k
}
libregexp.c:dbuf_put_u32
Line
Count
Source
298
109k
{
299
109k
    if (unlikely((s->allocated_size - s->size) < 4)) {
300
24.5k
        return __dbuf_put_u32(s, val);
301
84.6k
    } else {
302
84.6k
        put_u32(s->buf + s->size, val);
303
84.6k
        s->size += 4;
304
84.6k
        return 0;
305
84.6k
    }
306
109k
}
Unexecuted instantiation: cutils.c:dbuf_put_u32
Unexecuted instantiation: libunicode.c:dbuf_put_u32
307
308
static inline int dbuf_put_u64(DynBuf *s, uint64_t val)
309
0
{
310
0
    if (unlikely((s->allocated_size - s->size) < 8)) {
311
0
        return __dbuf_put_u64(s, val);
312
0
    } else {
313
0
        put_u64(s->buf + s->size, val);
314
0
        s->size += 8;
315
0
        return 0;
316
0
    }
317
0
}
Unexecuted instantiation: libregexp.c:dbuf_put_u64
Unexecuted instantiation: cutils.c:dbuf_put_u64
Unexecuted instantiation: libunicode.c:dbuf_put_u64
318
319
int __attribute__((format(printf, 2, 3))) dbuf_printf(DynBuf *s,
320
                                                      const char *fmt, ...);
321
void dbuf_free(DynBuf *s);
322
59.4k
static inline BOOL dbuf_error(DynBuf *s) {
323
59.4k
    return s->error;
324
59.4k
}
libregexp.c:dbuf_error
Line
Count
Source
322
59.4k
static inline BOOL dbuf_error(DynBuf *s) {
323
59.4k
    return s->error;
324
59.4k
}
Unexecuted instantiation: cutils.c:dbuf_error
Unexecuted instantiation: libunicode.c:dbuf_error
325
static inline void dbuf_set_error(DynBuf *s)
326
0
{
327
0
    s->error = TRUE;
328
0
}
Unexecuted instantiation: libregexp.c:dbuf_set_error
Unexecuted instantiation: cutils.c:dbuf_set_error
Unexecuted instantiation: libunicode.c:dbuf_set_error
329
330
57.6k
#define UTF8_CHAR_LEN_MAX 6
331
332
int unicode_to_utf8(uint8_t *buf, unsigned int c);
333
int unicode_from_utf8(const uint8_t *p, int max_len, const uint8_t **pp);
334
335
static inline BOOL is_surrogate(uint32_t c)
336
0
{
337
0
    return (c >> 11) == (0xD800 >> 11); // 0xD800-0xDFFF
338
0
}
Unexecuted instantiation: libregexp.c:is_surrogate
Unexecuted instantiation: cutils.c:is_surrogate
Unexecuted instantiation: libunicode.c:is_surrogate
339
340
static inline BOOL is_hi_surrogate(uint32_t c)
341
12.5k
{
342
12.5k
    return (c >> 10) == (0xD800 >> 10); // 0xD800-0xDBFF
343
12.5k
}
libregexp.c:is_hi_surrogate
Line
Count
Source
341
12.5k
{
342
12.5k
    return (c >> 10) == (0xD800 >> 10); // 0xD800-0xDBFF
343
12.5k
}
Unexecuted instantiation: cutils.c:is_hi_surrogate
Unexecuted instantiation: libunicode.c:is_hi_surrogate
344
345
static inline BOOL is_lo_surrogate(uint32_t c)
346
1.54k
{
347
1.54k
    return (c >> 10) == (0xDC00 >> 10); // 0xDC00-0xDFFF
348
1.54k
}
libregexp.c:is_lo_surrogate
Line
Count
Source
346
1.54k
{
347
1.54k
    return (c >> 10) == (0xDC00 >> 10); // 0xDC00-0xDFFF
348
1.54k
}
Unexecuted instantiation: cutils.c:is_lo_surrogate
Unexecuted instantiation: libunicode.c:is_lo_surrogate
349
350
static inline uint32_t get_hi_surrogate(uint32_t c)
351
0
{
352
0
    return (c >> 10) - (0x10000 >> 10) + 0xD800;
353
0
}
Unexecuted instantiation: libregexp.c:get_hi_surrogate
Unexecuted instantiation: cutils.c:get_hi_surrogate
Unexecuted instantiation: libunicode.c:get_hi_surrogate
354
355
static inline uint32_t get_lo_surrogate(uint32_t c)
356
0
{
357
0
    return (c & 0x3FF) | 0xDC00;
358
0
}
Unexecuted instantiation: libregexp.c:get_lo_surrogate
Unexecuted instantiation: cutils.c:get_lo_surrogate
Unexecuted instantiation: libunicode.c:get_lo_surrogate
359
360
static inline uint32_t from_surrogate(uint32_t hi, uint32_t lo)
361
665
{
362
665
    return 0x10000 + 0x400 * (hi - 0xD800) + (lo - 0xDC00);
363
665
}
libregexp.c:from_surrogate
Line
Count
Source
361
665
{
362
665
    return 0x10000 + 0x400 * (hi - 0xD800) + (lo - 0xDC00);
363
665
}
Unexecuted instantiation: cutils.c:from_surrogate
Unexecuted instantiation: libunicode.c:from_surrogate
364
365
static inline int from_hex(int c)
366
64.8k
{
367
64.8k
    if (c >= '0' && c <= '9')
368
20.3k
        return c - '0';
369
44.4k
    else if (c >= 'A' && c <= 'F')
370
17.0k
        return c - 'A' + 10;
371
27.4k
    else if (c >= 'a' && c <= 'f')
372
17.0k
        return c - 'a' + 10;
373
10.3k
    else
374
10.3k
        return -1;
375
64.8k
}
libregexp.c:from_hex
Line
Count
Source
366
64.8k
{
367
64.8k
    if (c >= '0' && c <= '9')
368
20.3k
        return c - '0';
369
44.4k
    else if (c >= 'A' && c <= 'F')
370
17.0k
        return c - 'A' + 10;
371
27.4k
    else if (c >= 'a' && c <= 'f')
372
17.0k
        return c - 'a' + 10;
373
10.3k
    else
374
10.3k
        return -1;
375
64.8k
}
Unexecuted instantiation: cutils.c:from_hex
Unexecuted instantiation: libunicode.c:from_hex
376
377
void rqsort(void *base, size_t nmemb, size_t size,
378
            int (*cmp)(const void *, const void *, void *),
379
            void *arg);
380
381
static inline uint64_t float64_as_uint64(double d)
382
0
{
383
0
    union {
384
0
        double d;
385
0
        uint64_t u64;
386
0
    } u;
387
0
    u.d = d;
388
0
    return u.u64;
389
0
}
Unexecuted instantiation: libregexp.c:float64_as_uint64
Unexecuted instantiation: cutils.c:float64_as_uint64
Unexecuted instantiation: libunicode.c:float64_as_uint64
390
391
static inline double uint64_as_float64(uint64_t u64)
392
0
{
393
0
    union {
394
0
        double d;
395
0
        uint64_t u64;
396
0
    } u;
397
0
    u.u64 = u64;
398
0
    return u.d;
399
0
}
Unexecuted instantiation: libregexp.c:uint64_as_float64
Unexecuted instantiation: cutils.c:uint64_as_float64
Unexecuted instantiation: libunicode.c:uint64_as_float64
400
401
static inline double fromfp16(uint16_t v)
402
0
{
403
0
    double d;
404
0
    uint32_t v1;
405
0
    v1 = v & 0x7fff;
406
0
    if (unlikely(v1 >= 0x7c00))
407
0
        v1 += 0x1f8000; /* NaN or infinity */
408
0
    d = uint64_as_float64(((uint64_t)(v >> 15) << 63) | ((uint64_t)v1 << (52 - 10)));
409
0
    return d * 0x1p1008;
410
0
}
Unexecuted instantiation: libregexp.c:fromfp16
Unexecuted instantiation: cutils.c:fromfp16
Unexecuted instantiation: libunicode.c:fromfp16
411
412
static inline uint16_t tofp16(double d)
413
0
{
414
0
    uint64_t a, addend;
415
0
    uint32_t v, sgn;
416
0
    int shift;
417
0
    
418
0
    a = float64_as_uint64(d);
419
0
    sgn = a >> 63;
420
0
    a = a & 0x7fffffffffffffff;
421
0
    if (unlikely(a > 0x7ff0000000000000)) {
422
0
        /* nan */
423
0
        v = 0x7c01;
424
0
    } else if (a < 0x3f10000000000000) { /* 0x1p-14 */
425
0
        /* subnormal f16 number or zero */
426
0
        if (a <= 0x3e60000000000000) { /* 0x1p-25 */
427
0
            v = 0x0000; /* zero */
428
0
        } else {
429
0
            shift = 1051 - (a >> 52);
430
0
            a = ((uint64_t)1 << 52) | (a & (((uint64_t)1 << 52) - 1));
431
0
            addend = ((a >> shift) & 1) + (((uint64_t)1 << (shift - 1)) - 1);
432
0
            v = (a + addend) >> shift;
433
0
        }
434
0
    } else {
435
0
        /* normal number or infinity */
436
0
        a -= 0x3f00000000000000; /* adjust the exponent */
437
0
        /* round */
438
0
        addend = ((a >> (52 - 10)) & 1) + (((uint64_t)1 << (52 - 11)) - 1);
439
0
        v = (a + addend) >> (52 - 10);
440
0
        /* overflow ? */
441
0
        if (unlikely(v > 0x7c00))
442
0
            v = 0x7c00;
443
0
    }
444
0
    return v | (sgn << 15);
445
0
}
Unexecuted instantiation: libregexp.c:tofp16
Unexecuted instantiation: cutils.c:tofp16
Unexecuted instantiation: libunicode.c:tofp16
446
447
static inline int isfp16nan(uint16_t v)
448
0
{
449
0
    return (v & 0x7FFF) > 0x7C00;
450
0
}
Unexecuted instantiation: libregexp.c:isfp16nan
Unexecuted instantiation: cutils.c:isfp16nan
Unexecuted instantiation: libunicode.c:isfp16nan
451
452
static inline int isfp16zero(uint16_t v)
453
0
{
454
0
    return (v & 0x7FFF) == 0;
455
0
}
Unexecuted instantiation: libregexp.c:isfp16zero
Unexecuted instantiation: cutils.c:isfp16zero
Unexecuted instantiation: libunicode.c:isfp16zero
456
457
#endif  /* CUTILS_H */