Coverage Report

Created: 2025-08-28 06:43

/src/capstonenext/MathExtras.h
Line
Count
Source (jump to first uncovered line)
1
//===-- llvm/Support/MathExtras.h - Useful math functions -------*- C++ -*-===//
2
//
3
//                     The LLVM Compiler Infrastructure
4
//
5
// This file is distributed under the University of Illinois Open Source
6
// License. See LICENSE.TXT for details.
7
//
8
//===----------------------------------------------------------------------===//
9
//
10
// This file contains some functions that are useful for math stuff.
11
//
12
//===----------------------------------------------------------------------===//
13
14
/* Capstone Disassembly Engine */
15
/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */
16
17
#ifndef CS_LLVM_SUPPORT_MATHEXTRAS_H
18
#define CS_LLVM_SUPPORT_MATHEXTRAS_H
19
20
#if defined(_WIN32_WCE) && (_WIN32_WCE < 0x800)
21
#include "windowsce/intrin.h"
22
#elif defined(_MSC_VER)
23
#include <intrin.h>
24
#endif
25
26
#ifndef __cplusplus
27
#ifdef _MSC_VER
28
#define inline /* inline */
29
#endif
30
#endif
31
32
#include <limits.h>
33
34
// NOTE: The following support functions use the _32/_64 extensions instead of
35
// type overloading so that signed and unsigned integers can be used without
36
// ambiguity.
37
38
/// Hi_32 - This function returns the high 32 bits of a 64 bit value.
39
static inline uint32_t Hi_32(uint64_t Value)
40
0
{
41
0
  return (uint32_t)(Value >> 32);
42
0
}
Unexecuted instantiation: SparcModule.c:Hi_32
Unexecuted instantiation: ARMMapping.c:Hi_32
Unexecuted instantiation: AArch64Mapping.c:Hi_32
Unexecuted instantiation: PPCMapping.c:Hi_32
Unexecuted instantiation: SparcMapping.c:Hi_32
Unexecuted instantiation: XCoreDisassembler.c:Hi_32
Unexecuted instantiation: XCoreInstPrinter.c:Hi_32
Unexecuted instantiation: M68KDisassembler.c:Hi_32
Unexecuted instantiation: TMS320C64xDisassembler.c:Hi_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:Hi_32
Unexecuted instantiation: RISCVDisassembler.c:Hi_32
Unexecuted instantiation: TriCoreDisassembler.c:Hi_32
Unexecuted instantiation: HPPADisassembler.c:Hi_32
Unexecuted instantiation: XtensaMapping.c:Hi_32
Unexecuted instantiation: ARMDisassembler.c:Hi_32
Unexecuted instantiation: ARMDisassemblerExtension.c:Hi_32
Unexecuted instantiation: ARMInstPrinter.c:Hi_32
Unexecuted instantiation: AArch64Disassembler.c:Hi_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:Hi_32
Unexecuted instantiation: AArch64InstPrinter.c:Hi_32
Unexecuted instantiation: MipsDisassembler.c:Hi_32
Unexecuted instantiation: PPCDisassembler.c:Hi_32
Unexecuted instantiation: PPCInstPrinter.c:Hi_32
Unexecuted instantiation: SparcDisassembler.c:Hi_32
Unexecuted instantiation: SparcDisassemblerExtension.c:Hi_32
Unexecuted instantiation: SparcInstPrinter.c:Hi_32
Unexecuted instantiation: SystemZDisassembler.c:Hi_32
Unexecuted instantiation: SystemZInstPrinter.c:Hi_32
Unexecuted instantiation: TriCoreInstPrinter.c:Hi_32
Unexecuted instantiation: LoongArchDisassembler.c:Hi_32
Unexecuted instantiation: XtensaDisassembler.c:Hi_32
Unexecuted instantiation: XtensaInstPrinter.c:Hi_32
Unexecuted instantiation: ARCDisassembler.c:Hi_32
43
44
/// Lo_32 - This function returns the low 32 bits of a 64 bit value.
45
static inline uint32_t Lo_32(uint64_t Value)
46
0
{
47
0
  return (uint32_t)(Value);
48
0
}
Unexecuted instantiation: SparcModule.c:Lo_32
Unexecuted instantiation: ARMMapping.c:Lo_32
Unexecuted instantiation: AArch64Mapping.c:Lo_32
Unexecuted instantiation: PPCMapping.c:Lo_32
Unexecuted instantiation: SparcMapping.c:Lo_32
Unexecuted instantiation: XCoreDisassembler.c:Lo_32
Unexecuted instantiation: XCoreInstPrinter.c:Lo_32
Unexecuted instantiation: M68KDisassembler.c:Lo_32
Unexecuted instantiation: TMS320C64xDisassembler.c:Lo_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:Lo_32
Unexecuted instantiation: RISCVDisassembler.c:Lo_32
Unexecuted instantiation: TriCoreDisassembler.c:Lo_32
Unexecuted instantiation: HPPADisassembler.c:Lo_32
Unexecuted instantiation: XtensaMapping.c:Lo_32
Unexecuted instantiation: ARMDisassembler.c:Lo_32
Unexecuted instantiation: ARMDisassemblerExtension.c:Lo_32
Unexecuted instantiation: ARMInstPrinter.c:Lo_32
Unexecuted instantiation: AArch64Disassembler.c:Lo_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:Lo_32
Unexecuted instantiation: AArch64InstPrinter.c:Lo_32
Unexecuted instantiation: MipsDisassembler.c:Lo_32
Unexecuted instantiation: PPCDisassembler.c:Lo_32
Unexecuted instantiation: PPCInstPrinter.c:Lo_32
Unexecuted instantiation: SparcDisassembler.c:Lo_32
Unexecuted instantiation: SparcDisassemblerExtension.c:Lo_32
Unexecuted instantiation: SparcInstPrinter.c:Lo_32
Unexecuted instantiation: SystemZDisassembler.c:Lo_32
Unexecuted instantiation: SystemZInstPrinter.c:Lo_32
Unexecuted instantiation: TriCoreInstPrinter.c:Lo_32
Unexecuted instantiation: LoongArchDisassembler.c:Lo_32
Unexecuted instantiation: XtensaDisassembler.c:Lo_32
Unexecuted instantiation: XtensaInstPrinter.c:Lo_32
Unexecuted instantiation: ARCDisassembler.c:Lo_32
49
50
/// isUIntN - Checks if an unsigned integer fits into the given (dynamic)
51
/// bit width.
52
static inline bool isUIntN(unsigned N, uint64_t x)
53
185k
{
54
185k
  return x == (x & (~0ULL >> (64 - N)));
55
185k
}
Unexecuted instantiation: SparcModule.c:isUIntN
Unexecuted instantiation: ARMMapping.c:isUIntN
Unexecuted instantiation: AArch64Mapping.c:isUIntN
Unexecuted instantiation: PPCMapping.c:isUIntN
Unexecuted instantiation: SparcMapping.c:isUIntN
Unexecuted instantiation: XCoreDisassembler.c:isUIntN
Unexecuted instantiation: XCoreInstPrinter.c:isUIntN
Unexecuted instantiation: M68KDisassembler.c:isUIntN
Unexecuted instantiation: TMS320C64xDisassembler.c:isUIntN
Unexecuted instantiation: TMS320C64xInstPrinter.c:isUIntN
Unexecuted instantiation: RISCVDisassembler.c:isUIntN
Unexecuted instantiation: TriCoreDisassembler.c:isUIntN
Unexecuted instantiation: HPPADisassembler.c:isUIntN
Unexecuted instantiation: XtensaMapping.c:isUIntN
Unexecuted instantiation: ARMDisassembler.c:isUIntN
Unexecuted instantiation: ARMDisassemblerExtension.c:isUIntN
Unexecuted instantiation: ARMInstPrinter.c:isUIntN
Unexecuted instantiation: AArch64Disassembler.c:isUIntN
Unexecuted instantiation: AArch64DisassemblerExtension.c:isUIntN
Unexecuted instantiation: AArch64InstPrinter.c:isUIntN
Unexecuted instantiation: MipsDisassembler.c:isUIntN
PPCDisassembler.c:isUIntN
Line
Count
Source
53
42.6k
{
54
42.6k
  return x == (x & (~0ULL >> (64 - N)));
55
42.6k
}
Unexecuted instantiation: PPCInstPrinter.c:isUIntN
Unexecuted instantiation: SparcDisassembler.c:isUIntN
Unexecuted instantiation: SparcDisassemblerExtension.c:isUIntN
Unexecuted instantiation: SparcInstPrinter.c:isUIntN
SystemZDisassembler.c:isUIntN
Line
Count
Source
53
143k
{
54
143k
  return x == (x & (~0ULL >> (64 - N)));
55
143k
}
Unexecuted instantiation: SystemZInstPrinter.c:isUIntN
Unexecuted instantiation: TriCoreInstPrinter.c:isUIntN
Unexecuted instantiation: LoongArchDisassembler.c:isUIntN
Unexecuted instantiation: XtensaDisassembler.c:isUIntN
Unexecuted instantiation: XtensaInstPrinter.c:isUIntN
Unexecuted instantiation: ARCDisassembler.c:isUIntN
56
57
/// isIntN - Checks if an signed integer fits into the given (dynamic)
58
/// bit width.
59
static inline bool isIntN(unsigned N, int64_t x)
60
0
{
61
0
  return N >= 64 ||
62
0
         (-(INT64_C(1) << (N - 1)) <= x && x < (INT64_C(1) << (N - 1)));
63
0
}
Unexecuted instantiation: SparcModule.c:isIntN
Unexecuted instantiation: ARMMapping.c:isIntN
Unexecuted instantiation: AArch64Mapping.c:isIntN
Unexecuted instantiation: PPCMapping.c:isIntN
Unexecuted instantiation: SparcMapping.c:isIntN
Unexecuted instantiation: XCoreDisassembler.c:isIntN
Unexecuted instantiation: XCoreInstPrinter.c:isIntN
Unexecuted instantiation: M68KDisassembler.c:isIntN
Unexecuted instantiation: TMS320C64xDisassembler.c:isIntN
Unexecuted instantiation: TMS320C64xInstPrinter.c:isIntN
Unexecuted instantiation: RISCVDisassembler.c:isIntN
Unexecuted instantiation: TriCoreDisassembler.c:isIntN
Unexecuted instantiation: HPPADisassembler.c:isIntN
Unexecuted instantiation: XtensaMapping.c:isIntN
Unexecuted instantiation: ARMDisassembler.c:isIntN
Unexecuted instantiation: ARMDisassemblerExtension.c:isIntN
Unexecuted instantiation: ARMInstPrinter.c:isIntN
Unexecuted instantiation: AArch64Disassembler.c:isIntN
Unexecuted instantiation: AArch64DisassemblerExtension.c:isIntN
Unexecuted instantiation: AArch64InstPrinter.c:isIntN
Unexecuted instantiation: MipsDisassembler.c:isIntN
Unexecuted instantiation: PPCDisassembler.c:isIntN
Unexecuted instantiation: PPCInstPrinter.c:isIntN
Unexecuted instantiation: SparcDisassembler.c:isIntN
Unexecuted instantiation: SparcDisassemblerExtension.c:isIntN
Unexecuted instantiation: SparcInstPrinter.c:isIntN
Unexecuted instantiation: SystemZDisassembler.c:isIntN
Unexecuted instantiation: SystemZInstPrinter.c:isIntN
Unexecuted instantiation: TriCoreInstPrinter.c:isIntN
Unexecuted instantiation: LoongArchDisassembler.c:isIntN
Unexecuted instantiation: XtensaDisassembler.c:isIntN
Unexecuted instantiation: XtensaInstPrinter.c:isIntN
Unexecuted instantiation: ARCDisassembler.c:isIntN
64
65
/// isMask_32 - This function returns true if the argument is a sequence of ones
66
/// starting at the least significant bit with the remainder zero (32 bit
67
/// version).   Ex. isMask_32(0x0000FFFFU) == true.
68
static inline bool isMask_32(uint32_t Value)
69
0
{
70
0
  return Value && ((Value + 1) & Value) == 0;
71
0
}
Unexecuted instantiation: SparcModule.c:isMask_32
Unexecuted instantiation: ARMMapping.c:isMask_32
Unexecuted instantiation: AArch64Mapping.c:isMask_32
Unexecuted instantiation: PPCMapping.c:isMask_32
Unexecuted instantiation: SparcMapping.c:isMask_32
Unexecuted instantiation: XCoreDisassembler.c:isMask_32
Unexecuted instantiation: XCoreInstPrinter.c:isMask_32
Unexecuted instantiation: M68KDisassembler.c:isMask_32
Unexecuted instantiation: TMS320C64xDisassembler.c:isMask_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:isMask_32
Unexecuted instantiation: RISCVDisassembler.c:isMask_32
Unexecuted instantiation: TriCoreDisassembler.c:isMask_32
Unexecuted instantiation: HPPADisassembler.c:isMask_32
Unexecuted instantiation: XtensaMapping.c:isMask_32
Unexecuted instantiation: ARMDisassembler.c:isMask_32
Unexecuted instantiation: ARMDisassemblerExtension.c:isMask_32
Unexecuted instantiation: ARMInstPrinter.c:isMask_32
Unexecuted instantiation: AArch64Disassembler.c:isMask_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:isMask_32
Unexecuted instantiation: AArch64InstPrinter.c:isMask_32
Unexecuted instantiation: MipsDisassembler.c:isMask_32
Unexecuted instantiation: PPCDisassembler.c:isMask_32
Unexecuted instantiation: PPCInstPrinter.c:isMask_32
Unexecuted instantiation: SparcDisassembler.c:isMask_32
Unexecuted instantiation: SparcDisassemblerExtension.c:isMask_32
Unexecuted instantiation: SparcInstPrinter.c:isMask_32
Unexecuted instantiation: SystemZDisassembler.c:isMask_32
Unexecuted instantiation: SystemZInstPrinter.c:isMask_32
Unexecuted instantiation: TriCoreInstPrinter.c:isMask_32
Unexecuted instantiation: LoongArchDisassembler.c:isMask_32
Unexecuted instantiation: XtensaDisassembler.c:isMask_32
Unexecuted instantiation: XtensaInstPrinter.c:isMask_32
Unexecuted instantiation: ARCDisassembler.c:isMask_32
72
73
/// isMask_64 - This function returns true if the argument is a sequence of ones
74
/// starting at the least significant bit with the remainder zero (64 bit
75
/// version).
76
static inline bool isMask_64(uint64_t Value)
77
7.71k
{
78
7.71k
  return Value && ((Value + 1) & Value) == 0;
79
7.71k
}
Unexecuted instantiation: SparcModule.c:isMask_64
Unexecuted instantiation: ARMMapping.c:isMask_64
Unexecuted instantiation: AArch64Mapping.c:isMask_64
Unexecuted instantiation: PPCMapping.c:isMask_64
Unexecuted instantiation: SparcMapping.c:isMask_64
Unexecuted instantiation: XCoreDisassembler.c:isMask_64
Unexecuted instantiation: XCoreInstPrinter.c:isMask_64
Unexecuted instantiation: M68KDisassembler.c:isMask_64
Unexecuted instantiation: TMS320C64xDisassembler.c:isMask_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:isMask_64
Unexecuted instantiation: RISCVDisassembler.c:isMask_64
Unexecuted instantiation: TriCoreDisassembler.c:isMask_64
Unexecuted instantiation: HPPADisassembler.c:isMask_64
Unexecuted instantiation: XtensaMapping.c:isMask_64
Unexecuted instantiation: ARMDisassembler.c:isMask_64
Unexecuted instantiation: ARMDisassemblerExtension.c:isMask_64
Unexecuted instantiation: ARMInstPrinter.c:isMask_64
Unexecuted instantiation: AArch64Disassembler.c:isMask_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:isMask_64
AArch64InstPrinter.c:isMask_64
Line
Count
Source
77
7.71k
{
78
7.71k
  return Value && ((Value + 1) & Value) == 0;
79
7.71k
}
Unexecuted instantiation: MipsDisassembler.c:isMask_64
Unexecuted instantiation: PPCDisassembler.c:isMask_64
Unexecuted instantiation: PPCInstPrinter.c:isMask_64
Unexecuted instantiation: SparcDisassembler.c:isMask_64
Unexecuted instantiation: SparcDisassemblerExtension.c:isMask_64
Unexecuted instantiation: SparcInstPrinter.c:isMask_64
Unexecuted instantiation: SystemZDisassembler.c:isMask_64
Unexecuted instantiation: SystemZInstPrinter.c:isMask_64
Unexecuted instantiation: TriCoreInstPrinter.c:isMask_64
Unexecuted instantiation: LoongArchDisassembler.c:isMask_64
Unexecuted instantiation: XtensaDisassembler.c:isMask_64
Unexecuted instantiation: XtensaInstPrinter.c:isMask_64
Unexecuted instantiation: ARCDisassembler.c:isMask_64
80
81
/// isShiftedMask_32 - This function returns true if the argument contains a
82
/// sequence of ones with the remainder zero (32 bit version.)
83
/// Ex. isShiftedMask_32(0x0000FF00U) == true.
84
static inline bool isShiftedMask_32(uint32_t Value)
85
0
{
86
0
  return isMask_32((Value - 1) | Value);
87
0
}
Unexecuted instantiation: SparcModule.c:isShiftedMask_32
Unexecuted instantiation: ARMMapping.c:isShiftedMask_32
Unexecuted instantiation: AArch64Mapping.c:isShiftedMask_32
Unexecuted instantiation: PPCMapping.c:isShiftedMask_32
Unexecuted instantiation: SparcMapping.c:isShiftedMask_32
Unexecuted instantiation: XCoreDisassembler.c:isShiftedMask_32
Unexecuted instantiation: XCoreInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: M68KDisassembler.c:isShiftedMask_32
Unexecuted instantiation: TMS320C64xDisassembler.c:isShiftedMask_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: RISCVDisassembler.c:isShiftedMask_32
Unexecuted instantiation: TriCoreDisassembler.c:isShiftedMask_32
Unexecuted instantiation: HPPADisassembler.c:isShiftedMask_32
Unexecuted instantiation: XtensaMapping.c:isShiftedMask_32
Unexecuted instantiation: ARMDisassembler.c:isShiftedMask_32
Unexecuted instantiation: ARMDisassemblerExtension.c:isShiftedMask_32
Unexecuted instantiation: ARMInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: AArch64Disassembler.c:isShiftedMask_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:isShiftedMask_32
Unexecuted instantiation: AArch64InstPrinter.c:isShiftedMask_32
Unexecuted instantiation: MipsDisassembler.c:isShiftedMask_32
Unexecuted instantiation: PPCDisassembler.c:isShiftedMask_32
Unexecuted instantiation: PPCInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: SparcDisassembler.c:isShiftedMask_32
Unexecuted instantiation: SparcDisassemblerExtension.c:isShiftedMask_32
Unexecuted instantiation: SparcInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: SystemZDisassembler.c:isShiftedMask_32
Unexecuted instantiation: SystemZInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: TriCoreInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: LoongArchDisassembler.c:isShiftedMask_32
Unexecuted instantiation: XtensaDisassembler.c:isShiftedMask_32
Unexecuted instantiation: XtensaInstPrinter.c:isShiftedMask_32
Unexecuted instantiation: ARCDisassembler.c:isShiftedMask_32
88
89
/// isShiftedMask_64 - This function returns true if the argument contains a
90
/// sequence of ones with the remainder zero (64 bit version.)
91
static inline bool isShiftedMask_64(uint64_t Value)
92
7.71k
{
93
7.71k
  return isMask_64((Value - 1) | Value);
94
7.71k
}
Unexecuted instantiation: SparcModule.c:isShiftedMask_64
Unexecuted instantiation: ARMMapping.c:isShiftedMask_64
Unexecuted instantiation: AArch64Mapping.c:isShiftedMask_64
Unexecuted instantiation: PPCMapping.c:isShiftedMask_64
Unexecuted instantiation: SparcMapping.c:isShiftedMask_64
Unexecuted instantiation: XCoreDisassembler.c:isShiftedMask_64
Unexecuted instantiation: XCoreInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: M68KDisassembler.c:isShiftedMask_64
Unexecuted instantiation: TMS320C64xDisassembler.c:isShiftedMask_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: RISCVDisassembler.c:isShiftedMask_64
Unexecuted instantiation: TriCoreDisassembler.c:isShiftedMask_64
Unexecuted instantiation: HPPADisassembler.c:isShiftedMask_64
Unexecuted instantiation: XtensaMapping.c:isShiftedMask_64
Unexecuted instantiation: ARMDisassembler.c:isShiftedMask_64
Unexecuted instantiation: ARMDisassemblerExtension.c:isShiftedMask_64
Unexecuted instantiation: ARMInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: AArch64Disassembler.c:isShiftedMask_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:isShiftedMask_64
AArch64InstPrinter.c:isShiftedMask_64
Line
Count
Source
92
7.71k
{
93
7.71k
  return isMask_64((Value - 1) | Value);
94
7.71k
}
Unexecuted instantiation: MipsDisassembler.c:isShiftedMask_64
Unexecuted instantiation: PPCDisassembler.c:isShiftedMask_64
Unexecuted instantiation: PPCInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: SparcDisassembler.c:isShiftedMask_64
Unexecuted instantiation: SparcDisassemblerExtension.c:isShiftedMask_64
Unexecuted instantiation: SparcInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: SystemZDisassembler.c:isShiftedMask_64
Unexecuted instantiation: SystemZInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: TriCoreInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: LoongArchDisassembler.c:isShiftedMask_64
Unexecuted instantiation: XtensaDisassembler.c:isShiftedMask_64
Unexecuted instantiation: XtensaInstPrinter.c:isShiftedMask_64
Unexecuted instantiation: ARCDisassembler.c:isShiftedMask_64
95
96
/// isPowerOf2_32 - This function returns true if the argument is a power of
97
/// two > 0. Ex. isPowerOf2_32(0x00100000U) == true (32 bit edition.)
98
static inline bool isPowerOf2_32(uint32_t Value)
99
0
{
100
0
  return Value && !(Value & (Value - 1));
101
0
}
Unexecuted instantiation: SparcModule.c:isPowerOf2_32
Unexecuted instantiation: ARMMapping.c:isPowerOf2_32
Unexecuted instantiation: AArch64Mapping.c:isPowerOf2_32
Unexecuted instantiation: PPCMapping.c:isPowerOf2_32
Unexecuted instantiation: SparcMapping.c:isPowerOf2_32
Unexecuted instantiation: XCoreDisassembler.c:isPowerOf2_32
Unexecuted instantiation: XCoreInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: M68KDisassembler.c:isPowerOf2_32
Unexecuted instantiation: TMS320C64xDisassembler.c:isPowerOf2_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: RISCVDisassembler.c:isPowerOf2_32
Unexecuted instantiation: TriCoreDisassembler.c:isPowerOf2_32
Unexecuted instantiation: HPPADisassembler.c:isPowerOf2_32
Unexecuted instantiation: XtensaMapping.c:isPowerOf2_32
Unexecuted instantiation: ARMDisassembler.c:isPowerOf2_32
Unexecuted instantiation: ARMDisassemblerExtension.c:isPowerOf2_32
Unexecuted instantiation: ARMInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: AArch64Disassembler.c:isPowerOf2_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:isPowerOf2_32
Unexecuted instantiation: AArch64InstPrinter.c:isPowerOf2_32
Unexecuted instantiation: MipsDisassembler.c:isPowerOf2_32
Unexecuted instantiation: PPCDisassembler.c:isPowerOf2_32
Unexecuted instantiation: PPCInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: SparcDisassembler.c:isPowerOf2_32
Unexecuted instantiation: SparcDisassemblerExtension.c:isPowerOf2_32
Unexecuted instantiation: SparcInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: SystemZDisassembler.c:isPowerOf2_32
Unexecuted instantiation: SystemZInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: TriCoreInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: LoongArchDisassembler.c:isPowerOf2_32
Unexecuted instantiation: XtensaDisassembler.c:isPowerOf2_32
Unexecuted instantiation: XtensaInstPrinter.c:isPowerOf2_32
Unexecuted instantiation: ARCDisassembler.c:isPowerOf2_32
102
103
/// CountLeadingZeros_32 - this function performs the platform optimal form of
104
/// counting the number of zeros from the most significant bit to the first one
105
/// bit.  Ex. CountLeadingZeros_32(0x00F000FF) == 8.
106
/// Returns 32 if the word is zero.
107
static inline unsigned CountLeadingZeros_32(uint32_t Value)
108
106k
{
109
106k
  unsigned Count; // result
110
106k
#if __GNUC__ >= 4
111
  // PowerPC is defined for __builtin_clz(0)
112
106k
#if !defined(__ppc__) && !defined(__ppc64__)
113
106k
  if (!Value)
114
417
    return 32;
115
106k
#endif
116
106k
  Count = __builtin_clz(Value);
117
#else
118
  unsigned Shift;
119
  if (!Value)
120
    return 32;
121
  Count = 0;
122
  // bisection method for count leading zeros
123
  for (Shift = 32 >> 1; Shift; Shift >>= 1) {
124
    uint32_t Tmp = Value >> Shift;
125
    if (Tmp) {
126
      Value = Tmp;
127
    } else {
128
      Count |= Shift;
129
    }
130
  }
131
#endif
132
106k
  return Count;
133
106k
}
Unexecuted instantiation: SparcModule.c:CountLeadingZeros_32
Unexecuted instantiation: ARMMapping.c:CountLeadingZeros_32
AArch64Mapping.c:CountLeadingZeros_32
Line
Count
Source
108
13.1k
{
109
13.1k
  unsigned Count; // result
110
13.1k
#if __GNUC__ >= 4
111
  // PowerPC is defined for __builtin_clz(0)
112
13.1k
#if !defined(__ppc__) && !defined(__ppc64__)
113
13.1k
  if (!Value)
114
0
    return 32;
115
13.1k
#endif
116
13.1k
  Count = __builtin_clz(Value);
117
#else
118
  unsigned Shift;
119
  if (!Value)
120
    return 32;
121
  Count = 0;
122
  // bisection method for count leading zeros
123
  for (Shift = 32 >> 1; Shift; Shift >>= 1) {
124
    uint32_t Tmp = Value >> Shift;
125
    if (Tmp) {
126
      Value = Tmp;
127
    } else {
128
      Count |= Shift;
129
    }
130
  }
131
#endif
132
13.1k
  return Count;
133
13.1k
}
Unexecuted instantiation: PPCMapping.c:CountLeadingZeros_32
Unexecuted instantiation: SparcMapping.c:CountLeadingZeros_32
Unexecuted instantiation: XCoreDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: XCoreInstPrinter.c:CountLeadingZeros_32
Unexecuted instantiation: M68KDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: TMS320C64xDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountLeadingZeros_32
Unexecuted instantiation: RISCVDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: TriCoreDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: HPPADisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: XtensaMapping.c:CountLeadingZeros_32
Unexecuted instantiation: ARMDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: ARMDisassemblerExtension.c:CountLeadingZeros_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountLeadingZeros_32
AArch64InstPrinter.c:CountLeadingZeros_32
Line
Count
Source
108
93.3k
{
109
93.3k
  unsigned Count; // result
110
93.3k
#if __GNUC__ >= 4
111
  // PowerPC is defined for __builtin_clz(0)
112
93.3k
#if !defined(__ppc__) && !defined(__ppc64__)
113
93.3k
  if (!Value)
114
417
    return 32;
115
92.9k
#endif
116
92.9k
  Count = __builtin_clz(Value);
117
#else
118
  unsigned Shift;
119
  if (!Value)
120
    return 32;
121
  Count = 0;
122
  // bisection method for count leading zeros
123
  for (Shift = 32 >> 1; Shift; Shift >>= 1) {
124
    uint32_t Tmp = Value >> Shift;
125
    if (Tmp) {
126
      Value = Tmp;
127
    } else {
128
      Count |= Shift;
129
    }
130
  }
131
#endif
132
92.9k
  return Count;
133
93.3k
}
Unexecuted instantiation: MipsDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: PPCDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: PPCInstPrinter.c:CountLeadingZeros_32
Unexecuted instantiation: SparcDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: SparcDisassemblerExtension.c:CountLeadingZeros_32
Unexecuted instantiation: SparcInstPrinter.c:CountLeadingZeros_32
Unexecuted instantiation: SystemZDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: SystemZInstPrinter.c:CountLeadingZeros_32
Unexecuted instantiation: TriCoreInstPrinter.c:CountLeadingZeros_32
Unexecuted instantiation: LoongArchDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: XtensaDisassembler.c:CountLeadingZeros_32
Unexecuted instantiation: XtensaInstPrinter.c:CountLeadingZeros_32
Unexecuted instantiation: ARCDisassembler.c:CountLeadingZeros_32
134
135
/// CountLeadingOnes_32 - this function performs the operation of
136
/// counting the number of ones from the most significant bit to the first zero
137
/// bit.  Ex. CountLeadingOnes_32(0xFF0FFF00) == 8.
138
/// Returns 32 if the word is all ones.
139
static inline unsigned CountLeadingOnes_32(uint32_t Value)
140
0
{
141
0
  return CountLeadingZeros_32(~Value);
142
0
}
Unexecuted instantiation: SparcModule.c:CountLeadingOnes_32
Unexecuted instantiation: ARMMapping.c:CountLeadingOnes_32
Unexecuted instantiation: AArch64Mapping.c:CountLeadingOnes_32
Unexecuted instantiation: PPCMapping.c:CountLeadingOnes_32
Unexecuted instantiation: SparcMapping.c:CountLeadingOnes_32
Unexecuted instantiation: XCoreDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: XCoreInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: M68KDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: TMS320C64xDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: RISCVDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: TriCoreDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: HPPADisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: XtensaMapping.c:CountLeadingOnes_32
Unexecuted instantiation: ARMDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: ARMDisassemblerExtension.c:CountLeadingOnes_32
Unexecuted instantiation: ARMInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: AArch64Disassembler.c:CountLeadingOnes_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountLeadingOnes_32
Unexecuted instantiation: MipsDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: PPCDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: PPCInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: SparcDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: SparcDisassemblerExtension.c:CountLeadingOnes_32
Unexecuted instantiation: SparcInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: SystemZDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: SystemZInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: TriCoreInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: LoongArchDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: XtensaDisassembler.c:CountLeadingOnes_32
Unexecuted instantiation: XtensaInstPrinter.c:CountLeadingOnes_32
Unexecuted instantiation: ARCDisassembler.c:CountLeadingOnes_32
143
144
/// CountLeadingZeros_64 - This function performs the platform optimal form
145
/// of counting the number of zeros from the most significant bit to the first
146
/// one bit (64 bit edition.)
147
/// Returns 64 if the word is zero.
148
static inline unsigned CountLeadingZeros_64(uint64_t Value)
149
473
{
150
473
  unsigned Count; // result
151
473
#if __GNUC__ >= 4
152
  // PowerPC is defined for __builtin_clzll(0)
153
473
#if !defined(__ppc__) && !defined(__ppc64__)
154
473
  if (!Value)
155
0
    return 64;
156
473
#endif
157
473
  Count = __builtin_clzll(Value);
158
#else
159
#ifndef _MSC_VER
160
  unsigned Shift;
161
  if (sizeof(long) == sizeof(int64_t)) {
162
    if (!Value)
163
      return 64;
164
    Count = 0;
165
    // bisection method for count leading zeros
166
    for (Shift = 64 >> 1; Shift; Shift >>= 1) {
167
      uint64_t Tmp = Value >> Shift;
168
      if (Tmp) {
169
        Value = Tmp;
170
      } else {
171
        Count |= Shift;
172
      }
173
    }
174
  } else
175
#endif
176
  {
177
    // get hi portion
178
    uint32_t Hi = Hi_32(Value);
179
180
    // if some bits in hi portion
181
    if (Hi) {
182
      // leading zeros in hi portion plus all bits in lo portion
183
      Count = CountLeadingZeros_32(Hi);
184
    } else {
185
      // get lo portion
186
      uint32_t Lo = Lo_32(Value);
187
      // same as 32 bit value
188
      Count = CountLeadingZeros_32(Lo) + 32;
189
    }
190
  }
191
#endif
192
473
  return Count;
193
473
}
Unexecuted instantiation: SparcModule.c:CountLeadingZeros_64
Unexecuted instantiation: ARMMapping.c:CountLeadingZeros_64
Unexecuted instantiation: AArch64Mapping.c:CountLeadingZeros_64
Unexecuted instantiation: PPCMapping.c:CountLeadingZeros_64
Unexecuted instantiation: SparcMapping.c:CountLeadingZeros_64
Unexecuted instantiation: XCoreDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: XCoreInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: M68KDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: TMS320C64xDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: RISCVDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: TriCoreDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: HPPADisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: XtensaMapping.c:CountLeadingZeros_64
Unexecuted instantiation: ARMDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: ARMDisassemblerExtension.c:CountLeadingZeros_64
Unexecuted instantiation: ARMInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: AArch64Disassembler.c:CountLeadingZeros_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountLeadingZeros_64
AArch64InstPrinter.c:CountLeadingZeros_64
Line
Count
Source
149
473
{
150
473
  unsigned Count; // result
151
473
#if __GNUC__ >= 4
152
  // PowerPC is defined for __builtin_clzll(0)
153
473
#if !defined(__ppc__) && !defined(__ppc64__)
154
473
  if (!Value)
155
0
    return 64;
156
473
#endif
157
473
  Count = __builtin_clzll(Value);
158
#else
159
#ifndef _MSC_VER
160
  unsigned Shift;
161
  if (sizeof(long) == sizeof(int64_t)) {
162
    if (!Value)
163
      return 64;
164
    Count = 0;
165
    // bisection method for count leading zeros
166
    for (Shift = 64 >> 1; Shift; Shift >>= 1) {
167
      uint64_t Tmp = Value >> Shift;
168
      if (Tmp) {
169
        Value = Tmp;
170
      } else {
171
        Count |= Shift;
172
      }
173
    }
174
  } else
175
#endif
176
  {
177
    // get hi portion
178
    uint32_t Hi = Hi_32(Value);
179
180
    // if some bits in hi portion
181
    if (Hi) {
182
      // leading zeros in hi portion plus all bits in lo portion
183
      Count = CountLeadingZeros_32(Hi);
184
    } else {
185
      // get lo portion
186
      uint32_t Lo = Lo_32(Value);
187
      // same as 32 bit value
188
      Count = CountLeadingZeros_32(Lo) + 32;
189
    }
190
  }
191
#endif
192
473
  return Count;
193
473
}
Unexecuted instantiation: MipsDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: PPCDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: PPCInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: SparcDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: SparcDisassemblerExtension.c:CountLeadingZeros_64
Unexecuted instantiation: SparcInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: SystemZDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: SystemZInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: TriCoreInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: LoongArchDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: XtensaDisassembler.c:CountLeadingZeros_64
Unexecuted instantiation: XtensaInstPrinter.c:CountLeadingZeros_64
Unexecuted instantiation: ARCDisassembler.c:CountLeadingZeros_64
194
195
/// CountLeadingOnes_64 - This function performs the operation
196
/// of counting the number of ones from the most significant bit to the first
197
/// zero bit (64 bit edition.)
198
/// Returns 64 if the word is all ones.
199
static inline unsigned CountLeadingOnes_64(uint64_t Value)
200
473
{
201
473
  return CountLeadingZeros_64(~Value);
202
473
}
Unexecuted instantiation: SparcModule.c:CountLeadingOnes_64
Unexecuted instantiation: ARMMapping.c:CountLeadingOnes_64
Unexecuted instantiation: AArch64Mapping.c:CountLeadingOnes_64
Unexecuted instantiation: PPCMapping.c:CountLeadingOnes_64
Unexecuted instantiation: SparcMapping.c:CountLeadingOnes_64
Unexecuted instantiation: XCoreDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: XCoreInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: M68KDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: TMS320C64xDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: RISCVDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: TriCoreDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: HPPADisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: XtensaMapping.c:CountLeadingOnes_64
Unexecuted instantiation: ARMDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: ARMDisassemblerExtension.c:CountLeadingOnes_64
Unexecuted instantiation: ARMInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: AArch64Disassembler.c:CountLeadingOnes_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountLeadingOnes_64
AArch64InstPrinter.c:CountLeadingOnes_64
Line
Count
Source
200
473
{
201
473
  return CountLeadingZeros_64(~Value);
202
473
}
Unexecuted instantiation: MipsDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: PPCDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: PPCInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: SparcDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: SparcDisassemblerExtension.c:CountLeadingOnes_64
Unexecuted instantiation: SparcInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: SystemZDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: SystemZInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: TriCoreInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: LoongArchDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: XtensaDisassembler.c:CountLeadingOnes_64
Unexecuted instantiation: XtensaInstPrinter.c:CountLeadingOnes_64
Unexecuted instantiation: ARCDisassembler.c:CountLeadingOnes_64
203
204
/// CountTrailingZeros_32 - this function performs the platform optimal form of
205
/// counting the number of zeros from the least significant bit to the first one
206
/// bit.  Ex. CountTrailingZeros_32(0xFF00FF00) == 8.
207
/// Returns 32 if the word is zero.
208
static inline unsigned CountTrailingZeros_32(uint32_t Value)
209
76.3k
{
210
76.3k
#if __GNUC__ >= 4
211
76.3k
  return Value ? __builtin_ctz(Value) : 32;
212
#else
213
  static const unsigned Mod37BitPosition[] = {
214
    32, 0, 1,  26, 2,  23, 27, 0,  3,  16, 24, 30, 28,
215
    11, 0, 13, 4,  7,  17, 0,  25, 22, 31, 15, 29, 10,
216
    12, 6, 0,  21, 14, 9,  5,  20, 8,  19, 18
217
  };
218
  // Replace "-Value" by "1+~Value" in the following commented code to avoid
219
  // MSVC warning C4146
220
  //    return Mod37BitPosition[(-Value & Value) % 37];
221
  return Mod37BitPosition[((1 + ~Value) & Value) % 37];
222
#endif
223
76.3k
}
Unexecuted instantiation: SparcModule.c:CountTrailingZeros_32
ARMMapping.c:CountTrailingZeros_32
Line
Count
Source
209
28.7k
{
210
28.7k
#if __GNUC__ >= 4
211
28.7k
  return Value ? __builtin_ctz(Value) : 32;
212
#else
213
  static const unsigned Mod37BitPosition[] = {
214
    32, 0, 1,  26, 2,  23, 27, 0,  3,  16, 24, 30, 28,
215
    11, 0, 13, 4,  7,  17, 0,  25, 22, 31, 15, 29, 10,
216
    12, 6, 0,  21, 14, 9,  5,  20, 8,  19, 18
217
  };
218
  // Replace "-Value" by "1+~Value" in the following commented code to avoid
219
  // MSVC warning C4146
220
  //    return Mod37BitPosition[(-Value & Value) % 37];
221
  return Mod37BitPosition[((1 + ~Value) & Value) % 37];
222
#endif
223
28.7k
}
Unexecuted instantiation: AArch64Mapping.c:CountTrailingZeros_32
Unexecuted instantiation: PPCMapping.c:CountTrailingZeros_32
Unexecuted instantiation: SparcMapping.c:CountTrailingZeros_32
Unexecuted instantiation: XCoreDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: XCoreInstPrinter.c:CountTrailingZeros_32
Unexecuted instantiation: M68KDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: TMS320C64xDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountTrailingZeros_32
Unexecuted instantiation: RISCVDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: TriCoreDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: HPPADisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: XtensaMapping.c:CountTrailingZeros_32
Unexecuted instantiation: ARMDisassemblerExtension.c:CountTrailingZeros_32
ARMInstPrinter.c:CountTrailingZeros_32
Line
Count
Source
209
47.1k
{
210
47.1k
#if __GNUC__ >= 4
211
47.1k
  return Value ? __builtin_ctz(Value) : 32;
212
#else
213
  static const unsigned Mod37BitPosition[] = {
214
    32, 0, 1,  26, 2,  23, 27, 0,  3,  16, 24, 30, 28,
215
    11, 0, 13, 4,  7,  17, 0,  25, 22, 31, 15, 29, 10,
216
    12, 6, 0,  21, 14, 9,  5,  20, 8,  19, 18
217
  };
218
  // Replace "-Value" by "1+~Value" in the following commented code to avoid
219
  // MSVC warning C4146
220
  //    return Mod37BitPosition[(-Value & Value) % 37];
221
  return Mod37BitPosition[((1 + ~Value) & Value) % 37];
222
#endif
223
47.1k
}
Unexecuted instantiation: AArch64Disassembler.c:CountTrailingZeros_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountTrailingZeros_32
Unexecuted instantiation: MipsDisassembler.c:CountTrailingZeros_32
PPCDisassembler.c:CountTrailingZeros_32
Line
Count
Source
209
458
{
210
458
#if __GNUC__ >= 4
211
458
  return Value ? __builtin_ctz(Value) : 32;
212
#else
213
  static const unsigned Mod37BitPosition[] = {
214
    32, 0, 1,  26, 2,  23, 27, 0,  3,  16, 24, 30, 28,
215
    11, 0, 13, 4,  7,  17, 0,  25, 22, 31, 15, 29, 10,
216
    12, 6, 0,  21, 14, 9,  5,  20, 8,  19, 18
217
  };
218
  // Replace "-Value" by "1+~Value" in the following commented code to avoid
219
  // MSVC warning C4146
220
  //    return Mod37BitPosition[(-Value & Value) % 37];
221
  return Mod37BitPosition[((1 + ~Value) & Value) % 37];
222
#endif
223
458
}
Unexecuted instantiation: PPCInstPrinter.c:CountTrailingZeros_32
Unexecuted instantiation: SparcDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: SparcDisassemblerExtension.c:CountTrailingZeros_32
Unexecuted instantiation: SparcInstPrinter.c:CountTrailingZeros_32
Unexecuted instantiation: SystemZDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: SystemZInstPrinter.c:CountTrailingZeros_32
Unexecuted instantiation: TriCoreInstPrinter.c:CountTrailingZeros_32
Unexecuted instantiation: LoongArchDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: XtensaDisassembler.c:CountTrailingZeros_32
Unexecuted instantiation: XtensaInstPrinter.c:CountTrailingZeros_32
Unexecuted instantiation: ARCDisassembler.c:CountTrailingZeros_32
224
225
// Count trailing zeros as in:
226
// https://graphics.stanford.edu/~seander/bithacks.html#ZerosOnRightParallel
227
static inline unsigned CountTrailingZeros_8(uint8_t Value)
228
21.4k
{
229
21.4k
  uint8_t c = 8;
230
21.4k
  Value &= -((int8_t)Value);
231
21.4k
  if (Value)
232
21.4k
    c--;
233
21.4k
  if (Value & 0x0F)
234
21.4k
    c -= 4;
235
21.4k
  if (Value & 0x33)
236
18.7k
    c -= 2;
237
21.4k
  if (Value & 0x55)
238
18.1k
    c -= 1;
239
21.4k
  return c;
240
21.4k
}
Unexecuted instantiation: SparcModule.c:CountTrailingZeros_8
Unexecuted instantiation: ARMMapping.c:CountTrailingZeros_8
Unexecuted instantiation: AArch64Mapping.c:CountTrailingZeros_8
Unexecuted instantiation: PPCMapping.c:CountTrailingZeros_8
Unexecuted instantiation: SparcMapping.c:CountTrailingZeros_8
Unexecuted instantiation: XCoreDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: XCoreInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: M68KDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: TMS320C64xDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: RISCVDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: TriCoreDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: HPPADisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: XtensaMapping.c:CountTrailingZeros_8
Unexecuted instantiation: ARMDisassembler.c:CountTrailingZeros_8
ARMDisassemblerExtension.c:CountTrailingZeros_8
Line
Count
Source
228
21.4k
{
229
21.4k
  uint8_t c = 8;
230
21.4k
  Value &= -((int8_t)Value);
231
21.4k
  if (Value)
232
21.4k
    c--;
233
21.4k
  if (Value & 0x0F)
234
21.4k
    c -= 4;
235
21.4k
  if (Value & 0x33)
236
18.7k
    c -= 2;
237
21.4k
  if (Value & 0x55)
238
18.1k
    c -= 1;
239
21.4k
  return c;
240
21.4k
}
Unexecuted instantiation: ARMInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: AArch64Disassembler.c:CountTrailingZeros_8
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountTrailingZeros_8
Unexecuted instantiation: AArch64InstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: MipsDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: PPCDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: PPCInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: SparcDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: SparcDisassemblerExtension.c:CountTrailingZeros_8
Unexecuted instantiation: SparcInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: SystemZDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: SystemZInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: TriCoreInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: LoongArchDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: XtensaDisassembler.c:CountTrailingZeros_8
Unexecuted instantiation: XtensaInstPrinter.c:CountTrailingZeros_8
Unexecuted instantiation: ARCDisassembler.c:CountTrailingZeros_8
241
242
/// CountTrailingOnes_32 - this function performs the operation of
243
/// counting the number of ones from the least significant bit to the first zero
244
/// bit.  Ex. CountTrailingOnes_32(0x00FF00FF) == 8.
245
/// Returns 32 if the word is all ones.
246
static inline unsigned CountTrailingOnes_32(uint32_t Value)
247
0
{
248
0
  return CountTrailingZeros_32(~Value);
249
0
}
Unexecuted instantiation: SparcModule.c:CountTrailingOnes_32
Unexecuted instantiation: ARMMapping.c:CountTrailingOnes_32
Unexecuted instantiation: AArch64Mapping.c:CountTrailingOnes_32
Unexecuted instantiation: PPCMapping.c:CountTrailingOnes_32
Unexecuted instantiation: SparcMapping.c:CountTrailingOnes_32
Unexecuted instantiation: XCoreDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: XCoreInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: M68KDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: TMS320C64xDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: RISCVDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: TriCoreDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: HPPADisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: XtensaMapping.c:CountTrailingOnes_32
Unexecuted instantiation: ARMDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: ARMDisassemblerExtension.c:CountTrailingOnes_32
Unexecuted instantiation: ARMInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: AArch64Disassembler.c:CountTrailingOnes_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountTrailingOnes_32
Unexecuted instantiation: MipsDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: PPCDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: PPCInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: SparcDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: SparcDisassemblerExtension.c:CountTrailingOnes_32
Unexecuted instantiation: SparcInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: SystemZDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: SystemZInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: TriCoreInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: LoongArchDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: XtensaDisassembler.c:CountTrailingOnes_32
Unexecuted instantiation: XtensaInstPrinter.c:CountTrailingOnes_32
Unexecuted instantiation: ARCDisassembler.c:CountTrailingOnes_32
250
251
/// CountTrailingZeros_64 - This function performs the platform optimal form
252
/// of counting the number of zeros from the least significant bit to the first
253
/// one bit (64 bit edition.)
254
/// Returns 64 if the word is zero.
255
static inline unsigned CountTrailingZeros_64(uint64_t Value)
256
7.57k
{
257
7.57k
#if __GNUC__ >= 4
258
7.57k
  return Value ? __builtin_ctzll(Value) : 64;
259
#else
260
  static const unsigned Mod67Position[] = {
261
    64, 0,  1,  39, 2,  15, 40, 23, 3,  12, 16, 59, 41, 19,
262
    24, 54, 4,  64, 13, 10, 17, 62, 60, 28, 42, 30, 20, 51,
263
    25, 44, 55, 47, 5,  32, 65, 38, 14, 22, 11, 58, 18, 53,
264
    63, 9,  61, 27, 29, 50, 43, 46, 31, 37, 21, 57, 52, 8,
265
    26, 49, 45, 36, 56, 7,  48, 35, 6,  34, 33, 0
266
  };
267
  // Replace "-Value" by "1+~Value" in the following commented code to avoid
268
  // MSVC warning C4146
269
  //    return Mod67Position[(-Value & Value) % 67];
270
  return Mod67Position[((1 + ~Value) & Value) % 67];
271
#endif
272
7.57k
}
Unexecuted instantiation: SparcModule.c:CountTrailingZeros_64
Unexecuted instantiation: ARMMapping.c:CountTrailingZeros_64
Unexecuted instantiation: AArch64Mapping.c:CountTrailingZeros_64
Unexecuted instantiation: PPCMapping.c:CountTrailingZeros_64
Unexecuted instantiation: SparcMapping.c:CountTrailingZeros_64
Unexecuted instantiation: XCoreDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: XCoreInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: M68KDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: TMS320C64xDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: RISCVDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: TriCoreDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: HPPADisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: XtensaMapping.c:CountTrailingZeros_64
Unexecuted instantiation: ARMDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: ARMDisassemblerExtension.c:CountTrailingZeros_64
Unexecuted instantiation: ARMInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: AArch64Disassembler.c:CountTrailingZeros_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountTrailingZeros_64
AArch64InstPrinter.c:CountTrailingZeros_64
Line
Count
Source
256
7.57k
{
257
7.57k
#if __GNUC__ >= 4
258
7.57k
  return Value ? __builtin_ctzll(Value) : 64;
259
#else
260
  static const unsigned Mod67Position[] = {
261
    64, 0,  1,  39, 2,  15, 40, 23, 3,  12, 16, 59, 41, 19,
262
    24, 54, 4,  64, 13, 10, 17, 62, 60, 28, 42, 30, 20, 51,
263
    25, 44, 55, 47, 5,  32, 65, 38, 14, 22, 11, 58, 18, 53,
264
    63, 9,  61, 27, 29, 50, 43, 46, 31, 37, 21, 57, 52, 8,
265
    26, 49, 45, 36, 56, 7,  48, 35, 6,  34, 33, 0
266
  };
267
  // Replace "-Value" by "1+~Value" in the following commented code to avoid
268
  // MSVC warning C4146
269
  //    return Mod67Position[(-Value & Value) % 67];
270
  return Mod67Position[((1 + ~Value) & Value) % 67];
271
#endif
272
7.57k
}
Unexecuted instantiation: MipsDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: PPCInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: SparcDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: SparcDisassemblerExtension.c:CountTrailingZeros_64
Unexecuted instantiation: SparcInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: SystemZDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: SystemZInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: TriCoreInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: LoongArchDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: XtensaDisassembler.c:CountTrailingZeros_64
Unexecuted instantiation: XtensaInstPrinter.c:CountTrailingZeros_64
Unexecuted instantiation: ARCDisassembler.c:CountTrailingZeros_64
273
274
/// CountTrailingOnes_64 - This function performs the operation
275
/// of counting the number of ones from the least significant bit to the first
276
/// zero bit (64 bit edition.)
277
/// Returns 64 if the word is all ones.
278
static inline unsigned CountTrailingOnes_64(uint64_t Value)
279
4.02k
{
280
4.02k
  return CountTrailingZeros_64(~Value);
281
4.02k
}
Unexecuted instantiation: SparcModule.c:CountTrailingOnes_64
Unexecuted instantiation: ARMMapping.c:CountTrailingOnes_64
Unexecuted instantiation: AArch64Mapping.c:CountTrailingOnes_64
Unexecuted instantiation: PPCMapping.c:CountTrailingOnes_64
Unexecuted instantiation: SparcMapping.c:CountTrailingOnes_64
Unexecuted instantiation: XCoreDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: XCoreInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: M68KDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: TMS320C64xDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: RISCVDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: TriCoreDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: HPPADisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: XtensaMapping.c:CountTrailingOnes_64
Unexecuted instantiation: ARMDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: ARMDisassemblerExtension.c:CountTrailingOnes_64
Unexecuted instantiation: ARMInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: AArch64Disassembler.c:CountTrailingOnes_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountTrailingOnes_64
AArch64InstPrinter.c:CountTrailingOnes_64
Line
Count
Source
279
4.02k
{
280
4.02k
  return CountTrailingZeros_64(~Value);
281
4.02k
}
Unexecuted instantiation: MipsDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: PPCDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: PPCInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: SparcDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: SparcDisassemblerExtension.c:CountTrailingOnes_64
Unexecuted instantiation: SparcInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: SystemZDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: SystemZInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: TriCoreInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: LoongArchDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: XtensaDisassembler.c:CountTrailingOnes_64
Unexecuted instantiation: XtensaInstPrinter.c:CountTrailingOnes_64
Unexecuted instantiation: ARCDisassembler.c:CountTrailingOnes_64
282
283
/// CountPopulation_32 - this function counts the number of set bits in a value.
284
/// Ex. CountPopulation(0xF000F000) = 8
285
/// Returns 0 if the word is zero.
286
static inline unsigned CountPopulation_32(uint32_t Value)
287
0
{
288
0
#if __GNUC__ >= 4
289
0
  return __builtin_popcount(Value);
290
0
#else
291
0
  uint32_t v = Value - ((Value >> 1) & 0x55555555);
292
0
  v = (v & 0x33333333) + ((v >> 2) & 0x33333333);
293
0
  return (((v + (v >> 4)) & 0xF0F0F0F) * 0x1010101) >> 24;
294
0
#endif
295
0
}
Unexecuted instantiation: SparcModule.c:CountPopulation_32
Unexecuted instantiation: ARMMapping.c:CountPopulation_32
Unexecuted instantiation: AArch64Mapping.c:CountPopulation_32
Unexecuted instantiation: PPCMapping.c:CountPopulation_32
Unexecuted instantiation: SparcMapping.c:CountPopulation_32
Unexecuted instantiation: XCoreDisassembler.c:CountPopulation_32
Unexecuted instantiation: XCoreInstPrinter.c:CountPopulation_32
Unexecuted instantiation: M68KDisassembler.c:CountPopulation_32
Unexecuted instantiation: TMS320C64xDisassembler.c:CountPopulation_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountPopulation_32
Unexecuted instantiation: RISCVDisassembler.c:CountPopulation_32
Unexecuted instantiation: TriCoreDisassembler.c:CountPopulation_32
Unexecuted instantiation: HPPADisassembler.c:CountPopulation_32
Unexecuted instantiation: XtensaMapping.c:CountPopulation_32
Unexecuted instantiation: ARMDisassembler.c:CountPopulation_32
Unexecuted instantiation: ARMDisassemblerExtension.c:CountPopulation_32
Unexecuted instantiation: ARMInstPrinter.c:CountPopulation_32
Unexecuted instantiation: AArch64Disassembler.c:CountPopulation_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountPopulation_32
Unexecuted instantiation: AArch64InstPrinter.c:CountPopulation_32
Unexecuted instantiation: MipsDisassembler.c:CountPopulation_32
Unexecuted instantiation: PPCDisassembler.c:CountPopulation_32
Unexecuted instantiation: PPCInstPrinter.c:CountPopulation_32
Unexecuted instantiation: SparcDisassembler.c:CountPopulation_32
Unexecuted instantiation: SparcDisassemblerExtension.c:CountPopulation_32
Unexecuted instantiation: SparcInstPrinter.c:CountPopulation_32
Unexecuted instantiation: SystemZDisassembler.c:CountPopulation_32
Unexecuted instantiation: SystemZInstPrinter.c:CountPopulation_32
Unexecuted instantiation: TriCoreInstPrinter.c:CountPopulation_32
Unexecuted instantiation: LoongArchDisassembler.c:CountPopulation_32
Unexecuted instantiation: XtensaDisassembler.c:CountPopulation_32
Unexecuted instantiation: XtensaInstPrinter.c:CountPopulation_32
Unexecuted instantiation: ARCDisassembler.c:CountPopulation_32
296
297
/// CountPopulation_64 - this function counts the number of set bits in a value,
298
/// (64 bit edition.)
299
static inline unsigned CountPopulation_64(uint64_t Value)
300
0
{
301
0
#if __GNUC__ >= 4
302
0
  return __builtin_popcountll(Value);
303
0
#else
304
0
  uint64_t v = Value - ((Value >> 1) & 0x5555555555555555ULL);
305
0
  v = (v & 0x3333333333333333ULL) + ((v >> 2) & 0x3333333333333333ULL);
306
0
  v = (v + (v >> 4)) & 0x0F0F0F0F0F0F0F0FULL;
307
0
  return (uint64_t)((v * 0x0101010101010101ULL) >> 56);
308
0
#endif
309
0
}
Unexecuted instantiation: SparcModule.c:CountPopulation_64
Unexecuted instantiation: ARMMapping.c:CountPopulation_64
Unexecuted instantiation: AArch64Mapping.c:CountPopulation_64
Unexecuted instantiation: PPCMapping.c:CountPopulation_64
Unexecuted instantiation: SparcMapping.c:CountPopulation_64
Unexecuted instantiation: XCoreDisassembler.c:CountPopulation_64
Unexecuted instantiation: XCoreInstPrinter.c:CountPopulation_64
Unexecuted instantiation: M68KDisassembler.c:CountPopulation_64
Unexecuted instantiation: TMS320C64xDisassembler.c:CountPopulation_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:CountPopulation_64
Unexecuted instantiation: RISCVDisassembler.c:CountPopulation_64
Unexecuted instantiation: TriCoreDisassembler.c:CountPopulation_64
Unexecuted instantiation: HPPADisassembler.c:CountPopulation_64
Unexecuted instantiation: XtensaMapping.c:CountPopulation_64
Unexecuted instantiation: ARMDisassembler.c:CountPopulation_64
Unexecuted instantiation: ARMDisassemblerExtension.c:CountPopulation_64
Unexecuted instantiation: ARMInstPrinter.c:CountPopulation_64
Unexecuted instantiation: AArch64Disassembler.c:CountPopulation_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:CountPopulation_64
Unexecuted instantiation: AArch64InstPrinter.c:CountPopulation_64
Unexecuted instantiation: MipsDisassembler.c:CountPopulation_64
Unexecuted instantiation: PPCDisassembler.c:CountPopulation_64
Unexecuted instantiation: PPCInstPrinter.c:CountPopulation_64
Unexecuted instantiation: SparcDisassembler.c:CountPopulation_64
Unexecuted instantiation: SparcDisassemblerExtension.c:CountPopulation_64
Unexecuted instantiation: SparcInstPrinter.c:CountPopulation_64
Unexecuted instantiation: SystemZDisassembler.c:CountPopulation_64
Unexecuted instantiation: SystemZInstPrinter.c:CountPopulation_64
Unexecuted instantiation: TriCoreInstPrinter.c:CountPopulation_64
Unexecuted instantiation: LoongArchDisassembler.c:CountPopulation_64
Unexecuted instantiation: XtensaDisassembler.c:CountPopulation_64
Unexecuted instantiation: XtensaInstPrinter.c:CountPopulation_64
Unexecuted instantiation: ARCDisassembler.c:CountPopulation_64
310
311
/// Log2_32 - This function returns the floor log base 2 of the specified value,
312
/// UINT_MAX if the value is zero. (32 bit edition.)
313
/// Ex. Log2_32(32) == 5, Log2_32(1) == 0, Log2_32(0) == -1, Log2_32(6) == 2
314
static inline unsigned Log2_32(uint32_t Value)
315
26.2k
{
316
26.2k
  if (Value == 0) {
317
0
    return UINT_MAX;
318
0
  }
319
26.2k
  return 31 - CountLeadingZeros_32(Value);
320
26.2k
}
Unexecuted instantiation: SparcModule.c:Log2_32
Unexecuted instantiation: ARMMapping.c:Log2_32
AArch64Mapping.c:Log2_32
Line
Count
Source
315
13.1k
{
316
13.1k
  if (Value == 0) {
317
0
    return UINT_MAX;
318
0
  }
319
13.1k
  return 31 - CountLeadingZeros_32(Value);
320
13.1k
}
Unexecuted instantiation: PPCMapping.c:Log2_32
Unexecuted instantiation: SparcMapping.c:Log2_32
Unexecuted instantiation: XCoreDisassembler.c:Log2_32
Unexecuted instantiation: XCoreInstPrinter.c:Log2_32
Unexecuted instantiation: M68KDisassembler.c:Log2_32
Unexecuted instantiation: TMS320C64xDisassembler.c:Log2_32
Unexecuted instantiation: TMS320C64xInstPrinter.c:Log2_32
Unexecuted instantiation: RISCVDisassembler.c:Log2_32
Unexecuted instantiation: TriCoreDisassembler.c:Log2_32
Unexecuted instantiation: HPPADisassembler.c:Log2_32
Unexecuted instantiation: XtensaMapping.c:Log2_32
Unexecuted instantiation: ARMDisassembler.c:Log2_32
Unexecuted instantiation: ARMDisassemblerExtension.c:Log2_32
Unexecuted instantiation: ARMInstPrinter.c:Log2_32
Unexecuted instantiation: AArch64Disassembler.c:Log2_32
Unexecuted instantiation: AArch64DisassemblerExtension.c:Log2_32
AArch64InstPrinter.c:Log2_32
Line
Count
Source
315
13.1k
{
316
13.1k
  if (Value == 0) {
317
0
    return UINT_MAX;
318
0
  }
319
13.1k
  return 31 - CountLeadingZeros_32(Value);
320
13.1k
}
Unexecuted instantiation: MipsDisassembler.c:Log2_32
Unexecuted instantiation: PPCDisassembler.c:Log2_32
Unexecuted instantiation: PPCInstPrinter.c:Log2_32
Unexecuted instantiation: SparcDisassembler.c:Log2_32
Unexecuted instantiation: SparcDisassemblerExtension.c:Log2_32
Unexecuted instantiation: SparcInstPrinter.c:Log2_32
Unexecuted instantiation: SystemZDisassembler.c:Log2_32
Unexecuted instantiation: SystemZInstPrinter.c:Log2_32
Unexecuted instantiation: TriCoreInstPrinter.c:Log2_32
Unexecuted instantiation: LoongArchDisassembler.c:Log2_32
Unexecuted instantiation: XtensaDisassembler.c:Log2_32
Unexecuted instantiation: XtensaInstPrinter.c:Log2_32
Unexecuted instantiation: ARCDisassembler.c:Log2_32
321
322
/// Log2_64 - This function returns the floor log base 2 of the specified value,
323
/// UINT_MAX if the value is zero. (64 bit edition.)
324
static inline unsigned Log2_64(uint64_t Value)
325
0
{
326
0
  if (Value == 0) {
327
0
    return UINT32_MAX;
328
0
  }
329
0
  return 63 - CountLeadingZeros_64(Value);
330
0
}
Unexecuted instantiation: SparcModule.c:Log2_64
Unexecuted instantiation: ARMMapping.c:Log2_64
Unexecuted instantiation: AArch64Mapping.c:Log2_64
Unexecuted instantiation: PPCMapping.c:Log2_64
Unexecuted instantiation: SparcMapping.c:Log2_64
Unexecuted instantiation: XCoreDisassembler.c:Log2_64
Unexecuted instantiation: XCoreInstPrinter.c:Log2_64
Unexecuted instantiation: M68KDisassembler.c:Log2_64
Unexecuted instantiation: TMS320C64xDisassembler.c:Log2_64
Unexecuted instantiation: TMS320C64xInstPrinter.c:Log2_64
Unexecuted instantiation: RISCVDisassembler.c:Log2_64
Unexecuted instantiation: TriCoreDisassembler.c:Log2_64
Unexecuted instantiation: HPPADisassembler.c:Log2_64
Unexecuted instantiation: XtensaMapping.c:Log2_64
Unexecuted instantiation: ARMDisassembler.c:Log2_64
Unexecuted instantiation: ARMDisassemblerExtension.c:Log2_64
Unexecuted instantiation: ARMInstPrinter.c:Log2_64
Unexecuted instantiation: AArch64Disassembler.c:Log2_64
Unexecuted instantiation: AArch64DisassemblerExtension.c:Log2_64
Unexecuted instantiation: AArch64InstPrinter.c:Log2_64
Unexecuted instantiation: MipsDisassembler.c:Log2_64
Unexecuted instantiation: PPCDisassembler.c:Log2_64
Unexecuted instantiation: PPCInstPrinter.c:Log2_64
Unexecuted instantiation: SparcDisassembler.c:Log2_64
Unexecuted instantiation: SparcDisassemblerExtension.c:Log2_64
Unexecuted instantiation: SparcInstPrinter.c:Log2_64
Unexecuted instantiation: SystemZDisassembler.c:Log2_64
Unexecuted instantiation: SystemZInstPrinter.c:Log2_64
Unexecuted instantiation: TriCoreInstPrinter.c:Log2_64
Unexecuted instantiation: LoongArchDisassembler.c:Log2_64
Unexecuted instantiation: XtensaDisassembler.c:Log2_64
Unexecuted instantiation: XtensaInstPrinter.c:Log2_64
Unexecuted instantiation: ARCDisassembler.c:Log2_64
331
332
/// Log2_32_Ceil - This function returns the ceil log base 2 of the specified
333
/// value, 32 if the value is zero. (32 bit edition).
334
/// Ex. Log2_32_Ceil(32) == 5, Log2_32_Ceil(1) == 0, Log2_32_Ceil(6) == 3
335
static inline unsigned Log2_32_Ceil(uint32_t Value)
336
0
{
337
0
  return 32 - CountLeadingZeros_32(Value - 1);
338
0
}
Unexecuted instantiation: SparcModule.c:Log2_32_Ceil
Unexecuted instantiation: ARMMapping.c:Log2_32_Ceil
Unexecuted instantiation: AArch64Mapping.c:Log2_32_Ceil
Unexecuted instantiation: PPCMapping.c:Log2_32_Ceil
Unexecuted instantiation: SparcMapping.c:Log2_32_Ceil
Unexecuted instantiation: XCoreDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: XCoreInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: M68KDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: TMS320C64xDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: TMS320C64xInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: RISCVDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: TriCoreDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: HPPADisassembler.c:Log2_32_Ceil
Unexecuted instantiation: XtensaMapping.c:Log2_32_Ceil
Unexecuted instantiation: ARMDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: ARMDisassemblerExtension.c:Log2_32_Ceil
Unexecuted instantiation: ARMInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: AArch64Disassembler.c:Log2_32_Ceil
Unexecuted instantiation: AArch64DisassemblerExtension.c:Log2_32_Ceil
Unexecuted instantiation: AArch64InstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: MipsDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: PPCDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: PPCInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: SparcDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: SparcDisassemblerExtension.c:Log2_32_Ceil
Unexecuted instantiation: SparcInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: SystemZDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: SystemZInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: TriCoreInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: LoongArchDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: XtensaDisassembler.c:Log2_32_Ceil
Unexecuted instantiation: XtensaInstPrinter.c:Log2_32_Ceil
Unexecuted instantiation: ARCDisassembler.c:Log2_32_Ceil
339
340
/// Log2_64_Ceil - This function returns the ceil log base 2 of the specified
341
/// value, 64 if the value is zero. (64 bit edition.)
342
static inline unsigned Log2_64_Ceil(uint64_t Value)
343
0
{
344
0
  return 64 - CountLeadingZeros_64(Value - 1);
345
0
}
Unexecuted instantiation: SparcModule.c:Log2_64_Ceil
Unexecuted instantiation: ARMMapping.c:Log2_64_Ceil
Unexecuted instantiation: AArch64Mapping.c:Log2_64_Ceil
Unexecuted instantiation: PPCMapping.c:Log2_64_Ceil
Unexecuted instantiation: SparcMapping.c:Log2_64_Ceil
Unexecuted instantiation: XCoreDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: XCoreInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: M68KDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: TMS320C64xDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: TMS320C64xInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: RISCVDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: TriCoreDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: HPPADisassembler.c:Log2_64_Ceil
Unexecuted instantiation: XtensaMapping.c:Log2_64_Ceil
Unexecuted instantiation: ARMDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: ARMDisassemblerExtension.c:Log2_64_Ceil
Unexecuted instantiation: ARMInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: AArch64Disassembler.c:Log2_64_Ceil
Unexecuted instantiation: AArch64DisassemblerExtension.c:Log2_64_Ceil
Unexecuted instantiation: AArch64InstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: MipsDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: PPCDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: PPCInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: SparcDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: SparcDisassemblerExtension.c:Log2_64_Ceil
Unexecuted instantiation: SparcInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: SystemZDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: SystemZInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: TriCoreInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: LoongArchDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: XtensaDisassembler.c:Log2_64_Ceil
Unexecuted instantiation: XtensaInstPrinter.c:Log2_64_Ceil
Unexecuted instantiation: ARCDisassembler.c:Log2_64_Ceil
346
347
/// GreatestCommonDivisor64 - Return the greatest common divisor of the two
348
/// values using Euclid's algorithm.
349
static inline uint64_t GreatestCommonDivisor64(uint64_t A, uint64_t B)
350
0
{
351
0
  while (B) {
352
0
    uint64_t T = B;
353
0
    B = A % B;
354
0
    A = T;
355
0
  }
356
0
  return A;
357
0
}
Unexecuted instantiation: SparcModule.c:GreatestCommonDivisor64
Unexecuted instantiation: ARMMapping.c:GreatestCommonDivisor64
Unexecuted instantiation: AArch64Mapping.c:GreatestCommonDivisor64
Unexecuted instantiation: PPCMapping.c:GreatestCommonDivisor64
Unexecuted instantiation: SparcMapping.c:GreatestCommonDivisor64
Unexecuted instantiation: XCoreDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: XCoreInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: M68KDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: TMS320C64xDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: TMS320C64xInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: RISCVDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: TriCoreDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: HPPADisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: XtensaMapping.c:GreatestCommonDivisor64
Unexecuted instantiation: ARMDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: ARMDisassemblerExtension.c:GreatestCommonDivisor64
Unexecuted instantiation: ARMInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: AArch64Disassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: AArch64DisassemblerExtension.c:GreatestCommonDivisor64
Unexecuted instantiation: AArch64InstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: MipsDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: PPCDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: PPCInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: SparcDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: SparcDisassemblerExtension.c:GreatestCommonDivisor64
Unexecuted instantiation: SparcInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: SystemZDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: SystemZInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: TriCoreInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: LoongArchDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: XtensaDisassembler.c:GreatestCommonDivisor64
Unexecuted instantiation: XtensaInstPrinter.c:GreatestCommonDivisor64
Unexecuted instantiation: ARCDisassembler.c:GreatestCommonDivisor64
358
359
/// BitsToDouble - This function takes a 64-bit integer and returns the bit
360
/// equivalent double.
361
static inline double BitsToDouble(uint64_t Bits)
362
0
{
363
0
  union {
364
0
    uint64_t L;
365
0
    double D;
366
0
  } T;
367
0
  T.L = Bits;
368
0
  return T.D;
369
0
}
Unexecuted instantiation: SparcModule.c:BitsToDouble
Unexecuted instantiation: ARMMapping.c:BitsToDouble
Unexecuted instantiation: AArch64Mapping.c:BitsToDouble
Unexecuted instantiation: PPCMapping.c:BitsToDouble
Unexecuted instantiation: SparcMapping.c:BitsToDouble
Unexecuted instantiation: XCoreDisassembler.c:BitsToDouble
Unexecuted instantiation: XCoreInstPrinter.c:BitsToDouble
Unexecuted instantiation: M68KDisassembler.c:BitsToDouble
Unexecuted instantiation: TMS320C64xDisassembler.c:BitsToDouble
Unexecuted instantiation: TMS320C64xInstPrinter.c:BitsToDouble
Unexecuted instantiation: RISCVDisassembler.c:BitsToDouble
Unexecuted instantiation: TriCoreDisassembler.c:BitsToDouble
Unexecuted instantiation: HPPADisassembler.c:BitsToDouble
Unexecuted instantiation: XtensaMapping.c:BitsToDouble
Unexecuted instantiation: ARMDisassembler.c:BitsToDouble
Unexecuted instantiation: ARMDisassemblerExtension.c:BitsToDouble
Unexecuted instantiation: ARMInstPrinter.c:BitsToDouble
Unexecuted instantiation: AArch64Disassembler.c:BitsToDouble
Unexecuted instantiation: AArch64DisassemblerExtension.c:BitsToDouble
Unexecuted instantiation: AArch64InstPrinter.c:BitsToDouble
Unexecuted instantiation: MipsDisassembler.c:BitsToDouble
Unexecuted instantiation: PPCDisassembler.c:BitsToDouble
Unexecuted instantiation: PPCInstPrinter.c:BitsToDouble
Unexecuted instantiation: SparcDisassembler.c:BitsToDouble
Unexecuted instantiation: SparcDisassemblerExtension.c:BitsToDouble
Unexecuted instantiation: SparcInstPrinter.c:BitsToDouble
Unexecuted instantiation: SystemZDisassembler.c:BitsToDouble
Unexecuted instantiation: SystemZInstPrinter.c:BitsToDouble
Unexecuted instantiation: TriCoreInstPrinter.c:BitsToDouble
Unexecuted instantiation: LoongArchDisassembler.c:BitsToDouble
Unexecuted instantiation: XtensaDisassembler.c:BitsToDouble
Unexecuted instantiation: XtensaInstPrinter.c:BitsToDouble
Unexecuted instantiation: ARCDisassembler.c:BitsToDouble
370
371
/// BitsToFloat - This function takes a 32-bit integer and returns the bit
372
/// equivalent float.
373
static inline float BitsToFloat(uint32_t Bits)
374
3.23k
{
375
3.23k
  union {
376
3.23k
    uint32_t I;
377
3.23k
    float F;
378
3.23k
  } T;
379
3.23k
  T.I = Bits;
380
3.23k
  return T.F;
381
3.23k
}
Unexecuted instantiation: SparcModule.c:BitsToFloat
ARMMapping.c:BitsToFloat
Line
Count
Source
374
529
{
375
529
  union {
376
529
    uint32_t I;
377
529
    float F;
378
529
  } T;
379
529
  T.I = Bits;
380
529
  return T.F;
381
529
}
AArch64Mapping.c:BitsToFloat
Line
Count
Source
374
393
{
375
393
  union {
376
393
    uint32_t I;
377
393
    float F;
378
393
  } T;
379
393
  T.I = Bits;
380
393
  return T.F;
381
393
}
Unexecuted instantiation: PPCMapping.c:BitsToFloat
Unexecuted instantiation: SparcMapping.c:BitsToFloat
Unexecuted instantiation: XCoreDisassembler.c:BitsToFloat
Unexecuted instantiation: XCoreInstPrinter.c:BitsToFloat
M68KDisassembler.c:BitsToFloat
Line
Count
Source
374
1.38k
{
375
1.38k
  union {
376
1.38k
    uint32_t I;
377
1.38k
    float F;
378
1.38k
  } T;
379
1.38k
  T.I = Bits;
380
1.38k
  return T.F;
381
1.38k
}
Unexecuted instantiation: TMS320C64xDisassembler.c:BitsToFloat
Unexecuted instantiation: TMS320C64xInstPrinter.c:BitsToFloat
Unexecuted instantiation: RISCVDisassembler.c:BitsToFloat
Unexecuted instantiation: TriCoreDisassembler.c:BitsToFloat
Unexecuted instantiation: HPPADisassembler.c:BitsToFloat
Unexecuted instantiation: XtensaMapping.c:BitsToFloat
Unexecuted instantiation: ARMDisassembler.c:BitsToFloat
Unexecuted instantiation: ARMDisassemblerExtension.c:BitsToFloat
ARMInstPrinter.c:BitsToFloat
Line
Count
Source
374
529
{
375
529
  union {
376
529
    uint32_t I;
377
529
    float F;
378
529
  } T;
379
529
  T.I = Bits;
380
529
  return T.F;
381
529
}
Unexecuted instantiation: AArch64Disassembler.c:BitsToFloat
Unexecuted instantiation: AArch64DisassemblerExtension.c:BitsToFloat
AArch64InstPrinter.c:BitsToFloat
Line
Count
Source
374
393
{
375
393
  union {
376
393
    uint32_t I;
377
393
    float F;
378
393
  } T;
379
393
  T.I = Bits;
380
393
  return T.F;
381
393
}
Unexecuted instantiation: MipsDisassembler.c:BitsToFloat
Unexecuted instantiation: PPCDisassembler.c:BitsToFloat
Unexecuted instantiation: PPCInstPrinter.c:BitsToFloat
Unexecuted instantiation: SparcDisassembler.c:BitsToFloat
Unexecuted instantiation: SparcDisassemblerExtension.c:BitsToFloat
Unexecuted instantiation: SparcInstPrinter.c:BitsToFloat
Unexecuted instantiation: SystemZDisassembler.c:BitsToFloat
Unexecuted instantiation: SystemZInstPrinter.c:BitsToFloat
Unexecuted instantiation: TriCoreInstPrinter.c:BitsToFloat
Unexecuted instantiation: LoongArchDisassembler.c:BitsToFloat
Unexecuted instantiation: XtensaDisassembler.c:BitsToFloat
Unexecuted instantiation: XtensaInstPrinter.c:BitsToFloat
Unexecuted instantiation: ARCDisassembler.c:BitsToFloat
382
383
/// DoubleToBits - This function takes a double and returns the bit
384
/// equivalent 64-bit integer.  Note that copying doubles around
385
/// changes the bits of NaNs on some hosts, notably x86, so this
386
/// routine cannot be used if these bits are needed.
387
static inline uint64_t DoubleToBits(double Double)
388
0
{
389
0
  union {
390
0
    uint64_t L;
391
0
    double D;
392
0
  } T;
393
0
  T.D = Double;
394
0
  return T.L;
395
0
}
Unexecuted instantiation: SparcModule.c:DoubleToBits
Unexecuted instantiation: ARMMapping.c:DoubleToBits
Unexecuted instantiation: AArch64Mapping.c:DoubleToBits
Unexecuted instantiation: PPCMapping.c:DoubleToBits
Unexecuted instantiation: SparcMapping.c:DoubleToBits
Unexecuted instantiation: XCoreDisassembler.c:DoubleToBits
Unexecuted instantiation: XCoreInstPrinter.c:DoubleToBits
Unexecuted instantiation: M68KDisassembler.c:DoubleToBits
Unexecuted instantiation: TMS320C64xDisassembler.c:DoubleToBits
Unexecuted instantiation: TMS320C64xInstPrinter.c:DoubleToBits
Unexecuted instantiation: RISCVDisassembler.c:DoubleToBits
Unexecuted instantiation: TriCoreDisassembler.c:DoubleToBits
Unexecuted instantiation: HPPADisassembler.c:DoubleToBits
Unexecuted instantiation: XtensaMapping.c:DoubleToBits
Unexecuted instantiation: ARMDisassembler.c:DoubleToBits
Unexecuted instantiation: ARMDisassemblerExtension.c:DoubleToBits
Unexecuted instantiation: ARMInstPrinter.c:DoubleToBits
Unexecuted instantiation: AArch64Disassembler.c:DoubleToBits
Unexecuted instantiation: AArch64DisassemblerExtension.c:DoubleToBits
Unexecuted instantiation: AArch64InstPrinter.c:DoubleToBits
Unexecuted instantiation: MipsDisassembler.c:DoubleToBits
Unexecuted instantiation: PPCDisassembler.c:DoubleToBits
Unexecuted instantiation: PPCInstPrinter.c:DoubleToBits
Unexecuted instantiation: SparcDisassembler.c:DoubleToBits
Unexecuted instantiation: SparcDisassemblerExtension.c:DoubleToBits
Unexecuted instantiation: SparcInstPrinter.c:DoubleToBits
Unexecuted instantiation: SystemZDisassembler.c:DoubleToBits
Unexecuted instantiation: SystemZInstPrinter.c:DoubleToBits
Unexecuted instantiation: TriCoreInstPrinter.c:DoubleToBits
Unexecuted instantiation: LoongArchDisassembler.c:DoubleToBits
Unexecuted instantiation: XtensaDisassembler.c:DoubleToBits
Unexecuted instantiation: XtensaInstPrinter.c:DoubleToBits
Unexecuted instantiation: ARCDisassembler.c:DoubleToBits
396
397
/// FloatToBits - This function takes a float and returns the bit
398
/// equivalent 32-bit integer.  Note that copying floats around
399
/// changes the bits of NaNs on some hosts, notably x86, so this
400
/// routine cannot be used if these bits are needed.
401
static inline uint32_t FloatToBits(float Float)
402
0
{
403
0
  union {
404
0
    uint32_t I;
405
0
    float F;
406
0
  } T;
407
0
  T.F = Float;
408
0
  return T.I;
409
0
}
Unexecuted instantiation: SparcModule.c:FloatToBits
Unexecuted instantiation: ARMMapping.c:FloatToBits
Unexecuted instantiation: AArch64Mapping.c:FloatToBits
Unexecuted instantiation: PPCMapping.c:FloatToBits
Unexecuted instantiation: SparcMapping.c:FloatToBits
Unexecuted instantiation: XCoreDisassembler.c:FloatToBits
Unexecuted instantiation: XCoreInstPrinter.c:FloatToBits
Unexecuted instantiation: M68KDisassembler.c:FloatToBits
Unexecuted instantiation: TMS320C64xDisassembler.c:FloatToBits
Unexecuted instantiation: TMS320C64xInstPrinter.c:FloatToBits
Unexecuted instantiation: RISCVDisassembler.c:FloatToBits
Unexecuted instantiation: TriCoreDisassembler.c:FloatToBits
Unexecuted instantiation: HPPADisassembler.c:FloatToBits
Unexecuted instantiation: XtensaMapping.c:FloatToBits
Unexecuted instantiation: ARMDisassembler.c:FloatToBits
Unexecuted instantiation: ARMDisassemblerExtension.c:FloatToBits
Unexecuted instantiation: ARMInstPrinter.c:FloatToBits
Unexecuted instantiation: AArch64Disassembler.c:FloatToBits
Unexecuted instantiation: AArch64DisassemblerExtension.c:FloatToBits
Unexecuted instantiation: AArch64InstPrinter.c:FloatToBits
Unexecuted instantiation: MipsDisassembler.c:FloatToBits
Unexecuted instantiation: PPCDisassembler.c:FloatToBits
Unexecuted instantiation: PPCInstPrinter.c:FloatToBits
Unexecuted instantiation: SparcDisassembler.c:FloatToBits
Unexecuted instantiation: SparcDisassemblerExtension.c:FloatToBits
Unexecuted instantiation: SparcInstPrinter.c:FloatToBits
Unexecuted instantiation: SystemZDisassembler.c:FloatToBits
Unexecuted instantiation: SystemZInstPrinter.c:FloatToBits
Unexecuted instantiation: TriCoreInstPrinter.c:FloatToBits
Unexecuted instantiation: LoongArchDisassembler.c:FloatToBits
Unexecuted instantiation: XtensaDisassembler.c:FloatToBits
Unexecuted instantiation: XtensaInstPrinter.c:FloatToBits
Unexecuted instantiation: ARCDisassembler.c:FloatToBits
410
411
/// MinAlign - A and B are either alignments or offsets.  Return the minimum
412
/// alignment that may be assumed after adding the two together.
413
static inline uint64_t MinAlign(uint64_t A, uint64_t B)
414
0
{
415
0
  // The largest power of 2 that divides both A and B.
416
0
  //
417
0
  // Replace "-Value" by "1+~Value" in the following commented code to avoid
418
0
  // MSVC warning C4146
419
0
  //    return (A | B) & -(A | B);
420
0
  return (A | B) & (1 + ~(A | B));
421
0
}
Unexecuted instantiation: SparcModule.c:MinAlign
Unexecuted instantiation: ARMMapping.c:MinAlign
Unexecuted instantiation: AArch64Mapping.c:MinAlign
Unexecuted instantiation: PPCMapping.c:MinAlign
Unexecuted instantiation: SparcMapping.c:MinAlign
Unexecuted instantiation: XCoreDisassembler.c:MinAlign
Unexecuted instantiation: XCoreInstPrinter.c:MinAlign
Unexecuted instantiation: M68KDisassembler.c:MinAlign
Unexecuted instantiation: TMS320C64xDisassembler.c:MinAlign
Unexecuted instantiation: TMS320C64xInstPrinter.c:MinAlign
Unexecuted instantiation: RISCVDisassembler.c:MinAlign
Unexecuted instantiation: TriCoreDisassembler.c:MinAlign
Unexecuted instantiation: HPPADisassembler.c:MinAlign
Unexecuted instantiation: XtensaMapping.c:MinAlign
Unexecuted instantiation: ARMDisassembler.c:MinAlign
Unexecuted instantiation: ARMDisassemblerExtension.c:MinAlign
Unexecuted instantiation: ARMInstPrinter.c:MinAlign
Unexecuted instantiation: AArch64Disassembler.c:MinAlign
Unexecuted instantiation: AArch64DisassemblerExtension.c:MinAlign
Unexecuted instantiation: AArch64InstPrinter.c:MinAlign
Unexecuted instantiation: MipsDisassembler.c:MinAlign
Unexecuted instantiation: PPCDisassembler.c:MinAlign
Unexecuted instantiation: PPCInstPrinter.c:MinAlign
Unexecuted instantiation: SparcDisassembler.c:MinAlign
Unexecuted instantiation: SparcDisassemblerExtension.c:MinAlign
Unexecuted instantiation: SparcInstPrinter.c:MinAlign
Unexecuted instantiation: SystemZDisassembler.c:MinAlign
Unexecuted instantiation: SystemZInstPrinter.c:MinAlign
Unexecuted instantiation: TriCoreInstPrinter.c:MinAlign
Unexecuted instantiation: LoongArchDisassembler.c:MinAlign
Unexecuted instantiation: XtensaDisassembler.c:MinAlign
Unexecuted instantiation: XtensaInstPrinter.c:MinAlign
Unexecuted instantiation: ARCDisassembler.c:MinAlign
422
423
/// NextPowerOf2 - Returns the next power of two (in 64-bits)
424
/// that is strictly greater than A.  Returns zero on overflow.
425
static inline uint64_t NextPowerOf2(uint64_t A)
426
0
{
427
0
  A |= (A >> 1);
428
0
  A |= (A >> 2);
429
0
  A |= (A >> 4);
430
0
  A |= (A >> 8);
431
0
  A |= (A >> 16);
432
0
  A |= (A >> 32);
433
0
  return A + 1;
434
0
}
Unexecuted instantiation: SparcModule.c:NextPowerOf2
Unexecuted instantiation: ARMMapping.c:NextPowerOf2
Unexecuted instantiation: AArch64Mapping.c:NextPowerOf2
Unexecuted instantiation: PPCMapping.c:NextPowerOf2
Unexecuted instantiation: SparcMapping.c:NextPowerOf2
Unexecuted instantiation: XCoreDisassembler.c:NextPowerOf2
Unexecuted instantiation: XCoreInstPrinter.c:NextPowerOf2
Unexecuted instantiation: M68KDisassembler.c:NextPowerOf2
Unexecuted instantiation: TMS320C64xDisassembler.c:NextPowerOf2
Unexecuted instantiation: TMS320C64xInstPrinter.c:NextPowerOf2
Unexecuted instantiation: RISCVDisassembler.c:NextPowerOf2
Unexecuted instantiation: TriCoreDisassembler.c:NextPowerOf2
Unexecuted instantiation: HPPADisassembler.c:NextPowerOf2
Unexecuted instantiation: XtensaMapping.c:NextPowerOf2
Unexecuted instantiation: ARMDisassembler.c:NextPowerOf2
Unexecuted instantiation: ARMDisassemblerExtension.c:NextPowerOf2
Unexecuted instantiation: ARMInstPrinter.c:NextPowerOf2
Unexecuted instantiation: AArch64Disassembler.c:NextPowerOf2
Unexecuted instantiation: AArch64DisassemblerExtension.c:NextPowerOf2
Unexecuted instantiation: AArch64InstPrinter.c:NextPowerOf2
Unexecuted instantiation: MipsDisassembler.c:NextPowerOf2
Unexecuted instantiation: PPCDisassembler.c:NextPowerOf2
Unexecuted instantiation: PPCInstPrinter.c:NextPowerOf2
Unexecuted instantiation: SparcDisassembler.c:NextPowerOf2
Unexecuted instantiation: SparcDisassemblerExtension.c:NextPowerOf2
Unexecuted instantiation: SparcInstPrinter.c:NextPowerOf2
Unexecuted instantiation: SystemZDisassembler.c:NextPowerOf2
Unexecuted instantiation: SystemZInstPrinter.c:NextPowerOf2
Unexecuted instantiation: TriCoreInstPrinter.c:NextPowerOf2
Unexecuted instantiation: LoongArchDisassembler.c:NextPowerOf2
Unexecuted instantiation: XtensaDisassembler.c:NextPowerOf2
Unexecuted instantiation: XtensaInstPrinter.c:NextPowerOf2
Unexecuted instantiation: ARCDisassembler.c:NextPowerOf2
435
436
/// Returns the next integer (mod 2**64) that is greater than or equal to
437
/// \p Value and is a multiple of \p Align. \p Align must be non-zero.
438
///
439
/// Examples:
440
/// \code
441
///   RoundUpToAlignment(5, 8) = 8
442
///   RoundUpToAlignment(17, 8) = 24
443
///   RoundUpToAlignment(~0LL, 8) = 0
444
/// \endcode
445
static inline uint64_t RoundUpToAlignment(uint64_t Value, uint64_t Align)
446
0
{
447
0
  return ((Value + Align - 1) / Align) * Align;
448
0
}
Unexecuted instantiation: SparcModule.c:RoundUpToAlignment
Unexecuted instantiation: ARMMapping.c:RoundUpToAlignment
Unexecuted instantiation: AArch64Mapping.c:RoundUpToAlignment
Unexecuted instantiation: PPCMapping.c:RoundUpToAlignment
Unexecuted instantiation: SparcMapping.c:RoundUpToAlignment
Unexecuted instantiation: XCoreDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: XCoreInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: M68KDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: TMS320C64xDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: TMS320C64xInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: RISCVDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: TriCoreDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: HPPADisassembler.c:RoundUpToAlignment
Unexecuted instantiation: XtensaMapping.c:RoundUpToAlignment
Unexecuted instantiation: ARMDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: ARMDisassemblerExtension.c:RoundUpToAlignment
Unexecuted instantiation: ARMInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: AArch64Disassembler.c:RoundUpToAlignment
Unexecuted instantiation: AArch64DisassemblerExtension.c:RoundUpToAlignment
Unexecuted instantiation: AArch64InstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: MipsDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: PPCDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: PPCInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: SparcDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: SparcDisassemblerExtension.c:RoundUpToAlignment
Unexecuted instantiation: SparcInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: SystemZDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: SystemZInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: TriCoreInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: LoongArchDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: XtensaDisassembler.c:RoundUpToAlignment
Unexecuted instantiation: XtensaInstPrinter.c:RoundUpToAlignment
Unexecuted instantiation: ARCDisassembler.c:RoundUpToAlignment
449
450
/// Returns the offset to the next integer (mod 2**64) that is greater than
451
/// or equal to \p Value and is a multiple of \p Align. \p Align must be
452
/// non-zero.
453
static inline uint64_t OffsetToAlignment(uint64_t Value, uint64_t Align)
454
0
{
455
0
  return RoundUpToAlignment(Value, Align) - Value;
456
0
}
Unexecuted instantiation: SparcModule.c:OffsetToAlignment
Unexecuted instantiation: ARMMapping.c:OffsetToAlignment
Unexecuted instantiation: AArch64Mapping.c:OffsetToAlignment
Unexecuted instantiation: PPCMapping.c:OffsetToAlignment
Unexecuted instantiation: SparcMapping.c:OffsetToAlignment
Unexecuted instantiation: XCoreDisassembler.c:OffsetToAlignment
Unexecuted instantiation: XCoreInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: M68KDisassembler.c:OffsetToAlignment
Unexecuted instantiation: TMS320C64xDisassembler.c:OffsetToAlignment
Unexecuted instantiation: TMS320C64xInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: RISCVDisassembler.c:OffsetToAlignment
Unexecuted instantiation: TriCoreDisassembler.c:OffsetToAlignment
Unexecuted instantiation: HPPADisassembler.c:OffsetToAlignment
Unexecuted instantiation: XtensaMapping.c:OffsetToAlignment
Unexecuted instantiation: ARMDisassembler.c:OffsetToAlignment
Unexecuted instantiation: ARMDisassemblerExtension.c:OffsetToAlignment
Unexecuted instantiation: ARMInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: AArch64Disassembler.c:OffsetToAlignment
Unexecuted instantiation: AArch64DisassemblerExtension.c:OffsetToAlignment
Unexecuted instantiation: AArch64InstPrinter.c:OffsetToAlignment
Unexecuted instantiation: MipsDisassembler.c:OffsetToAlignment
Unexecuted instantiation: PPCDisassembler.c:OffsetToAlignment
Unexecuted instantiation: PPCInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: SparcDisassembler.c:OffsetToAlignment
Unexecuted instantiation: SparcDisassemblerExtension.c:OffsetToAlignment
Unexecuted instantiation: SparcInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: SystemZDisassembler.c:OffsetToAlignment
Unexecuted instantiation: SystemZInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: TriCoreInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: LoongArchDisassembler.c:OffsetToAlignment
Unexecuted instantiation: XtensaDisassembler.c:OffsetToAlignment
Unexecuted instantiation: XtensaInstPrinter.c:OffsetToAlignment
Unexecuted instantiation: ARCDisassembler.c:OffsetToAlignment
457
458
/// abs64 - absolute value of a 64-bit int.  Not all environments support
459
/// "abs" on whatever their name for the 64-bit int type is.  The absolute
460
/// value of the largest negative number is undefined, as with "abs".
461
static inline int64_t abs64(int64_t x)
462
0
{
463
0
  return (x < 0) ? -x : x;
464
0
}
Unexecuted instantiation: SparcModule.c:abs64
Unexecuted instantiation: ARMMapping.c:abs64
Unexecuted instantiation: AArch64Mapping.c:abs64
Unexecuted instantiation: PPCMapping.c:abs64
Unexecuted instantiation: SparcMapping.c:abs64
Unexecuted instantiation: XCoreDisassembler.c:abs64
Unexecuted instantiation: XCoreInstPrinter.c:abs64
Unexecuted instantiation: M68KDisassembler.c:abs64
Unexecuted instantiation: TMS320C64xDisassembler.c:abs64
Unexecuted instantiation: TMS320C64xInstPrinter.c:abs64
Unexecuted instantiation: RISCVDisassembler.c:abs64
Unexecuted instantiation: TriCoreDisassembler.c:abs64
Unexecuted instantiation: HPPADisassembler.c:abs64
Unexecuted instantiation: XtensaMapping.c:abs64
Unexecuted instantiation: ARMDisassembler.c:abs64
Unexecuted instantiation: ARMDisassemblerExtension.c:abs64
Unexecuted instantiation: ARMInstPrinter.c:abs64
Unexecuted instantiation: AArch64Disassembler.c:abs64
Unexecuted instantiation: AArch64DisassemblerExtension.c:abs64
Unexecuted instantiation: AArch64InstPrinter.c:abs64
Unexecuted instantiation: MipsDisassembler.c:abs64
Unexecuted instantiation: PPCDisassembler.c:abs64
Unexecuted instantiation: PPCInstPrinter.c:abs64
Unexecuted instantiation: SparcDisassembler.c:abs64
Unexecuted instantiation: SparcDisassemblerExtension.c:abs64
Unexecuted instantiation: SparcInstPrinter.c:abs64
Unexecuted instantiation: SystemZDisassembler.c:abs64
Unexecuted instantiation: SystemZInstPrinter.c:abs64
Unexecuted instantiation: TriCoreInstPrinter.c:abs64
Unexecuted instantiation: LoongArchDisassembler.c:abs64
Unexecuted instantiation: XtensaDisassembler.c:abs64
Unexecuted instantiation: XtensaInstPrinter.c:abs64
Unexecuted instantiation: ARCDisassembler.c:abs64
465
466
/// \brief Sign extend number in the bottom B bits of X to a 32-bit int.
467
/// Requires 0 < B <= 32.
468
/// Note that this implementation relies on right shift of signed
469
/// integers being an arithmetic shift.
470
static inline int32_t SignExtend32(uint32_t X, unsigned B)
471
232k
{
472
232k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
232k
}
Unexecuted instantiation: SparcModule.c:SignExtend32
Unexecuted instantiation: ARMMapping.c:SignExtend32
Unexecuted instantiation: AArch64Mapping.c:SignExtend32
PPCMapping.c:SignExtend32
Line
Count
Source
471
5.74k
{
472
5.74k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
5.74k
}
Unexecuted instantiation: SparcMapping.c:SignExtend32
Unexecuted instantiation: XCoreDisassembler.c:SignExtend32
Unexecuted instantiation: XCoreInstPrinter.c:SignExtend32
Unexecuted instantiation: M68KDisassembler.c:SignExtend32
Unexecuted instantiation: TMS320C64xDisassembler.c:SignExtend32
Unexecuted instantiation: TMS320C64xInstPrinter.c:SignExtend32
Unexecuted instantiation: RISCVDisassembler.c:SignExtend32
Unexecuted instantiation: TriCoreDisassembler.c:SignExtend32
Unexecuted instantiation: HPPADisassembler.c:SignExtend32
Unexecuted instantiation: XtensaMapping.c:SignExtend32
ARMDisassembler.c:SignExtend32
Line
Count
Source
471
126k
{
472
126k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
126k
}
Unexecuted instantiation: ARMDisassemblerExtension.c:SignExtend32
Unexecuted instantiation: ARMInstPrinter.c:SignExtend32
Unexecuted instantiation: AArch64Disassembler.c:SignExtend32
Unexecuted instantiation: AArch64DisassemblerExtension.c:SignExtend32
Unexecuted instantiation: AArch64InstPrinter.c:SignExtend32
MipsDisassembler.c:SignExtend32
Line
Count
Source
471
76.5k
{
472
76.5k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
76.5k
}
PPCDisassembler.c:SignExtend32
Line
Count
Source
471
10.0k
{
472
10.0k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
10.0k
}
PPCInstPrinter.c:SignExtend32
Line
Count
Source
471
14.3k
{
472
14.3k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
14.3k
}
Unexecuted instantiation: SparcDisassemblerExtension.c:SignExtend32
Unexecuted instantiation: SystemZDisassembler.c:SignExtend32
Unexecuted instantiation: SystemZInstPrinter.c:SignExtend32
Unexecuted instantiation: TriCoreInstPrinter.c:SignExtend32
Unexecuted instantiation: LoongArchDisassembler.c:SignExtend32
Unexecuted instantiation: XtensaDisassembler.c:SignExtend32
Unexecuted instantiation: XtensaInstPrinter.c:SignExtend32
Unexecuted instantiation: ARCDisassembler.c:SignExtend32
474
475
/// \brief Sign extend number in the bottom B bits of X to a 64-bit int.
476
/// Requires 0 < B <= 64.
477
/// Note that this implementation relies on right shift of signed
478
/// integers being an arithmetic shift.
479
static inline int64_t SignExtend64(uint64_t X, unsigned B)
480
164k
{
481
164k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
164k
}
Unexecuted instantiation: SparcModule.c:SignExtend64
Unexecuted instantiation: ARMMapping.c:SignExtend64
Unexecuted instantiation: AArch64Mapping.c:SignExtend64
PPCMapping.c:SignExtend64
Line
Count
Source
480
327
{
481
327
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
327
}
Unexecuted instantiation: SparcMapping.c:SignExtend64
Unexecuted instantiation: XCoreDisassembler.c:SignExtend64
Unexecuted instantiation: XCoreInstPrinter.c:SignExtend64
Unexecuted instantiation: M68KDisassembler.c:SignExtend64
Unexecuted instantiation: TMS320C64xDisassembler.c:SignExtend64
Unexecuted instantiation: TMS320C64xInstPrinter.c:SignExtend64
RISCVDisassembler.c:SignExtend64
Line
Count
Source
480
16.4k
{
481
16.4k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
16.4k
}
Unexecuted instantiation: TriCoreDisassembler.c:SignExtend64
Unexecuted instantiation: HPPADisassembler.c:SignExtend64
Unexecuted instantiation: XtensaMapping.c:SignExtend64
Unexecuted instantiation: ARMDisassembler.c:SignExtend64
Unexecuted instantiation: ARMDisassemblerExtension.c:SignExtend64
Unexecuted instantiation: ARMInstPrinter.c:SignExtend64
Unexecuted instantiation: AArch64Disassembler.c:SignExtend64
Unexecuted instantiation: AArch64DisassemblerExtension.c:SignExtend64
AArch64InstPrinter.c:SignExtend64
Line
Count
Source
480
10.1k
{
481
10.1k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
10.1k
}
MipsDisassembler.c:SignExtend64
Line
Count
Source
480
15.9k
{
481
15.9k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
15.9k
}
PPCDisassembler.c:SignExtend64
Line
Count
Source
480
39.0k
{
481
39.0k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
39.0k
}
SparcDisassembler.c:SignExtend64
Line
Count
Source
480
21.0k
{
481
21.0k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
21.0k
}
Unexecuted instantiation: SparcDisassemblerExtension.c:SignExtend64
Unexecuted instantiation: SparcInstPrinter.c:SignExtend64
SystemZDisassembler.c:SignExtend64
Line
Count
Source
480
41.3k
{
481
41.3k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
41.3k
}
Unexecuted instantiation: SystemZInstPrinter.c:SignExtend64
Unexecuted instantiation: TriCoreInstPrinter.c:SignExtend64
Unexecuted instantiation: LoongArchDisassembler.c:SignExtend64
XtensaDisassembler.c:SignExtend64
Line
Count
Source
480
19.7k
{
481
19.7k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
19.7k
}
Unexecuted instantiation: XtensaInstPrinter.c:SignExtend64
Unexecuted instantiation: ARCDisassembler.c:SignExtend64
483
484
/// \brief Removes the rightmost bit of x and extends the field to the left with that
485
/// bit to form a 64-bit quantity. The field is of size len
486
static inline int64_t LowSignExtend64(uint64_t x, unsigned len)
487
0
{
488
0
  return (x >> 1) - ((x & 1) << (len - 1));
489
0
}
Unexecuted instantiation: SparcModule.c:LowSignExtend64
Unexecuted instantiation: ARMMapping.c:LowSignExtend64
Unexecuted instantiation: AArch64Mapping.c:LowSignExtend64
Unexecuted instantiation: PPCMapping.c:LowSignExtend64
Unexecuted instantiation: SparcMapping.c:LowSignExtend64
Unexecuted instantiation: XCoreDisassembler.c:LowSignExtend64
Unexecuted instantiation: XCoreInstPrinter.c:LowSignExtend64
Unexecuted instantiation: M68KDisassembler.c:LowSignExtend64
Unexecuted instantiation: TMS320C64xDisassembler.c:LowSignExtend64
Unexecuted instantiation: TMS320C64xInstPrinter.c:LowSignExtend64
Unexecuted instantiation: RISCVDisassembler.c:LowSignExtend64
Unexecuted instantiation: TriCoreDisassembler.c:LowSignExtend64
Unexecuted instantiation: HPPADisassembler.c:LowSignExtend64
Unexecuted instantiation: XtensaMapping.c:LowSignExtend64
Unexecuted instantiation: ARMDisassembler.c:LowSignExtend64
Unexecuted instantiation: ARMDisassemblerExtension.c:LowSignExtend64
Unexecuted instantiation: ARMInstPrinter.c:LowSignExtend64
Unexecuted instantiation: AArch64Disassembler.c:LowSignExtend64
Unexecuted instantiation: AArch64DisassemblerExtension.c:LowSignExtend64
Unexecuted instantiation: AArch64InstPrinter.c:LowSignExtend64
Unexecuted instantiation: MipsDisassembler.c:LowSignExtend64
Unexecuted instantiation: PPCDisassembler.c:LowSignExtend64
Unexecuted instantiation: PPCInstPrinter.c:LowSignExtend64
Unexecuted instantiation: SparcDisassembler.c:LowSignExtend64
Unexecuted instantiation: SparcDisassemblerExtension.c:LowSignExtend64
Unexecuted instantiation: SparcInstPrinter.c:LowSignExtend64
Unexecuted instantiation: SystemZDisassembler.c:LowSignExtend64
Unexecuted instantiation: SystemZInstPrinter.c:LowSignExtend64
Unexecuted instantiation: TriCoreInstPrinter.c:LowSignExtend64
Unexecuted instantiation: LoongArchDisassembler.c:LowSignExtend64
Unexecuted instantiation: XtensaDisassembler.c:LowSignExtend64
Unexecuted instantiation: XtensaInstPrinter.c:LowSignExtend64
Unexecuted instantiation: ARCDisassembler.c:LowSignExtend64
490
491
/// \brief One extend number X starting at bit B and returns it as int32_t.
492
/// Requires 0 < B <= 32.
493
static inline int32_t OneExtend32(uint32_t X, unsigned B)
494
0
{
495
0
  return (~0U << B) | X;
496
0
}
Unexecuted instantiation: SparcModule.c:OneExtend32
Unexecuted instantiation: ARMMapping.c:OneExtend32
Unexecuted instantiation: AArch64Mapping.c:OneExtend32
Unexecuted instantiation: PPCMapping.c:OneExtend32
Unexecuted instantiation: SparcMapping.c:OneExtend32
Unexecuted instantiation: XCoreDisassembler.c:OneExtend32
Unexecuted instantiation: XCoreInstPrinter.c:OneExtend32
Unexecuted instantiation: M68KDisassembler.c:OneExtend32
Unexecuted instantiation: TMS320C64xDisassembler.c:OneExtend32
Unexecuted instantiation: TMS320C64xInstPrinter.c:OneExtend32
Unexecuted instantiation: RISCVDisassembler.c:OneExtend32
Unexecuted instantiation: TriCoreDisassembler.c:OneExtend32
Unexecuted instantiation: HPPADisassembler.c:OneExtend32
Unexecuted instantiation: XtensaMapping.c:OneExtend32
Unexecuted instantiation: ARMDisassembler.c:OneExtend32
Unexecuted instantiation: ARMDisassemblerExtension.c:OneExtend32
Unexecuted instantiation: ARMInstPrinter.c:OneExtend32
Unexecuted instantiation: AArch64Disassembler.c:OneExtend32
Unexecuted instantiation: AArch64DisassemblerExtension.c:OneExtend32
Unexecuted instantiation: AArch64InstPrinter.c:OneExtend32
Unexecuted instantiation: MipsDisassembler.c:OneExtend32
Unexecuted instantiation: PPCDisassembler.c:OneExtend32
Unexecuted instantiation: PPCInstPrinter.c:OneExtend32
Unexecuted instantiation: SparcDisassembler.c:OneExtend32
Unexecuted instantiation: SparcDisassemblerExtension.c:OneExtend32
Unexecuted instantiation: SparcInstPrinter.c:OneExtend32
Unexecuted instantiation: SystemZDisassembler.c:OneExtend32
Unexecuted instantiation: SystemZInstPrinter.c:OneExtend32
Unexecuted instantiation: TriCoreInstPrinter.c:OneExtend32
Unexecuted instantiation: LoongArchDisassembler.c:OneExtend32
Unexecuted instantiation: XtensaDisassembler.c:OneExtend32
Unexecuted instantiation: XtensaInstPrinter.c:OneExtend32
Unexecuted instantiation: ARCDisassembler.c:OneExtend32
497
498
/// \brief One extend number X starting at bit B and returns it as int64_t.
499
/// Requires 0 < B <= 64.
500
static inline int64_t OneExtend64(uint64_t X, unsigned B)
501
6.01k
{
502
6.01k
  return (~0ULL << B) | X;
503
6.01k
}
Unexecuted instantiation: SparcModule.c:OneExtend64
Unexecuted instantiation: ARMMapping.c:OneExtend64
Unexecuted instantiation: AArch64Mapping.c:OneExtend64
Unexecuted instantiation: PPCMapping.c:OneExtend64
Unexecuted instantiation: SparcMapping.c:OneExtend64
Unexecuted instantiation: XCoreDisassembler.c:OneExtend64
Unexecuted instantiation: XCoreInstPrinter.c:OneExtend64
Unexecuted instantiation: M68KDisassembler.c:OneExtend64
Unexecuted instantiation: TMS320C64xDisassembler.c:OneExtend64
Unexecuted instantiation: TMS320C64xInstPrinter.c:OneExtend64
Unexecuted instantiation: RISCVDisassembler.c:OneExtend64
Unexecuted instantiation: TriCoreDisassembler.c:OneExtend64
Unexecuted instantiation: HPPADisassembler.c:OneExtend64
Unexecuted instantiation: XtensaMapping.c:OneExtend64
Unexecuted instantiation: ARMDisassembler.c:OneExtend64
Unexecuted instantiation: ARMDisassemblerExtension.c:OneExtend64
Unexecuted instantiation: ARMInstPrinter.c:OneExtend64
Unexecuted instantiation: AArch64Disassembler.c:OneExtend64
Unexecuted instantiation: AArch64DisassemblerExtension.c:OneExtend64
Unexecuted instantiation: AArch64InstPrinter.c:OneExtend64
Unexecuted instantiation: MipsDisassembler.c:OneExtend64
Unexecuted instantiation: PPCDisassembler.c:OneExtend64
Unexecuted instantiation: PPCInstPrinter.c:OneExtend64
Unexecuted instantiation: SparcDisassembler.c:OneExtend64
Unexecuted instantiation: SparcDisassemblerExtension.c:OneExtend64
Unexecuted instantiation: SparcInstPrinter.c:OneExtend64
Unexecuted instantiation: SystemZDisassembler.c:OneExtend64
Unexecuted instantiation: SystemZInstPrinter.c:OneExtend64
Unexecuted instantiation: TriCoreInstPrinter.c:OneExtend64
Unexecuted instantiation: LoongArchDisassembler.c:OneExtend64
XtensaDisassembler.c:OneExtend64
Line
Count
Source
501
6.01k
{
502
6.01k
  return (~0ULL << B) | X;
503
6.01k
}
Unexecuted instantiation: XtensaInstPrinter.c:OneExtend64
Unexecuted instantiation: ARCDisassembler.c:OneExtend64
504
505
/// \brief Count number of 0's from the most significant bit to the least
506
///   stopping at the first 1.
507
///
508
/// Only unsigned integral types are allowed.
509
///
510
/// \param ZB the behavior on an input of 0. Only ZB_Width and ZB_Undefined are
511
///   valid arguments.
512
static inline unsigned int countLeadingZeros(int x)
513
78.1k
{
514
78.1k
  int i;
515
78.1k
  const unsigned bits = sizeof(x) * 8;
516
78.1k
  unsigned count = bits;
517
518
78.1k
  if (x < 0) {
519
310
    return 0;
520
310
  }
521
456k
  for (i = bits; --i;) {
522
456k
    if (x == 0)
523
77.4k
      break;
524
379k
    count--;
525
379k
    x >>= 1;
526
379k
  }
527
528
77.8k
  return count;
529
78.1k
}
Unexecuted instantiation: SparcModule.c:countLeadingZeros
ARMMapping.c:countLeadingZeros
Line
Count
Source
513
734
{
514
734
  int i;
515
734
  const unsigned bits = sizeof(x) * 8;
516
734
  unsigned count = bits;
517
518
734
  if (x < 0) {
519
155
    return 0;
520
155
  }
521
11.1k
  for (i = bits; --i;) {
522
10.9k
    if (x == 0)
523
405
      break;
524
10.5k
    count--;
525
10.5k
    x >>= 1;
526
10.5k
  }
527
528
579
  return count;
529
734
}
AArch64Mapping.c:countLeadingZeros
Line
Count
Source
513
14.0k
{
514
14.0k
  int i;
515
14.0k
  const unsigned bits = sizeof(x) * 8;
516
14.0k
  unsigned count = bits;
517
518
14.0k
  if (x < 0) {
519
0
    return 0;
520
0
  }
521
83.7k
  for (i = bits; --i;) {
522
83.7k
    if (x == 0)
523
14.0k
      break;
524
69.6k
    count--;
525
69.6k
    x >>= 1;
526
69.6k
  }
527
528
14.0k
  return count;
529
14.0k
}
Unexecuted instantiation: PPCMapping.c:countLeadingZeros
Unexecuted instantiation: SparcMapping.c:countLeadingZeros
Unexecuted instantiation: XCoreDisassembler.c:countLeadingZeros
Unexecuted instantiation: XCoreInstPrinter.c:countLeadingZeros
Unexecuted instantiation: M68KDisassembler.c:countLeadingZeros
Unexecuted instantiation: TMS320C64xDisassembler.c:countLeadingZeros
Unexecuted instantiation: TMS320C64xInstPrinter.c:countLeadingZeros
Unexecuted instantiation: RISCVDisassembler.c:countLeadingZeros
Unexecuted instantiation: TriCoreDisassembler.c:countLeadingZeros
Unexecuted instantiation: HPPADisassembler.c:countLeadingZeros
Unexecuted instantiation: XtensaMapping.c:countLeadingZeros
Unexecuted instantiation: ARMDisassembler.c:countLeadingZeros
Unexecuted instantiation: ARMDisassemblerExtension.c:countLeadingZeros
ARMInstPrinter.c:countLeadingZeros
Line
Count
Source
513
734
{
514
734
  int i;
515
734
  const unsigned bits = sizeof(x) * 8;
516
734
  unsigned count = bits;
517
518
734
  if (x < 0) {
519
155
    return 0;
520
155
  }
521
11.1k
  for (i = bits; --i;) {
522
10.9k
    if (x == 0)
523
405
      break;
524
10.5k
    count--;
525
10.5k
    x >>= 1;
526
10.5k
  }
527
528
579
  return count;
529
734
}
AArch64Disassembler.c:countLeadingZeros
Line
Count
Source
513
15.3k
{
514
15.3k
  int i;
515
15.3k
  const unsigned bits = sizeof(x) * 8;
516
15.3k
  unsigned count = bits;
517
518
15.3k
  if (x < 0) {
519
0
    return 0;
520
0
  }
521
91.7k
  for (i = bits; --i;) {
522
91.7k
    if (x == 0)
523
15.3k
      break;
524
76.3k
    count--;
525
76.3k
    x >>= 1;
526
76.3k
  }
527
528
15.3k
  return count;
529
15.3k
}
Unexecuted instantiation: AArch64DisassemblerExtension.c:countLeadingZeros
AArch64InstPrinter.c:countLeadingZeros
Line
Count
Source
513
47.2k
{
514
47.2k
  int i;
515
47.2k
  const unsigned bits = sizeof(x) * 8;
516
47.2k
  unsigned count = bits;
517
518
47.2k
  if (x < 0) {
519
0
    return 0;
520
0
  }
521
259k
  for (i = bits; --i;) {
522
259k
    if (x == 0)
523
47.2k
      break;
524
211k
    count--;
525
211k
    x >>= 1;
526
211k
  }
527
528
47.2k
  return count;
529
47.2k
}
Unexecuted instantiation: MipsDisassembler.c:countLeadingZeros
Unexecuted instantiation: PPCDisassembler.c:countLeadingZeros
Unexecuted instantiation: PPCInstPrinter.c:countLeadingZeros
Unexecuted instantiation: SparcDisassembler.c:countLeadingZeros
Unexecuted instantiation: SparcDisassemblerExtension.c:countLeadingZeros
Unexecuted instantiation: SparcInstPrinter.c:countLeadingZeros
Unexecuted instantiation: SystemZDisassembler.c:countLeadingZeros
Unexecuted instantiation: SystemZInstPrinter.c:countLeadingZeros
Unexecuted instantiation: TriCoreInstPrinter.c:countLeadingZeros
Unexecuted instantiation: LoongArchDisassembler.c:countLeadingZeros
Unexecuted instantiation: XtensaDisassembler.c:countLeadingZeros
Unexecuted instantiation: XtensaInstPrinter.c:countLeadingZeros
Unexecuted instantiation: ARCDisassembler.c:countLeadingZeros
530
531
/// \brief Get specified field from 32-bit instruction. Returns bits from the segment [from, to]
532
/// The right most bit of insn is bit 31.
533
static inline uint32_t get_insn_field(uint32_t insn, uint8_t from, uint8_t to)
534
0
{
535
0
  return insn >> (31 - to) & ((1 << (to - from + 1)) - 1);
536
0
}
Unexecuted instantiation: SparcModule.c:get_insn_field
Unexecuted instantiation: ARMMapping.c:get_insn_field
Unexecuted instantiation: AArch64Mapping.c:get_insn_field
Unexecuted instantiation: PPCMapping.c:get_insn_field
Unexecuted instantiation: SparcMapping.c:get_insn_field
Unexecuted instantiation: XCoreDisassembler.c:get_insn_field
Unexecuted instantiation: XCoreInstPrinter.c:get_insn_field
Unexecuted instantiation: M68KDisassembler.c:get_insn_field
Unexecuted instantiation: TMS320C64xDisassembler.c:get_insn_field
Unexecuted instantiation: TMS320C64xInstPrinter.c:get_insn_field
Unexecuted instantiation: RISCVDisassembler.c:get_insn_field
Unexecuted instantiation: TriCoreDisassembler.c:get_insn_field
Unexecuted instantiation: HPPADisassembler.c:get_insn_field
Unexecuted instantiation: XtensaMapping.c:get_insn_field
Unexecuted instantiation: ARMDisassembler.c:get_insn_field
Unexecuted instantiation: ARMDisassemblerExtension.c:get_insn_field
Unexecuted instantiation: ARMInstPrinter.c:get_insn_field
Unexecuted instantiation: AArch64Disassembler.c:get_insn_field
Unexecuted instantiation: AArch64DisassemblerExtension.c:get_insn_field
Unexecuted instantiation: AArch64InstPrinter.c:get_insn_field
Unexecuted instantiation: MipsDisassembler.c:get_insn_field
Unexecuted instantiation: PPCDisassembler.c:get_insn_field
Unexecuted instantiation: PPCInstPrinter.c:get_insn_field
Unexecuted instantiation: SparcDisassembler.c:get_insn_field
Unexecuted instantiation: SparcDisassemblerExtension.c:get_insn_field
Unexecuted instantiation: SparcInstPrinter.c:get_insn_field
Unexecuted instantiation: SystemZDisassembler.c:get_insn_field
Unexecuted instantiation: SystemZInstPrinter.c:get_insn_field
Unexecuted instantiation: TriCoreInstPrinter.c:get_insn_field
Unexecuted instantiation: LoongArchDisassembler.c:get_insn_field
Unexecuted instantiation: XtensaDisassembler.c:get_insn_field
Unexecuted instantiation: XtensaInstPrinter.c:get_insn_field
Unexecuted instantiation: ARCDisassembler.c:get_insn_field
537
538
/// \brief Get specified field from 32-bit instruction. Returns bits from the segment [from, to]
539
/// The right most bit of insn is bit 0.
540
static inline uint32_t get_insn_field_r(uint32_t insn, uint8_t from, uint8_t to)
541
70.2k
{
542
70.2k
  return insn >> from & ((1 << (to - from + 1)) - 1);
543
70.2k
}
Unexecuted instantiation: SparcModule.c:get_insn_field_r
Unexecuted instantiation: ARMMapping.c:get_insn_field_r
Unexecuted instantiation: AArch64Mapping.c:get_insn_field_r
Unexecuted instantiation: PPCMapping.c:get_insn_field_r
SparcMapping.c:get_insn_field_r
Line
Count
Source
541
70.2k
{
542
70.2k
  return insn >> from & ((1 << (to - from + 1)) - 1);
543
70.2k
}
Unexecuted instantiation: XCoreDisassembler.c:get_insn_field_r
Unexecuted instantiation: XCoreInstPrinter.c:get_insn_field_r
Unexecuted instantiation: M68KDisassembler.c:get_insn_field_r
Unexecuted instantiation: TMS320C64xDisassembler.c:get_insn_field_r
Unexecuted instantiation: TMS320C64xInstPrinter.c:get_insn_field_r
Unexecuted instantiation: RISCVDisassembler.c:get_insn_field_r
Unexecuted instantiation: TriCoreDisassembler.c:get_insn_field_r
Unexecuted instantiation: HPPADisassembler.c:get_insn_field_r
Unexecuted instantiation: XtensaMapping.c:get_insn_field_r
Unexecuted instantiation: ARMDisassembler.c:get_insn_field_r
Unexecuted instantiation: ARMDisassemblerExtension.c:get_insn_field_r
Unexecuted instantiation: ARMInstPrinter.c:get_insn_field_r
Unexecuted instantiation: AArch64Disassembler.c:get_insn_field_r
Unexecuted instantiation: AArch64DisassemblerExtension.c:get_insn_field_r
Unexecuted instantiation: AArch64InstPrinter.c:get_insn_field_r
Unexecuted instantiation: MipsDisassembler.c:get_insn_field_r
Unexecuted instantiation: PPCDisassembler.c:get_insn_field_r
Unexecuted instantiation: PPCInstPrinter.c:get_insn_field_r
Unexecuted instantiation: SparcDisassembler.c:get_insn_field_r
Unexecuted instantiation: SparcDisassemblerExtension.c:get_insn_field_r
Unexecuted instantiation: SparcInstPrinter.c:get_insn_field_r
Unexecuted instantiation: SystemZDisassembler.c:get_insn_field_r
Unexecuted instantiation: SystemZInstPrinter.c:get_insn_field_r
Unexecuted instantiation: TriCoreInstPrinter.c:get_insn_field_r
Unexecuted instantiation: LoongArchDisassembler.c:get_insn_field_r
Unexecuted instantiation: XtensaDisassembler.c:get_insn_field_r
Unexecuted instantiation: XtensaInstPrinter.c:get_insn_field_r
Unexecuted instantiation: ARCDisassembler.c:get_insn_field_r
544
545
/// \brief Get specified bit from 32-bit instruction
546
static inline uint32_t get_insn_bit(uint32_t insn, uint8_t bit)
547
0
{
548
0
  return get_insn_field(insn, bit, bit);
549
0
}
Unexecuted instantiation: SparcModule.c:get_insn_bit
Unexecuted instantiation: ARMMapping.c:get_insn_bit
Unexecuted instantiation: AArch64Mapping.c:get_insn_bit
Unexecuted instantiation: PPCMapping.c:get_insn_bit
Unexecuted instantiation: SparcMapping.c:get_insn_bit
Unexecuted instantiation: XCoreDisassembler.c:get_insn_bit
Unexecuted instantiation: XCoreInstPrinter.c:get_insn_bit
Unexecuted instantiation: M68KDisassembler.c:get_insn_bit
Unexecuted instantiation: TMS320C64xDisassembler.c:get_insn_bit
Unexecuted instantiation: TMS320C64xInstPrinter.c:get_insn_bit
Unexecuted instantiation: RISCVDisassembler.c:get_insn_bit
Unexecuted instantiation: TriCoreDisassembler.c:get_insn_bit
Unexecuted instantiation: HPPADisassembler.c:get_insn_bit
Unexecuted instantiation: XtensaMapping.c:get_insn_bit
Unexecuted instantiation: ARMDisassembler.c:get_insn_bit
Unexecuted instantiation: ARMDisassemblerExtension.c:get_insn_bit
Unexecuted instantiation: ARMInstPrinter.c:get_insn_bit
Unexecuted instantiation: AArch64Disassembler.c:get_insn_bit
Unexecuted instantiation: AArch64DisassemblerExtension.c:get_insn_bit
Unexecuted instantiation: AArch64InstPrinter.c:get_insn_bit
Unexecuted instantiation: MipsDisassembler.c:get_insn_bit
Unexecuted instantiation: PPCDisassembler.c:get_insn_bit
Unexecuted instantiation: PPCInstPrinter.c:get_insn_bit
Unexecuted instantiation: SparcDisassembler.c:get_insn_bit
Unexecuted instantiation: SparcDisassemblerExtension.c:get_insn_bit
Unexecuted instantiation: SparcInstPrinter.c:get_insn_bit
Unexecuted instantiation: SystemZDisassembler.c:get_insn_bit
Unexecuted instantiation: SystemZInstPrinter.c:get_insn_bit
Unexecuted instantiation: TriCoreInstPrinter.c:get_insn_bit
Unexecuted instantiation: LoongArchDisassembler.c:get_insn_bit
Unexecuted instantiation: XtensaDisassembler.c:get_insn_bit
Unexecuted instantiation: XtensaInstPrinter.c:get_insn_bit
Unexecuted instantiation: ARCDisassembler.c:get_insn_bit
550
551
/// \brief Create a bitmask with the N right-most bits set to 1, and all other
552
/// bits set to 0.  Only unsigned types are allowed.
553
static inline uint32_t maskTrailingOnes32(uint32_t N)
554
0
{
555
0
  const unsigned Bits = CHAR_BIT * sizeof(uint32_t);
556
0
  return N == 0 ? 0 : (((uint32_t)-1) >> (Bits - N));
557
0
}
Unexecuted instantiation: SparcModule.c:maskTrailingOnes32
Unexecuted instantiation: ARMMapping.c:maskTrailingOnes32
Unexecuted instantiation: AArch64Mapping.c:maskTrailingOnes32
Unexecuted instantiation: PPCMapping.c:maskTrailingOnes32
Unexecuted instantiation: SparcMapping.c:maskTrailingOnes32
Unexecuted instantiation: XCoreDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: XCoreInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: M68KDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: TMS320C64xDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: TMS320C64xInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: RISCVDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: TriCoreDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: HPPADisassembler.c:maskTrailingOnes32
Unexecuted instantiation: XtensaMapping.c:maskTrailingOnes32
Unexecuted instantiation: ARMDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: ARMDisassemblerExtension.c:maskTrailingOnes32
Unexecuted instantiation: ARMInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: AArch64Disassembler.c:maskTrailingOnes32
Unexecuted instantiation: AArch64DisassemblerExtension.c:maskTrailingOnes32
Unexecuted instantiation: AArch64InstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: MipsDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: PPCDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: PPCInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: SparcDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: SparcDisassemblerExtension.c:maskTrailingOnes32
Unexecuted instantiation: SparcInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: SystemZDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: SystemZInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: TriCoreInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: LoongArchDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: XtensaDisassembler.c:maskTrailingOnes32
Unexecuted instantiation: XtensaInstPrinter.c:maskTrailingOnes32
Unexecuted instantiation: ARCDisassembler.c:maskTrailingOnes32
558
559
#endif