Coverage Report

Created: 2026-06-02 06:40

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/php-src/Zend/zend_bitset.h
Line
Count
Source
1
/*
2
   +----------------------------------------------------------------------+
3
   | Zend OPcache JIT                                                     |
4
   +----------------------------------------------------------------------+
5
   | Copyright © The PHP Group and Contributors.                          |
6
   +----------------------------------------------------------------------+
7
   | This source file is subject to the Modified BSD License that is      |
8
   | bundled with this package in the file LICENSE, and is available      |
9
   | through the World Wide Web at <https://www.php.net/license/>.        |
10
   |                                                                      |
11
   | SPDX-License-Identifier: BSD-3-Clause                                |
12
   +----------------------------------------------------------------------+
13
   | Authors: Dmitry Stogov <dmitry@php.net>                              |
14
   +----------------------------------------------------------------------+
15
*/
16
17
#ifndef _ZEND_BITSET_H_
18
#define _ZEND_BITSET_H_
19
20
#include <stdint.h>
21
#include <stdbool.h>
22
#include <string.h>
23
24
#include "zend_portability.h"
25
#include "zend_long.h"
26
27
typedef zend_ulong *zend_bitset;
28
29
4.25M
#define ZEND_BITSET_ELM_SIZE sizeof(zend_ulong)
30
31
#if SIZEOF_ZEND_LONG == 4
32
# define ZEND_BITSET_ELM_NUM(n)   ((n) >> 5)
33
# define ZEND_BITSET_BIT_NUM(n)   ((zend_ulong)(n) & Z_UL(0x1f))
34
#elif SIZEOF_ZEND_LONG == 8
35
23.0M
# define ZEND_BITSET_ELM_NUM(n)   ((n) >> 6)
36
23.0M
# define ZEND_BITSET_BIT_NUM(n)   ((zend_ulong)(n) & Z_UL(0x3f))
37
#else
38
# define ZEND_BITSET_ELM_NUM(n)   ((n) / (sizeof(zend_long) * 8))
39
# define ZEND_BITSET_BIT_NUM(n)   ((n) % (sizeof(zend_long) * 8))
40
#endif
41
42
#define ZEND_BITSET_ALLOCA(n, use_heap) \
43
285k
  (zend_bitset)do_alloca((n) * ZEND_BITSET_ELM_SIZE, use_heap)
