summaryrefslogtreecommitdiff
path: root/riscv/riscv-probe/libfemto/include/stdbits.h
blob: 298538137a5267fb77690bc66496d06380edda22 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#pragma once

#ifdef __cplusplus
extern "C" {
#endif

#include <stdint.h>

#define clz(val) ({                         \
    int result;                             \
    switch(sizeof(val)) {                   \
    case 1: result = clz8(val); break;      \
    case 2: result = clz16(val); break;     \
    case 4: result = clz32(val); break;     \
    case 8: result = clz64(val); break;     \
    }                                       \
    result;                                 \
})

#define ctz(val) ({                         \
    int result;                             \
    switch(sizeof(val)) {                   \
    case 1: result = ctz8(val); break;      \
    case 2: result = ctz16(val); break;     \
    case 4: result = ctz32(val); break;     \
    case 8: result = ctz64(val); break;     \
    }                                       \
    result;                                 \
})

int clz8(int8_t val);
int clz16(int16_t val);
int clz32(int32_t val);
int clz64(int64_t val);

int ctz8(int8_t val);
int ctz16(int16_t val);
int ctz32(int32_t val);
int ctz64(int64_t val);

static inline int ispow2(uintptr_t val)
{
    return val && !(val & (val-1));
}

static inline uintptr_t roundpow2(uintptr_t val)
{
    val--;
    val |= val >> 1;
    val |= val >> 2;
    val |= val >> 4;
    val |= val >> 8;
    val |= val >> 16;
#if __SIZE_WIDTH__ == 64
    val |= val >> 32;
#endif
    val++;
    return val;
}

#ifdef __cplusplus
}
#endif