blob: e0f2e0a08a8062eadb7a9e28c79c8110f92ef300 [file] [log] [blame]
Andrew Scull18834872018-10-12 11:48:09 +01001/*
Andrew Walbran692b3252019-03-07 15:51:31 +00002 * Copyright 2018 The Hafnium Authors.
Andrew Scull18834872018-10-12 11:48:09 +01003 *
Andrew Walbrane959ec12020-06-17 15:01:09 +01004 * Use of this source code is governed by a BSD-style
5 * license that can be found in the LICENSE file or at
6 * https://opensource.org/licenses/BSD-3-Clause.
Andrew Scull18834872018-10-12 11:48:09 +01007 */
8
Andrew Scullfbc938a2018-08-20 14:09:28 +01009#pragma once
Wedson Almeida Filho987c0ff2018-06-20 16:34:38 +010010
11#include <stddef.h>
12#include <stdint.h>
13
Andrew Scull6386f252018-12-06 13:29:10 +000014#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
15
Wedson Almeida Filho987c0ff2018-06-20 16:34:38 +010016int memcmp(const void *a, const void *b, size_t n);
17
Andrew Scull3c351e92020-01-28 11:26:05 +000018int strncmp(const char *a, const char *b, size_t n);
Wedson Almeida Filho987c0ff2018-06-20 16:34:38 +010019
Andrew Walbran318f5732018-11-20 16:23:42 +000020#define ctz(x) __builtin_ctz(x)
21
Alfredo Mazzinghieb1997c2019-02-07 18:00:01 +000022/* Compatibility with old compilers */
23#ifndef __has_builtin
24#define __has_builtin(x) 0
25#endif
26
27/**
28 * Check whether the value `v` is aligned to the boundary `a`,
29 * with `a` power of 2.
30 */
31#if __has_builtin(__builtin_is_aligned)
32#define is_aligned(v, a) __builtin_is_aligned((v), (a))
33#else
Andrew Scullad897042020-01-20 16:01:03 +000034#define is_aligned(v, a) (((uintptr_t)(v) & ((a)-1)) == 0)
Alfredo Mazzinghieb1997c2019-02-07 18:00:01 +000035#endif
36
37/**
38 * Align up the value `v` to the boundary `a`, with `a` power of 2.
39 */
40#if __has_builtin(__builtin_align_up)
41#define align_up(v, a) __builtin_align_up((v), (a))
42#else
Andrew Scullad897042020-01-20 16:01:03 +000043#define align_up(v, a) (((uintptr_t)(v) + ((a)-1)) & ~((a)-1))
Alfredo Mazzinghieb1997c2019-02-07 18:00:01 +000044#endif
45
46/**
47 * Align down the value `v` to the boundary `a`, with `a` power of 2.
48 */
49#if __has_builtin(__builtin_align_down)
50#define align_down(v, a) __builtin_align_down((v), (a))
51#else
Andrew Scullad897042020-01-20 16:01:03 +000052#define align_down(v, a) ((uintptr_t)(v) & ~((a)-1))
Alfredo Mazzinghieb1997c2019-02-07 18:00:01 +000053#endif
54
Andrew Walbran4a53ba62019-03-05 17:26:12 +000055#ifndef be16toh
Andrew Scullf12b35d2018-07-16 12:12:59 +010056#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
Wedson Almeida Filho987c0ff2018-06-20 16:34:38 +010057
Andrew Scullf12b35d2018-07-16 12:12:59 +010058#define be16toh(v) __builtin_bswap16(v)
59#define be32toh(v) __builtin_bswap32(v)
60#define be64toh(v) __builtin_bswap64(v)
Wedson Almeida Filho987c0ff2018-06-20 16:34:38 +010061
Andrew Scullf12b35d2018-07-16 12:12:59 +010062#define htobe16(v) __builtin_bswap16(v)
63#define htobe32(v) __builtin_bswap32(v)
64#define htobe64(v) __builtin_bswap64(v)
Wedson Almeida Filho987c0ff2018-06-20 16:34:38 +010065
Andrew Scullf12b35d2018-07-16 12:12:59 +010066#define le16toh(v) (v)
67#define le32toh(v) (v)
68#define le64toh(v) (v)
Wedson Almeida Filho987c0ff2018-06-20 16:34:38 +010069
Andrew Scullf12b35d2018-07-16 12:12:59 +010070#define htole16(v) (v)
71#define htole32(v) (v)
72#define htole64(v) (v)
73
74#elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
75
76#define be16toh(v) (v)
77#define be32toh(v) (v)
78#define be64toh(v) (v)
79
80#define htobe16(v) (v)
81#define htobe32(v) (v)
82#define htobe64(v) (v)
83
84#define le16toh(v) __builtin_bswap16(v)
85#define le32toh(v) __builtin_bswap32(v)
86#define le64toh(v) __builtin_bswap64(v)
87
88#define htole16(v) __builtin_bswap16(v)
89#define htole32(v) __builtin_bswap32(v)
90#define htole64(v) __builtin_bswap64(v)
91
Andrew Scullcbefbdb2019-01-11 16:36:26 +000092#else
93
94/*
95 * __BYTE_ORDER__ != __ORDER_LITTLE_ENDIAN__ &&
96 * __BYTE_ORDER__ != __ORDER_BIG_ENDIAN__
97 */
Andrew Scullf12b35d2018-07-16 12:12:59 +010098
99#error "Unsupported byte order"
100
101#endif
Andrew Walbran4a53ba62019-03-05 17:26:12 +0000102#endif