44
45
/* Number of trailing zero bits (0x01 -> 0; 0x40 -> 6; 0x00 -> LEN) */
46
ZEND_ATTRIBUTE_CONST static zend_always_inline int zend_ulong_ntz(zend_ulong num)
47
1.40M
{
48
1.40M
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
49
1.40M
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
50
1.40M
  return __builtin_ctzl(num);
51
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
52
  return __builtin_ctzll(num);
53
#elif defined(_WIN32)
54
  unsigned long index;
55
56
#if defined(_WIN64)
57
  if (!BitScanForward64(&index, num)) {
58
#else
59
  if (!BitScanForward(&index, num)) {
60
#endif
61
    return SIZEOF_ZEND_LONG * 8;
62
  }
63
64
  return (int) index;
65
#else
66
  int n;
67
68
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
69
70
  n = 1;
71
#if SIZEOF_ZEND_LONG == 8
72
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
73
#endif
74
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
75
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
76
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
77
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
78
  return n - (num & 1);
79
#endif
80
1.40M
}
Unexecuted instantiation: zend_jit.c:zend_ulong_ntz
Unexecuted instantiation: array.c:zend_ulong_ntz
Unexecuted instantiation: math.c:zend_ulong_ntz
Unexecuted instantiation: string.c:zend_ulong_ntz
Unexecuted instantiation: block_pass.c:zend_ulong_ntz
Unexecuted instantiation: compact_vars.c:zend_ulong_ntz
dce.c:zend_ulong_ntz
Line
Count
Source
47
142k
{
48
142k
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
49
142k
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
50
142k
  return __builtin_ctzl(num);
51
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
52
  return __builtin_ctzll(num);
53
#elif defined(_WIN32)
54
  unsigned long index;
55
56
#if defined(_WIN64)
57
  if (!BitScanForward64(&index, num)) {
58
#else
59
  if (!BitScanForward(&index, num)) {
60
#endif
61
    return SIZEOF_ZEND_LONG * 8;
62
  }
63
64
  return (int) index;
65
#else
66
  int n;
67
68
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
69
70
  n = 1;
71
#if SIZEOF_ZEND_LONG == 8
72
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
73
#endif
74
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
75
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
76
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
77
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
78
  return n - (num & 1);
79
#endif
80
142k
}
Unexecuted instantiation: dfa_pass.c:zend_ulong_ntz
Unexecuted instantiation: escape_analysis.c:zend_ulong_ntz
Unexecuted instantiation: optimize_temp_vars_5.c:zend_ulong_ntz
Unexecuted instantiation: sccp.c:zend_ulong_ntz
scdf.c:zend_ulong_ntz
Line
Count
Source
47
215k
{
48
215k
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
49
215k
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
50
215k
  return __builtin_ctzl(num);
51
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
52
  return __builtin_ctzll(num);
53
#elif defined(_WIN32)
54
  unsigned long index;
55
56
#if defined(_WIN64)
57
  if (!BitScanForward64(&index, num)) {
58
#else
59
  if (!BitScanForward(&index, num)) {
60
#endif
61
    return SIZEOF_ZEND_LONG * 8;
62
  }
63
64
  return (int) index;
65
#else
66
  int n;
67
68
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
69
70
  n = 1;
71
#if SIZEOF_ZEND_LONG == 8
72
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
73
#endif
74
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
75
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
76
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
77
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
78
  return n - (num & 1);
79
#endif
80
215k
}
Unexecuted instantiation: zend_call_graph.c:zend_ulong_ntz
Unexecuted instantiation: zend_cfg.c:zend_ulong_ntz
Unexecuted instantiation: zend_dfg.c:zend_ulong_ntz
Unexecuted instantiation: zend_dump.c:zend_ulong_ntz
Unexecuted instantiation: zend_func_info.c:zend_ulong_ntz
zend_inference.c:zend_ulong_ntz
Line
Count
Source
47
1.04M
{
48
1.04M
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
49
1.04M
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
50
1.04M
  return __builtin_ctzl(num);
51
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
52
  return __builtin_ctzll(num);
53
#elif defined(_WIN32)
54
  unsigned long index;
55
56
#if defined(_WIN64)
57
  if (!BitScanForward64(&index, num)) {
58
#else
59
  if (!BitScanForward(&index, num)) {
60
#endif
61
    return SIZEOF_ZEND_LONG * 8;
62
  }
63
64
  return (int) index;
65
#else
66
  int n;
67
68
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
69
70
  n = 1;
71
#if SIZEOF_ZEND_LONG == 8
72
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
73
#endif
74
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
75
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
76
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
77
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
78
  return n - (num & 1);
79
#endif
80
1.04M
}
Unexecuted instantiation: zend_optimizer.c:zend_ulong_ntz
Unexecuted instantiation: zend_ssa.c:zend_ulong_ntz
Unexecuted instantiation: zend_alloc.c:zend_ulong_ntz
81
82
/* Number of leading zero bits (Undefined for zero) */
83
ZEND_ATTRIBUTE_CONST static zend_always_inline int zend_ulong_nlz(zend_ulong num)
84
0
{
85
0
#if (defined(__GNUC__) || __has_builtin(__builtin_clzl)) \
86
0
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CLZL)
87
0
  return __builtin_clzl(num);
88
#elif (defined(__GNUC__) || __has_builtin(__builtin_clzll)) && defined(PHP_HAVE_BUILTIN_CLZLL)
89
  return __builtin_clzll(num);
90
#elif defined(_WIN32)
91
  unsigned long index;
92
93
#if defined(_WIN64)
94
  if (!BitScanReverse64(&index, num)) {
95
#else
96
  if (!BitScanReverse(&index, num)) {
97
#endif
98
    return SIZEOF_ZEND_LONG * 8;
99
  }
100
101
  return (int) (SIZEOF_ZEND_LONG * 8 - 1)- index;
102
#else
103
  zend_ulong x;
104
  int n;
105
106
#if SIZEOF_ZEND_LONG == 8
107
  n = 64;
108
  x = num >> 32; if (x != 0) {n -= 32; num = x;}
109
#else
110
  n = 32;
111
#endif
112
  x = num >> 16; if (x != 0) {n -= 16; num = x;}
113
  x = num >> 8;  if (x != 0) {n -=  8; num = x;}
114
  x = num >> 4;  if (x != 0) {n -=  4; num = x;}
115
  x = num >> 2;  if (x != 0) {n -=  2; num = x;}
116
  x = num >> 1;  if (x != 0) return n - 2;
117
  return n - num;
118
#endif
119
0
}
Unexecuted instantiation: zend_jit.c:zend_ulong_nlz
Unexecuted instantiation: array.c:zend_ulong_nlz
Unexecuted instantiation: math.c:zend_ulong_nlz
Unexecuted instantiation: string.c:zend_ulong_nlz
Unexecuted instantiation: block_pass.c:zend_ulong_nlz
Unexecuted instantiation: compact_vars.c:zend_ulong_nlz
Unexecuted instantiation: dce.c:zend_ulong_nlz
Unexecuted instantiation: dfa_pass.c:zend_ulong_nlz
Unexecuted instantiation: escape_analysis.c:zend_ulong_nlz
Unexecuted instantiation: optimize_temp_vars_5.c:zend_ulong_nlz
Unexecuted instantiation: sccp.c:zend_ulong_nlz
Unexecuted instantiation: scdf.c:zend_ulong_nlz
Unexecuted instantiation: zend_call_graph.c:zend_ulong_nlz
Unexecuted instantiation: zend_cfg.c:zend_ulong_nlz
Unexecuted instantiation: zend_dfg.c:zend_ulong_nlz
Unexecuted instantiation: zend_dump.c:zend_ulong_nlz
Unexecuted instantiation: zend_func_info.c:zend_ulong_nlz
Unexecuted instantiation: zend_inference.c:zend_ulong_nlz
Unexecuted instantiation: zend_optimizer.c:zend_ulong_nlz
Unexecuted instantiation: zend_ssa.c:zend_ulong_nlz
Unexecuted instantiation: zend_alloc.c:zend_ulong_nlz
120
121
/* Returns the number of zend_ulong words needed to store a bitset that is N
122
   bits long.  */
123
static inline uint32_t zend_bitset_len(uint32_t n)
124
2.34M
{
125
2.34M
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
2.34M
}
Unexecuted instantiation: zend_jit.c:zend_bitset_len
Unexecuted instantiation: array.c:zend_bitset_len
Unexecuted instantiation: math.c:zend_bitset_len
Unexecuted instantiation: string.c:zend_bitset_len
block_pass.c:zend_bitset_len
Line
Count
Source
124
191k
{
125
191k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
191k
}
compact_vars.c:zend_bitset_len
Line
Count
Source
124
93.0k
{
125
93.0k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
93.0k
}
dce.c:zend_bitset_len
Line
Count
Source
124
142k
{
125
142k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
142k
}
Unexecuted instantiation: dfa_pass.c:zend_bitset_len
Unexecuted instantiation: escape_analysis.c:zend_bitset_len
optimize_temp_vars_5.c:zend_bitset_len
Line
Count
Source
124
93.0k
{
125
93.0k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
93.0k
}
Unexecuted instantiation: sccp.c:zend_bitset_len
scdf.c:zend_bitset_len
Line
Count
Source
124
285k
{
125
285k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
285k
}
zend_call_graph.c:zend_bitset_len
Line
Count
Source
124
49.4k
{
125
49.4k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
49.4k
}
zend_cfg.c:zend_bitset_len
Line
Count
Source
124
744k
{
125
744k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
744k
}
zend_dfg.c:zend_bitset_len
Line
Count
Source
124
71.2k
{
125
71.2k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
71.2k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_len
Unexecuted instantiation: zend_func_info.c:zend_bitset_len
zend_inference.c:zend_bitset_len
Line
Count
Source
124
599k
{
125
599k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
599k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_len
zend_ssa.c:zend_bitset_len
Line
Count
Source
124
71.2k
{
125
71.2k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
126
71.2k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_len
127
128
static inline bool zend_bitset_in(zend_bitset set, uint32_t n)
129
125M
{
130
125M
  return ZEND_BIT_TEST(set, n);
131
125M
}
Unexecuted instantiation: zend_jit.c:zend_bitset_in
Unexecuted instantiation: array.c:zend_bitset_in
Unexecuted instantiation: math.c:zend_bitset_in
Unexecuted instantiation: string.c:zend_bitset_in
block_pass.c:zend_bitset_in
Line
Count
Source
129
2.53M
{
130
2.53M
  return ZEND_BIT_TEST(set, n);
131
2.53M
}
compact_vars.c:zend_bitset_in
Line
Count
Source
129
644k
{
130
644k
  return ZEND_BIT_TEST(set, n);
131
644k
}
dce.c:zend_bitset_in
Line
Count
Source
129
1.78M
{
130
1.78M
  return ZEND_BIT_TEST(set, n);
131
1.78M
}
Unexecuted instantiation: dfa_pass.c:zend_bitset_in
Unexecuted instantiation: escape_analysis.c:zend_bitset_in
optimize_temp_vars_5.c:zend_bitset_in
Line
Count
Source
129
116M
{
130
116M
  return ZEND_BIT_TEST(set, n);
131
116M
}
sccp.c:zend_bitset_in
Line
Count
Source
129
258k
{
130
258k
  return ZEND_BIT_TEST(set, n);
131
258k
}
scdf.c:zend_bitset_in
Line
Count
Source
129
754k
{
130
754k
  return ZEND_BIT_TEST(set, n);
131
754k
}
zend_call_graph.c:zend_bitset_in
Line
Count
Source
129
26.8k
{
130
26.8k
  return ZEND_BIT_TEST(set, n);
131
26.8k
}
zend_cfg.c:zend_bitset_in
Line
Count
Source
129
1.66M
{
130
1.66M
  return ZEND_BIT_TEST(set, n);
131
1.66M
}
zend_dfg.c:zend_bitset_in
Line
Count
Source
129
1.10M
{
130
1.10M
  return ZEND_BIT_TEST(set, n);
131
1.10M
}
Unexecuted instantiation: zend_dump.c:zend_bitset_in
Unexecuted instantiation: zend_func_info.c:zend_bitset_in
zend_inference.c:zend_bitset_in
Line
Count
Source
129
118k
{
130
118k
  return ZEND_BIT_TEST(set, n);
131
118k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_in
zend_ssa.c:zend_bitset_in
Line
Count
Source
129
49.1k
{
130
49.1k
  return ZEND_BIT_TEST(set, n);
131
49.1k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_in
132
133
static inline void zend_bitset_incl(zend_bitset set, uint32_t n)
134
15.5M
{
135
15.5M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
15.5M
}
Unexecuted instantiation: zend_jit.c:zend_bitset_incl
Unexecuted instantiation: array.c:zend_bitset_incl
Unexecuted instantiation: math.c:zend_bitset_incl
Unexecuted instantiation: string.c:zend_bitset_incl
block_pass.c:zend_bitset_incl
Line
Count
Source
134
2.41M
{
135
2.41M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
2.41M
}
compact_vars.c:zend_bitset_incl
Line
Count
Source
134
2.94M
{
135
2.94M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
2.94M
}
dce.c:zend_bitset_incl
Line
Count
Source
134
1.05M
{
135
1.05M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
1.05M
}
Unexecuted instantiation: dfa_pass.c:zend_bitset_incl
Unexecuted instantiation: escape_analysis.c:zend_bitset_incl
optimize_temp_vars_5.c:zend_bitset_incl
Line
Count
Source
134
838k
{
135
838k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
838k
}
sccp.c:zend_bitset_incl
Line
Count
Source
134
1.21M
{
135
1.21M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
1.21M
}
scdf.c:zend_bitset_incl
Line
Count
Source
134
687k
{
135
687k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
687k
}
zend_call_graph.c:zend_bitset_incl
Line
Count
Source
134
24.7k
{
135
24.7k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
24.7k
}
zend_cfg.c:zend_bitset_incl
Line
Count
Source
134
1.26M
{
135
1.26M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
1.26M
}
zend_dfg.c:zend_bitset_incl
Line
Count
Source
134
1.64M
{
135
1.64M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
1.64M
}
Unexecuted instantiation: zend_dump.c:zend_bitset_incl
Unexecuted instantiation: zend_func_info.c:zend_bitset_incl
zend_inference.c:zend_bitset_incl
Line
Count
Source
134
3.41M
{
135
3.41M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
3.41M
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_incl
zend_ssa.c:zend_bitset_incl
Line
Count
Source
134
42.0k
{
135
42.0k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
136
42.0k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_incl
137
138
static inline void zend_bitset_excl(zend_bitset set, uint32_t n)
139
7.53M
{
140
7.53M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
141
7.53M
}
Unexecuted instantiation: zend_jit.c:zend_bitset_excl
Unexecuted instantiation: array.c:zend_bitset_excl
Unexecuted instantiation: math.c:zend_bitset_excl
Unexecuted instantiation: string.c:zend_bitset_excl
block_pass.c:zend_bitset_excl
Line
Count
Source
139
1.07M
{
140
1.07M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
141
1.07M
}
Unexecuted instantiation: compact_vars.c:zend_bitset_excl
dce.c:zend_bitset_excl
Line
Count
Source
139
1.19M
{
140
1.19M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
141
1.19M
}
Unexecuted instantiation: dfa_pass.c:zend_bitset_excl
Unexecuted instantiation: escape_analysis.c:zend_bitset_excl
optimize_temp_vars_5.c:zend_bitset_excl
Line
Count
Source
139
837k
{
140
837k
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
141
837k
}
Unexecuted instantiation: sccp.c:zend_bitset_excl
scdf.c:zend_bitset_excl
Line
Count
Source
139
1.82M
{
140
1.82M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
141
1.82M
}
Unexecuted instantiation: zend_call_graph.c:zend_bitset_excl
Unexecuted instantiation: zend_cfg.c:zend_bitset_excl
zend_dfg.c:zend_bitset_excl
Line
Count
Source
139
247k
{
140
247k
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
141
247k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_excl
Unexecuted instantiation: zend_func_info.c:zend_bitset_excl
zend_inference.c:zend_bitset_excl
Line
Count
Source
139
2.35M
{
140
2.35M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
141
2.35M
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_excl
Unexecuted instantiation: zend_ssa.c:zend_bitset_excl
Unexecuted instantiation: zend_alloc.c:zend_bitset_excl
142
143
static inline void zend_bitset_clear(zend_bitset set, uint32_t len)
144
833k
{
145
833k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
833k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_clear
Unexecuted instantiation: array.c:zend_bitset_clear
Unexecuted instantiation: math.c:zend_bitset_clear
Unexecuted instantiation: string.c:zend_bitset_clear
block_pass.c:zend_bitset_clear
Line
Count
Source
144
416k
{
145
416k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
416k
}
compact_vars.c:zend_bitset_clear
Line
Count
Source
144
93.0k
{
145
93.0k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
93.0k
}
Unexecuted instantiation: dce.c:zend_bitset_clear
Unexecuted instantiation: dfa_pass.c:zend_bitset_clear
Unexecuted instantiation: escape_analysis.c:zend_bitset_clear
optimize_temp_vars_5.c:zend_bitset_clear
Line
Count
Source
144
93.0k
{
145
93.0k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
93.0k
}
Unexecuted instantiation: sccp.c:zend_bitset_clear
Unexecuted instantiation: scdf.c:zend_bitset_clear
Unexecuted instantiation: zend_call_graph.c:zend_bitset_clear
zend_cfg.c:zend_bitset_clear
Line
Count
Source
144
10.9k
{
145
10.9k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
10.9k
}
zend_dfg.c:zend_bitset_clear
Line
Count
Source
144
73.1k
{
145
73.1k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
73.1k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_clear
Unexecuted instantiation: zend_func_info.c:zend_bitset_clear
zend_inference.c:zend_bitset_clear
Line
Count
Source
144
74.6k
{
145
74.6k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
74.6k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_clear
zend_ssa.c:zend_bitset_clear
Line
Count
Source
144
71.2k
{
145
71.2k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
146
71.2k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_clear
147
148
static inline bool zend_bitset_empty(zend_bitset set, uint32_t len)
149
2.23M
{
150
2.23M
  uint32_t i;
151
10.3M
  for (i = 0; i < len; i++) {
152
9.57M
    if (set[i]) {
153
1.43M
      return 0;
154
1.43M
    }
155
9.57M
  }
156
800k
  return 1;
157
2.23M
}
Unexecuted instantiation: zend_jit.c:zend_bitset_empty
Unexecuted instantiation: array.c:zend_bitset_empty
Unexecuted instantiation: math.c:zend_bitset_empty
Unexecuted instantiation: string.c:zend_bitset_empty
Unexecuted instantiation: block_pass.c:zend_bitset_empty
Unexecuted instantiation: compact_vars.c:zend_bitset_empty
dce.c:zend_bitset_empty
Line
Count
Source
149
166k
{
150
166k
  uint32_t i;
151
329k
  for (i = 0; i < len; i++) {
152
176k
    if (set[i]) {
153
13.2k
      return 0;
154
13.2k
    }
155
176k
  }
156
152k
  return 1;
157
166k
}
Unexecuted instantiation: dfa_pass.c:zend_bitset_empty
Unexecuted instantiation: escape_analysis.c:zend_bitset_empty
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_empty
Unexecuted instantiation: sccp.c:zend_bitset_empty
scdf.c:zend_bitset_empty
Line
Count
Source
149
432k
{
150
432k
  uint32_t i;
151
796k
  for (i = 0; i < len; i++) {
152
438k
    if (set[i]) {
153
75.1k
      return 0;
154
75.1k
    }
155
438k
  }
156
357k
  return 1;
157
432k
}
Unexecuted instantiation: zend_call_graph.c:zend_bitset_empty
Unexecuted instantiation: zend_cfg.c:zend_bitset_empty
zend_dfg.c:zend_bitset_empty
Line
Count
Source
149
318k
{
150
318k
  uint32_t i;
151
390k
  for (i = 0; i < len; i++) {
152
319k
    if (set[i]) {
153
247k
      return 0;
154
247k
    }
155
319k
  }
156
71.2k
  return 1;
157
318k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_empty
Unexecuted instantiation: zend_func_info.c:zend_bitset_empty
zend_inference.c:zend_bitset_empty
Line
Count
Source
149
1.11M
{
150
1.11M
  uint32_t i;
151
8.25M
  for (i = 0; i < len; i++) {
152
8.18M
    if (set[i]) {
153
1.04M
      return 0;
154
1.04M
    }
155
8.18M
  }
156
71.2k
  return 1;
157
1.11M
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_empty
zend_ssa.c:zend_bitset_empty
Line
Count
Source
149
199k
{
150
199k
  uint32_t i;
151
599k
  for (i = 0; i < len; i++) {
152
451k
    if (set[i]) {
153
51.7k
      return 0;
154
51.7k
    }
155
451k
  }
156
147k
  return 1;
157
199k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_empty
158
159
static inline void zend_bitset_fill(zend_bitset set, uint32_t len)
160
0
{
161
0
  memset(set, 0xff, len * ZEND_BITSET_ELM_SIZE);
162
0
}
Unexecuted instantiation: zend_jit.c:zend_bitset_fill
Unexecuted instantiation: array.c:zend_bitset_fill
Unexecuted instantiation: math.c:zend_bitset_fill
Unexecuted instantiation: string.c:zend_bitset_fill
Unexecuted instantiation: block_pass.c:zend_bitset_fill
Unexecuted instantiation: compact_vars.c:zend_bitset_fill
Unexecuted instantiation: dce.c:zend_bitset_fill
Unexecuted instantiation: dfa_pass.c:zend_bitset_fill
Unexecuted instantiation: escape_analysis.c:zend_bitset_fill
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_fill
Unexecuted instantiation: sccp.c:zend_bitset_fill
Unexecuted instantiation: scdf.c:zend_bitset_fill
Unexecuted instantiation: zend_call_graph.c:zend_bitset_fill
Unexecuted instantiation: zend_cfg.c:zend_bitset_fill
Unexecuted instantiation: zend_dfg.c:zend_bitset_fill
Unexecuted instantiation: zend_dump.c:zend_bitset_fill
Unexecuted instantiation: zend_func_info.c:zend_bitset_fill
Unexecuted instantiation: zend_inference.c:zend_bitset_fill
Unexecuted instantiation: zend_optimizer.c:zend_bitset_fill
Unexecuted instantiation: zend_ssa.c:zend_bitset_fill
Unexecuted instantiation: zend_alloc.c:zend_bitset_fill
163
164
static inline bool zend_bitset_equal(zend_bitset set1, zend_bitset set2, uint32_t len)
165
247k
{
166
247k
    return memcmp(set1, set2, len * ZEND_BITSET_ELM_SIZE) == 0;
167
247k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_equal
Unexecuted instantiation: array.c:zend_bitset_equal
Unexecuted instantiation: math.c:zend_bitset_equal
Unexecuted instantiation: string.c:zend_bitset_equal
Unexecuted instantiation: block_pass.c:zend_bitset_equal
Unexecuted instantiation: compact_vars.c:zend_bitset_equal
Unexecuted instantiation: dce.c:zend_bitset_equal
Unexecuted instantiation: dfa_pass.c:zend_bitset_equal
Unexecuted instantiation: escape_analysis.c:zend_bitset_equal
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_equal
Unexecuted instantiation: sccp.c:zend_bitset_equal
Unexecuted instantiation: scdf.c:zend_bitset_equal
Unexecuted instantiation: zend_call_graph.c:zend_bitset_equal
Unexecuted instantiation: zend_cfg.c:zend_bitset_equal
zend_dfg.c:zend_bitset_equal
Line
Count
Source
165
247k
{
166
247k
    return memcmp(set1, set2, len * ZEND_BITSET_ELM_SIZE) == 0;
167
247k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_equal
Unexecuted instantiation: zend_func_info.c:zend_bitset_equal
Unexecuted instantiation: zend_inference.c:zend_bitset_equal
Unexecuted instantiation: zend_optimizer.c:zend_bitset_equal
Unexecuted instantiation: zend_ssa.c:zend_bitset_equal
Unexecuted instantiation: zend_alloc.c:zend_bitset_equal
168
169
static inline void zend_bitset_copy(zend_bitset set1, zend_bitset set2, uint32_t len)
170
656k
{
171
656k
    memcpy(set1, set2, len * ZEND_BITSET_ELM_SIZE);
172
656k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_copy
Unexecuted instantiation: array.c:zend_bitset_copy
Unexecuted instantiation: math.c:zend_bitset_copy
Unexecuted instantiation: string.c:zend_bitset_copy
block_pass.c:zend_bitset_copy
Line
Count
Source
170
304k
{
171
304k
    memcpy(set1, set2, len * ZEND_BITSET_ELM_SIZE);
172
304k
}
Unexecuted instantiation: compact_vars.c:zend_bitset_copy
Unexecuted instantiation: dce.c:zend_bitset_copy
Unexecuted instantiation: dfa_pass.c:zend_bitset_copy
Unexecuted instantiation: escape_analysis.c:zend_bitset_copy
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_copy
Unexecuted instantiation: sccp.c:zend_bitset_copy
Unexecuted instantiation: scdf.c:zend_bitset_copy
Unexecuted instantiation: zend_call_graph.c:zend_bitset_copy
Unexecuted instantiation: zend_cfg.c:zend_bitset_copy
zend_dfg.c:zend_bitset_copy
Line
Count
Source
170
351k
{
171
351k
    memcpy(set1, set2, len * ZEND_BITSET_ELM_SIZE);
172
351k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_copy
Unexecuted instantiation: zend_func_info.c:zend_bitset_copy
Unexecuted instantiation: zend_inference.c:zend_bitset_copy
Unexecuted instantiation: zend_optimizer.c:zend_bitset_copy
Unexecuted instantiation: zend_ssa.c:zend_bitset_copy
Unexecuted instantiation: zend_alloc.c:zend_bitset_copy
173
174
static inline void zend_bitset_intersection(zend_bitset set1, zend_bitset set2, uint32_t len)
175
0
{
176
0
    uint32_t i;
177
178
0
    for (i = 0; i < len; i++) {
179
0
    set1[i] &= set2[i];
180
0
  }
181
0
}
Unexecuted instantiation: zend_jit.c:zend_bitset_intersection
Unexecuted instantiation: array.c:zend_bitset_intersection
Unexecuted instantiation: math.c:zend_bitset_intersection
Unexecuted instantiation: string.c:zend_bitset_intersection
Unexecuted instantiation: block_pass.c:zend_bitset_intersection
Unexecuted instantiation: compact_vars.c:zend_bitset_intersection
Unexecuted instantiation: dce.c:zend_bitset_intersection
Unexecuted instantiation: dfa_pass.c:zend_bitset_intersection
Unexecuted instantiation: escape_analysis.c:zend_bitset_intersection
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_intersection
Unexecuted instantiation: sccp.c:zend_bitset_intersection
Unexecuted instantiation: scdf.c:zend_bitset_intersection
Unexecuted instantiation: zend_call_graph.c:zend_bitset_intersection
Unexecuted instantiation: zend_cfg.c:zend_bitset_intersection
Unexecuted instantiation: zend_dfg.c:zend_bitset_intersection
Unexecuted instantiation: zend_dump.c:zend_bitset_intersection
Unexecuted instantiation: zend_func_info.c:zend_bitset_intersection
Unexecuted instantiation: zend_inference.c:zend_bitset_intersection
Unexecuted instantiation: zend_optimizer.c:zend_bitset_intersection
Unexecuted instantiation: zend_ssa.c:zend_bitset_intersection
Unexecuted instantiation: zend_alloc.c:zend_bitset_intersection
182
183
static inline void zend_bitset_union(zend_bitset set1, zend_bitset set2, uint32_t len)
184
256k
{
185
256k
  uint32_t i;
186
187
1.30M
  for (i = 0; i < len; i++) {
188
1.05M
    set1[i] |= set2[i];
189
1.05M
  }
190
256k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_union
Unexecuted instantiation: array.c:zend_bitset_union
Unexecuted instantiation: math.c:zend_bitset_union
Unexecuted instantiation: string.c:zend_bitset_union
block_pass.c:zend_bitset_union
Line
Count
Source
184
118k
{
185
118k
  uint32_t i;
186
187
490k
  for (i = 0; i < len; i++) {
188
371k
    set1[i] |= set2[i];
189
371k
  }
190
118k
}
Unexecuted instantiation: compact_vars.c:zend_bitset_union
Unexecuted instantiation: dce.c:zend_bitset_union
Unexecuted instantiation: dfa_pass.c:zend_bitset_union
Unexecuted instantiation: escape_analysis.c:zend_bitset_union
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_union
Unexecuted instantiation: sccp.c:zend_bitset_union
Unexecuted instantiation: scdf.c:zend_bitset_union
Unexecuted instantiation: zend_call_graph.c:zend_bitset_union
Unexecuted instantiation: zend_cfg.c:zend_bitset_union
zend_dfg.c:zend_bitset_union
Line
Count
Source
184
88.1k
{
185
88.1k
  uint32_t i;
186
187
480k
  for (i = 0; i < len; i++) {
188
392k
    set1[i] |= set2[i];
189
392k
  }
190
88.1k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_union
Unexecuted instantiation: zend_func_info.c:zend_bitset_union
zend_inference.c:zend_bitset_union
Line
Count
Source
184
4
{
185
4
  uint32_t i;
186
187
8
  for (i = 0; i < len; i++) {
188
4
    set1[i] |= set2[i];
189
4
  }
190
4
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_union
zend_ssa.c:zend_bitset_union
Line
Count
Source
184
49.3k
{
185
49.3k
  uint32_t i;
186
187
337k
  for (i = 0; i < len; i++) {
188
287k
    set1[i] |= set2[i];
189
287k
  }
190
49.3k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_union
191
192
static inline void zend_bitset_difference(zend_bitset set1, zend_bitset set2, uint32_t len)
193
0
{
194
0
  uint32_t i;
195
0
196
0
  for (i = 0; i < len; i++) {
197
0
    set1[i] = set1[i] & ~set2[i];
198
0
  }
199
0
}
Unexecuted instantiation: zend_jit.c:zend_bitset_difference
Unexecuted instantiation: array.c:zend_bitset_difference
Unexecuted instantiation: math.c:zend_bitset_difference
Unexecuted instantiation: string.c:zend_bitset_difference
Unexecuted instantiation: block_pass.c:zend_bitset_difference
Unexecuted instantiation: compact_vars.c:zend_bitset_difference
Unexecuted instantiation: dce.c:zend_bitset_difference
Unexecuted instantiation: dfa_pass.c:zend_bitset_difference
Unexecuted instantiation: escape_analysis.c:zend_bitset_difference
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_difference
Unexecuted instantiation: sccp.c:zend_bitset_difference
Unexecuted instantiation: scdf.c:zend_bitset_difference
Unexecuted instantiation: zend_call_graph.c:zend_bitset_difference
Unexecuted instantiation: zend_cfg.c:zend_bitset_difference
Unexecuted instantiation: zend_dfg.c:zend_bitset_difference
Unexecuted instantiation: zend_dump.c:zend_bitset_difference
Unexecuted instantiation: zend_func_info.c:zend_bitset_difference
Unexecuted instantiation: zend_inference.c:zend_bitset_difference
Unexecuted instantiation: zend_optimizer.c:zend_bitset_difference
Unexecuted instantiation: zend_ssa.c:zend_bitset_difference
Unexecuted instantiation: zend_alloc.c:zend_bitset_difference
200
201
static inline void zend_bitset_union_with_intersection(zend_bitset set1, zend_bitset set2, zend_bitset set3, zend_bitset set4, uint32_t len)
202
214k
{
203
214k
  uint32_t i;
204
205
1.12M
  for (i = 0; i < len; i++) {
206
915k
    set1[i] = set2[i] | (set3[i] & set4[i]);
207
915k
  }
208
214k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_union_with_intersection
Unexecuted instantiation: array.c:zend_bitset_union_with_intersection
Unexecuted instantiation: math.c:zend_bitset_union_with_intersection
Unexecuted instantiation: string.c:zend_bitset_union_with_intersection
Unexecuted instantiation: block_pass.c:zend_bitset_union_with_intersection
Unexecuted instantiation: compact_vars.c:zend_bitset_union_with_intersection
Unexecuted instantiation: dce.c:zend_bitset_union_with_intersection
Unexecuted instantiation: dfa_pass.c:zend_bitset_union_with_intersection
Unexecuted instantiation: escape_analysis.c:zend_bitset_union_with_intersection
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_union_with_intersection
Unexecuted instantiation: sccp.c:zend_bitset_union_with_intersection
Unexecuted instantiation: scdf.c:zend_bitset_union_with_intersection
Unexecuted instantiation: zend_call_graph.c:zend_bitset_union_with_intersection
Unexecuted instantiation: zend_cfg.c:zend_bitset_union_with_intersection
Unexecuted instantiation: zend_dfg.c:zend_bitset_union_with_intersection
Unexecuted instantiation: zend_dump.c:zend_bitset_union_with_intersection
Unexecuted instantiation: zend_func_info.c:zend_bitset_union_with_intersection
Unexecuted instantiation: zend_inference.c:zend_bitset_union_with_intersection
Unexecuted instantiation: zend_optimizer.c:zend_bitset_union_with_intersection
zend_ssa.c:zend_bitset_union_with_intersection
Line
Count
Source
202
214k
{
203
214k
  uint32_t i;
204
205
1.12M
  for (i = 0; i < len; i++) {
206
915k
    set1[i] = set2[i] | (set3[i] & set4[i]);
207
915k
  }
208
214k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_union_with_intersection
209
210
static inline void zend_bitset_union_with_difference(zend_bitset set1, zend_bitset set2, zend_bitset set3, zend_bitset set4, uint32_t len)
211
247k
{
212
247k
  uint32_t i;
213
214
1.09M
  for (i = 0; i < len; i++) {
215
849k
    set1[i] = set2[i] | (set3[i] & ~set4[i]);
216
849k
  }
217
247k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_union_with_difference
Unexecuted instantiation: array.c:zend_bitset_union_with_difference
Unexecuted instantiation: math.c:zend_bitset_union_with_difference
Unexecuted instantiation: string.c:zend_bitset_union_with_difference
Unexecuted instantiation: block_pass.c:zend_bitset_union_with_difference
Unexecuted instantiation: compact_vars.c:zend_bitset_union_with_difference
Unexecuted instantiation: dce.c:zend_bitset_union_with_difference
Unexecuted instantiation: dfa_pass.c:zend_bitset_union_with_difference
Unexecuted instantiation: escape_analysis.c:zend_bitset_union_with_difference
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_union_with_difference
Unexecuted instantiation: sccp.c:zend_bitset_union_with_difference
Unexecuted instantiation: scdf.c:zend_bitset_union_with_difference
Unexecuted instantiation: zend_call_graph.c:zend_bitset_union_with_difference
Unexecuted instantiation: zend_cfg.c:zend_bitset_union_with_difference
zend_dfg.c:zend_bitset_union_with_difference
Line
Count
Source
211
247k
{
212
247k
  uint32_t i;
213
214
1.09M
  for (i = 0; i < len; i++) {
215
849k
    set1[i] = set2[i] | (set3[i] & ~set4[i]);
216
849k
  }
217
247k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_union_with_difference
Unexecuted instantiation: zend_func_info.c:zend_bitset_union_with_difference
Unexecuted instantiation: zend_inference.c:zend_bitset_union_with_difference
Unexecuted instantiation: zend_optimizer.c:zend_bitset_union_with_difference
Unexecuted instantiation: zend_ssa.c:zend_bitset_union_with_difference
Unexecuted instantiation: zend_alloc.c:zend_bitset_union_with_difference
218
219
static inline bool zend_bitset_subset(zend_bitset set1, zend_bitset set2, uint32_t len)
220
115k
{
221
115k
  uint32_t i;
222
223
446k
  for (i = 0; i < len; i++) {
224
380k
    if (set1[i] & ~set2[i]) {
225
49.3k
      return 0;
226
49.3k
    }
227
380k
  }
228
66.0k
  return 1;
229
115k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_subset
Unexecuted instantiation: array.c:zend_bitset_subset
Unexecuted instantiation: math.c:zend_bitset_subset
Unexecuted instantiation: string.c:zend_bitset_subset
Unexecuted instantiation: block_pass.c:zend_bitset_subset
Unexecuted instantiation: compact_vars.c:zend_bitset_subset
Unexecuted instantiation: dce.c:zend_bitset_subset
Unexecuted instantiation: dfa_pass.c:zend_bitset_subset
Unexecuted instantiation: escape_analysis.c:zend_bitset_subset
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_subset
Unexecuted instantiation: sccp.c:zend_bitset_subset
Unexecuted instantiation: scdf.c:zend_bitset_subset
Unexecuted instantiation: zend_call_graph.c:zend_bitset_subset
Unexecuted instantiation: zend_cfg.c:zend_bitset_subset
Unexecuted instantiation: zend_dfg.c:zend_bitset_subset
Unexecuted instantiation: zend_dump.c:zend_bitset_subset
Unexecuted instantiation: zend_func_info.c:zend_bitset_subset
Unexecuted instantiation: zend_inference.c:zend_bitset_subset
Unexecuted instantiation: zend_optimizer.c:zend_bitset_subset
zend_ssa.c:zend_bitset_subset
Line
Count
Source
220
115k
{
221
115k
  uint32_t i;
222
223
446k
  for (i = 0; i < len; i++) {
224
380k
    if (set1[i] & ~set2[i]) {
225
49.3k
      return 0;
226
49.3k
    }
227
380k
  }
228
66.0k
  return 1;
229
115k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_subset
230
231
static inline int zend_bitset_first(zend_bitset set, uint32_t len)
232
1.72M
{
233
1.72M
  uint32_t i;
234
235
10.1M
  for (i = 0; i < len; i++) {
236
9.84M
    if (set[i]) {
237
1.40M
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
238
1.40M
    }
239
9.84M
  }
240
323k
  return -1; /* empty set */
241
1.72M
}
Unexecuted instantiation: zend_jit.c:zend_bitset_first
Unexecuted instantiation: array.c:zend_bitset_first
Unexecuted instantiation: math.c:zend_bitset_first
Unexecuted instantiation: string.c:zend_bitset_first
Unexecuted instantiation: block_pass.c:zend_bitset_first
Unexecuted instantiation: compact_vars.c:zend_bitset_first
dce.c:zend_bitset_first
Line
Count
Source
232
239k
{
233
239k
  uint32_t i;
234
235
1.26M
  for (i = 0; i < len; i++) {
236
1.17M
    if (set[i]) {
237
142k
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
238
142k
    }
239
1.17M
  }
240
97.7k
  return -1; /* empty set */
241
239k
}
Unexecuted instantiation: dfa_pass.c:zend_bitset_first
Unexecuted instantiation: escape_analysis.c:zend_bitset_first
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_first
Unexecuted instantiation: sccp.c:zend_bitset_first
scdf.c:zend_bitset_first
Line
Count
Source
232
440k
{
233
440k
  uint32_t i;
234
235
774k
  for (i = 0; i < len; i++) {
236
549k
    if (set[i]) {
237
215k
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
238
215k
    }
239
549k
  }
240
225k
  return -1; /* empty set */
241
440k
}
Unexecuted instantiation: zend_call_graph.c:zend_bitset_first
Unexecuted instantiation: zend_cfg.c:zend_bitset_first
Unexecuted instantiation: zend_dfg.c:zend_bitset_first
Unexecuted instantiation: zend_dump.c:zend_bitset_first
Unexecuted instantiation: zend_func_info.c:zend_bitset_first
zend_inference.c:zend_bitset_first
Line
Count
Source
232
1.04M
{
233
1.04M
  uint32_t i;
234
235
8.12M
  for (i = 0; i < len; i++) {
236
8.12M
    if (set[i]) {
237
1.04M
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
238
1.04M
    }
239
8.12M
  }
240
0
  return -1; /* empty set */
241
1.04M
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_first
Unexecuted instantiation: zend_ssa.c:zend_bitset_first
Unexecuted instantiation: zend_alloc.c:zend_bitset_first
242
243
static inline int zend_bitset_last(zend_bitset set, uint32_t len)
244
247k
{
245
247k
  uint32_t i = len;
246
247
407k
  while (i > 0) {
248
407k
    i--;
249
407k
    if (set[i]) {
250
247k
      int j = ZEND_BITSET_ELM_SIZE * 8 * i - 1;
251
247k
      zend_ulong x = set[i];
252
3.43M
      while (x != Z_UL(0)) {
253
3.18M
        x = x >> Z_UL(1);
254
3.18M
        j++;
255
3.18M
      }
256
247k
      return j;
257
247k
    }
258
407k
  }
259
0
  return -1; /* empty set */
260
247k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_last
Unexecuted instantiation: array.c:zend_bitset_last
Unexecuted instantiation: math.c:zend_bitset_last
Unexecuted instantiation: string.c:zend_bitset_last
Unexecuted instantiation: block_pass.c:zend_bitset_last
Unexecuted instantiation: compact_vars.c:zend_bitset_last
Unexecuted instantiation: dce.c:zend_bitset_last
Unexecuted instantiation: dfa_pass.c:zend_bitset_last
Unexecuted instantiation: escape_analysis.c:zend_bitset_last
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_last
Unexecuted instantiation: sccp.c:zend_bitset_last
Unexecuted instantiation: scdf.c:zend_bitset_last
Unexecuted instantiation: zend_call_graph.c:zend_bitset_last
Unexecuted instantiation: zend_cfg.c:zend_bitset_last
zend_dfg.c:zend_bitset_last
Line
Count
Source
244
247k
{
245
247k
  uint32_t i = len;
246
247
407k
  while (i > 0) {
248
407k
    i--;
249
407k
    if (set[i]) {
250
247k
      int j = ZEND_BITSET_ELM_SIZE * 8 * i - 1;
251
247k
      zend_ulong x = set[i];
252
3.43M
      while (x != Z_UL(0)) {
253
3.18M
        x = x >> Z_UL(1);
254
3.18M
        j++;
255
3.18M
      }
256
247k
      return j;
257
247k
    }
258
407k
  }
259
0
  return -1; /* empty set */
260
247k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_last
Unexecuted instantiation: zend_func_info.c:zend_bitset_last
Unexecuted instantiation: zend_inference.c:zend_bitset_last
Unexecuted instantiation: zend_optimizer.c:zend_bitset_last
Unexecuted instantiation: zend_ssa.c:zend_bitset_last
Unexecuted instantiation: zend_alloc.c:zend_bitset_last
261
262
855k
#define ZEND_BITSET_FOREACH(set, len, bit) do { \
263
855k
  zend_bitset _set = (set); \
264
855k
  uint32_t _i, _len = (len); \
265
2.63M
  for (_i = 0; _i < _len; _i++) { \
266
1.78M
    zend_ulong _x = _set[_i]; \
267
1.78M
    if (_x) { \
268
387k
      (bit) = ZEND_BITSET_ELM_SIZE * 8 * _i; \
269
9.29M
      for (; _x != 0; _x >>= Z_UL(1), (bit)++) { \
270
8.90M
        if (!(_x & Z_UL(1))) continue;
271
272
51.7k
#define ZEND_BITSET_REVERSE_FOREACH(set, len, bit) do { \
273
51.7k
  zend_bitset _set = (set); \
274
51.7k
  uint32_t _i = (len); \
275
51.7k
  zend_ulong _test = Z_UL(1) << (ZEND_BITSET_ELM_SIZE * 8 - 1); \
276
342k
  while (_i-- > 0) { \
277
290k
    zend_ulong _x = _set[_i]; \
278
290k
    if (_x) { \
279
69.5k
      (bit) = ZEND_BITSET_ELM_SIZE * 8 * (_i + 1) - 1; \
280
3.72M
      for (; _x != 0; _x <<= Z_UL(1), (bit)--) { \
281
3.65M
        if (!(_x & _test)) continue; \
282
283
#define ZEND_BITSET_FOREACH_END() \
284
1.43M
      } \
285
457k
    } \
286
2.07M
  } \
287
907k
} while (0)
288
289
680k
static inline int zend_bitset_pop_first(zend_bitset set, uint32_t len) {
290
680k
  int i = zend_bitset_first(set, len);
291
680k
  if (i >= 0) {
292
357k
    zend_bitset_excl(set, i);
293
357k
  }
294
680k
  return i;
295
680k
}
Unexecuted instantiation: zend_jit.c:zend_bitset_pop_first
Unexecuted instantiation: array.c:zend_bitset_pop_first
Unexecuted instantiation: math.c:zend_bitset_pop_first
Unexecuted instantiation: string.c:zend_bitset_pop_first
Unexecuted instantiation: block_pass.c:zend_bitset_pop_first
Unexecuted instantiation: compact_vars.c:zend_bitset_pop_first
dce.c:zend_bitset_pop_first
Line
Count
Source
289
239k
static inline int zend_bitset_pop_first(zend_bitset set, uint32_t len) {
290
239k
  int i = zend_bitset_first(set, len);
291
239k
  if (i >= 0) {
292
142k
    zend_bitset_excl(set, i);
293
142k
  }
294
239k
  return i;
295
239k
}
Unexecuted instantiation: dfa_pass.c:zend_bitset_pop_first
Unexecuted instantiation: escape_analysis.c:zend_bitset_pop_first
Unexecuted instantiation: optimize_temp_vars_5.c:zend_bitset_pop_first
Unexecuted instantiation: sccp.c:zend_bitset_pop_first
scdf.c:zend_bitset_pop_first
Line
Count
Source
289
440k
static inline int zend_bitset_pop_first(zend_bitset set, uint32_t len) {
290
440k
  int i = zend_bitset_first(set, len);
291
440k
  if (i >= 0) {
292
215k
    zend_bitset_excl(set, i);
293
215k
  }
294
440k
  return i;
295
440k
}
Unexecuted instantiation: zend_call_graph.c:zend_bitset_pop_first
Unexecuted instantiation: zend_cfg.c:zend_bitset_pop_first
Unexecuted instantiation: zend_dfg.c:zend_bitset_pop_first
Unexecuted instantiation: zend_dump.c:zend_bitset_pop_first
Unexecuted instantiation: zend_func_info.c:zend_bitset_pop_first
Unexecuted instantiation: zend_inference.c:zend_bitset_pop_first
Unexecuted instantiation: zend_optimizer.c:zend_bitset_pop_first
Unexecuted instantiation: zend_ssa.c:zend_bitset_pop_first
Unexecuted instantiation: zend_alloc.c:zend_bitset_pop_first
296
297
#endif /* _ZEND_BITSET_H_ */