Coverage Report

Created: 2025-11-24 06:12

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/capstonenext/MathExtras.h
Line
Count
Source
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
251k
{
54
251k
  return x == (x & (~0ULL >> (64 - N)));
55
251k
}
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
43.5k
{
54
43.5k
  return x == (x & (~0ULL >> (64 - N)));
55
43.5k
}
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
207k
{
54
207k
  return x == (x & (~0ULL >> (64 - N)));
55
207k
}
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
5.76k
{
78
5.76k
  return Value && ((Value + 1) & Value) == 0;
79
5.76k
}
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
5.76k
{
78
5.76k
  return Value && ((Value + 1) & Value) == 0;
79
5.76k
}
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
5.76k
{
93
5.76k
  return isMask_64((Value - 1) | Value);
94
5.76k
}
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
5.76k
{
93
5.76k
  return isMask_64((Value - 1) | Value);
94
5.76k
}
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
44.8k
{
109
44.8k
  unsigned Count; // result
110
44.8k
#if __GNUC__ >= 4
111
  // PowerPC is defined for __builtin_clz(0)
112
44.8k
#if !defined(__ppc__) && !defined(__ppc64__)
113
44.8k
  if (!Value)
114
7
    return 32;
115
44.8k
#endif
116
44.8k
  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
44.8k
  return Count;
133
44.8k
}
Unexecuted instantiation: SparcModule.c:CountLeadingZeros_32
Unexecuted instantiation: ARMMapping.c:CountLeadingZeros_32
AArch64Mapping.c:CountLeadingZeros_32
Line
Count
Source
108
17.9k
{
109
17.9k
  unsigned Count; // result
110
17.9k
#if __GNUC__ >= 4
111
  // PowerPC is defined for __builtin_clz(0)
112
17.9k
#if !defined(__ppc__) && !defined(__ppc64__)
113
17.9k
  if (!Value)
114
0
    return 32;
115
17.9k
#endif
116
17.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
17.9k
  return Count;
133
17.9k
}
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
26.9k
{
109
26.9k
  unsigned Count; // result
110
26.9k
#if __GNUC__ >= 4
111
  // PowerPC is defined for __builtin_clz(0)
112
26.9k
#if !defined(__ppc__) && !defined(__ppc64__)
113
26.9k
  if (!Value)
114
7
    return 32;
115
26.9k
#endif
116
26.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
26.9k
  return Count;
133
26.9k
}
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
893
{
150
893
  unsigned Count; // result
151
893
#if __GNUC__ >= 4
152
  // PowerPC is defined for __builtin_clzll(0)
153
893
#if !defined(__ppc__) && !defined(__ppc64__)
154
893
  if (!Value)
155
0
    return 64;
156
893
#endif
157
893
  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
893
  return Count;
193
893
}
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
893
{
150
893
  unsigned Count; // result
151
893
#if __GNUC__ >= 4
152
  // PowerPC is defined for __builtin_clzll(0)
153
893
#if !defined(__ppc__) && !defined(__ppc64__)
154
893
  if (!Value)
155
0
    return 64;
156
893
#endif
157
893
  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
893
  return Count;
193
893
}
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
893
{
201
893
  return CountLeadingZeros_64(~Value);
202
893
}
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
893
{
201
893
  return CountLeadingZeros_64(~Value);
202
893
}
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
62.4k
{
210
62.4k
#if __GNUC__ >= 4
211
62.4k
  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
62.4k
}
Unexecuted instantiation: SparcModule.c:CountTrailingZeros_32
ARMMapping.c:CountTrailingZeros_32
Line
Count
Source
209
28.8k
{
210
28.8k
#if __GNUC__ >= 4
211
28.8k
  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.8k
}
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
32.7k
{
210
32.7k
#if __GNUC__ >= 4
211
32.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
32.7k
}
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
843
{
210
843
#if __GNUC__ >= 4
211
843
  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
843
}
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
20.3k
{
229
20.3k
  uint8_t c = 8;
230
20.3k
  Value &= -((int8_t)Value);
231
20.3k
  if (Value)
232
20.3k
    c--;
233
20.3k
  if (Value & 0x0F)
234
20.3k
    c -= 4;
235
20.3k
  if (Value & 0x33)
236
17.0k
    c -= 2;
237
20.3k
  if (Value & 0x55)
238
16.7k
    c -= 1;
239
20.3k
  return c;
240
20.3k
}
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
20.3k
{
229
20.3k
  uint8_t c = 8;
230
20.3k
  Value &= -((int8_t)Value);
231
20.3k
  if (Value)
232
20.3k
    c--;
233
20.3k
  if (Value & 0x0F)
234
20.3k
    c -= 4;
235
20.3k
  if (Value & 0x33)
236
17.0k
    c -= 2;
237
20.3k
  if (Value & 0x55)
238
16.7k
    c -= 1;
239
20.3k
  return c;
240
20.3k
}
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
8.61k
{
257
8.61k
#if __GNUC__ >= 4
258
8.61k
  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
8.61k
}
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
8.61k
{
257
8.61k
#if __GNUC__ >= 4
258
8.61k
  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
8.61k
}
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.75k
{
280
4.75k
  return CountTrailingZeros_64(~Value);
281
4.75k
}
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.75k
{
280
4.75k
  return CountTrailingZeros_64(~Value);
281
4.75k
}
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
35.8k
{
316
35.8k
  if (Value == 0) {
317
0
    return UINT_MAX;
318
0
  }
319
35.8k
  return 31 - CountLeadingZeros_32(Value);
320
35.8k
}
Unexecuted instantiation: SparcModule.c:Log2_32
Unexecuted instantiation: ARMMapping.c:Log2_32
AArch64Mapping.c:Log2_32
Line
Count
Source
315
17.9k
{
316
17.9k
  if (Value == 0) {
317
0
    return UINT_MAX;
318
0
  }
319
17.9k
  return 31 - CountLeadingZeros_32(Value);
320
17.9k
}
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
17.9k
{
316
17.9k
  if (Value == 0) {
317
0
    return UINT_MAX;
318
0
  }
319
17.9k
  return 31 - CountLeadingZeros_32(Value);
320
17.9k
}
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
4.36k
{
375
4.36k
  union {
376
4.36k
    uint32_t I;
377
4.36k
    float F;
378
4.36k
  } T;
379
4.36k
  T.I = Bits;
380
4.36k
  return T.F;
381
4.36k
}
Unexecuted instantiation: SparcModule.c:BitsToFloat
ARMMapping.c:BitsToFloat
Line
Count
Source
374
752
{
375
752
  union {
376
752
    uint32_t I;
377
752
    float F;
378
752
  } T;
379
752
  T.I = Bits;
380
752
  return T.F;
381
752
}
AArch64Mapping.c:BitsToFloat
Line
Count
Source
374
854
{
375
854
  union {
376
854
    uint32_t I;
377
854
    float F;
378
854
  } T;
379
854
  T.I = Bits;
380
854
  return T.F;
381
854
}
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.15k
{
375
1.15k
  union {
376
1.15k
    uint32_t I;
377
1.15k
    float F;
378
1.15k
  } T;
379
1.15k
  T.I = Bits;
380
1.15k
  return T.F;
381
1.15k
}
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
752
{
375
752
  union {
376
752
    uint32_t I;
377
752
    float F;
378
752
  } T;
379
752
  T.I = Bits;
380
752
  return T.F;
381
752
}
Unexecuted instantiation: AArch64Disassembler.c:BitsToFloat
Unexecuted instantiation: AArch64DisassemblerExtension.c:BitsToFloat
AArch64InstPrinter.c:BitsToFloat
Line
Count
Source
374
854
{
375
854
  union {
376
854
    uint32_t I;
377
854
    float F;
378
854
  } T;
379
854
  T.I = Bits;
380
854
  return T.F;
381
854
}
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
151k
{
472
151k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
151k
}
Unexecuted instantiation: SparcModule.c:SignExtend32
Unexecuted instantiation: ARMMapping.c:SignExtend32
Unexecuted instantiation: AArch64Mapping.c:SignExtend32
PPCMapping.c:SignExtend32
Line
Count
Source
471
5.15k
{
472
5.15k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
5.15k
}
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
84.1k
{
472
84.1k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
84.1k
}
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
44.9k
{
472
44.9k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
44.9k
}
PPCDisassembler.c:SignExtend32
Line
Count
Source
471
8.84k
{
472
8.84k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
8.84k
}
PPCInstPrinter.c:SignExtend32
Line
Count
Source
471
8.07k
{
472
8.07k
  return (int32_t)(X << (32 - B)) >> (32 - B);
473
8.07k
}
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
116k
{
481
116k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
116k
}
Unexecuted instantiation: SparcModule.c:SignExtend64
Unexecuted instantiation: ARMMapping.c:SignExtend64
Unexecuted instantiation: AArch64Mapping.c:SignExtend64
PPCMapping.c:SignExtend64
Line
Count
Source
480
469
{
481
469
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
469
}
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
11.5k
{
481
11.5k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
11.5k
}
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
7.91k
{
481
7.91k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
7.91k
}
MipsDisassembler.c:SignExtend64
Line
Count
Source
480
11.2k
{
481
11.2k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
11.2k
}
PPCDisassembler.c:SignExtend64
Line
Count
Source
480
14.9k
{
481
14.9k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
14.9k
}
SparcDisassembler.c:SignExtend64
Line
Count
Source
480
13.7k
{
481
13.7k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
13.7k
}
Unexecuted instantiation: SparcDisassemblerExtension.c:SignExtend64
Unexecuted instantiation: SparcInstPrinter.c:SignExtend64
SystemZDisassembler.c:SignExtend64
Line
Count
Source
480
37.9k
{
481
37.9k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
37.9k
}
Unexecuted instantiation: SystemZInstPrinter.c:SignExtend64
Unexecuted instantiation: TriCoreInstPrinter.c:SignExtend64
Unexecuted instantiation: LoongArchDisassembler.c:SignExtend64
XtensaDisassembler.c:SignExtend64
Line
Count
Source
480
18.3k
{
481
18.3k
  return (int64_t)(X << (64 - B)) >> (64 - B);
482
18.3k
}
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
5.05k
{
502
5.05k
  return (~0ULL << B) | X;
503
5.05k
}
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
5.05k
{
502
5.05k
  return (~0ULL << B) | X;
503
5.05k
}
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
82.0k
{
514
82.0k
  int i;
515
82.0k
  const unsigned bits = sizeof(x) * 8;
516
82.0k
  unsigned count = bits;
517
518
82.0k
  if (x < 0) {
519
608
    return 0;
520
608
  }
521
527k
  for (i = bits; --i;) {
522
527k
    if (x == 0)
523
81.4k
      break;
524
445k
    count--;
525
445k
    x >>= 1;
526
445k
  }
527
528
81.4k
  return count;
529
82.0k
}
Unexecuted instantiation: SparcModule.c:countLeadingZeros
ARMMapping.c:countLeadingZeros
Line
Count
Source
513
990
{
514
990
  int i;
515
990
  const unsigned bits = sizeof(x) * 8;
516
990
  unsigned count = bits;
517
518
990
  if (x < 0) {
519
304
    return 0;
520
304
  }
521
8.76k
  for (i = bits; --i;) {
522
8.76k
    if (x == 0)
523
684
      break;
524
8.08k
    count--;
525
8.08k
    x >>= 1;
526
8.08k
  }
527
528
686
  return count;
529
990
}
AArch64Mapping.c:countLeadingZeros
Line
Count
Source
513
15.1k
{
514
15.1k
  int i;
515
15.1k
  const unsigned bits = sizeof(x) * 8;
516
15.1k
  unsigned count = bits;
517
518
15.1k
  if (x < 0) {
519
0
    return 0;
520
0
  }
521
98.3k
  for (i = bits; --i;) {
522
98.3k
    if (x == 0)
523
15.1k
      break;
524
83.2k
    count--;
525
83.2k
    x >>= 1;
526
83.2k
  }
527
528
15.1k
  return count;
529
15.1k
}
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
990
{
514
990
  int i;
515
990
  const unsigned bits = sizeof(x) * 8;
516
990
  unsigned count = bits;
517
518
990
  if (x < 0) {
519
304
    return 0;
520
304
  }
521
8.76k
  for (i = bits; --i;) {
522
8.76k
    if (x == 0)
523
684
      break;
524
8.08k
    count--;
525
8.08k
    x >>= 1;
526
8.08k
  }
527
528
686
  return count;
529
990
}
AArch64Disassembler.c:countLeadingZeros
Line
Count
Source
513
16.4k
{
514
16.4k
  int i;
515
16.4k
  const unsigned bits = sizeof(x) * 8;
516
16.4k
  unsigned count = bits;
517
518
16.4k
  if (x < 0) {
519
0
    return 0;
520
0
  }
521
106k
  for (i = bits; --i;) {
522
106k
    if (x == 0)
523
16.4k
      break;
524
90.2k
    count--;
525
90.2k
    x >>= 1;
526
90.2k
  }
527
528
16.4k
  return count;
529
16.4k
}
Unexecuted instantiation: AArch64DisassemblerExtension.c:countLeadingZeros
AArch64InstPrinter.c:countLeadingZeros
Line
Count
Source
513
48.4k
{
514
48.4k
  int i;
515
48.4k
  const unsigned bits = sizeof(x) * 8;
516
48.4k
  unsigned count = bits;
517
518
48.4k
  if (x < 0) {
519
0
    return 0;
520
0
  }
521
304k
  for (i = bits; --i;) {
522
304k
    if (x == 0)
523
48.4k
      break;
524
256k
    count--;
525
256k
    x >>= 1;
526
256k
  }
527
528
48.4k
  return count;
529
48.4k
}
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
46.8k
{
542
46.8k
  return insn >> from & ((1 << (to - from + 1)) - 1);
543
46.8k
}
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
46.8k
{
542
46.8k
  return insn >> from & ((1 << (to - from + 1)) - 1);
543
46.8k
}
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