Coverage Report

Created: 2025-12-14 06:09

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 (c) The PHP Group                                          |
6
   +----------------------------------------------------------------------+
7
   | This source file is subject to version 3.01 of the PHP license,      |
8
   | that is bundled with this package in the file LICENSE, and is        |
9
   | available through the world-wide-web at the following url:           |
10
   | https://www.php.net/license/3_01.txt                                 |
11
   | If you did not receive a copy of the PHP license and are unable to   |
12
   | obtain it through the world-wide-web, please send a note to          |
13
   | license@php.net so we can mail you a copy immediately.               |
14
   +----------------------------------------------------------------------+
15
   | Authors: Dmitry Stogov <dmitry@php.net>                              |
16
   +----------------------------------------------------------------------+
17
*/
18
19
#ifndef _ZEND_BITSET_H_
20
#define _ZEND_BITSET_H_
21
22
#include <stdint.h>
23
#include <stdbool.h>
24
#include <string.h>
25
26
#include "zend_portability.h"
27
#include "zend_long.h"
28
29
typedef zend_ulong *zend_bitset;
30
31
2.39M
#define ZEND_BITSET_ELM_SIZE sizeof(zend_ulong)
32
33
#if SIZEOF_ZEND_LONG == 4
34
# define ZEND_BITSET_ELM_NUM(n)   ((n) >> 5)
35
# define ZEND_BITSET_BIT_NUM(n)   ((zend_ulong)(n) & Z_UL(0x1f))
36
#elif SIZEOF_ZEND_LONG == 8
37
13.7M
# define ZEND_BITSET_ELM_NUM(n)   ((n) >> 6)
38
13.7M
# define ZEND_BITSET_BIT_NUM(n)   ((zend_ulong)(n) & Z_UL(0x3f))
39
#else
40
# define ZEND_BITSET_ELM_NUM(n)   ((n) / (sizeof(zend_long) * 8))
41
# define ZEND_BITSET_BIT_NUM(n)   ((n) % (sizeof(zend_long) * 8))
42
#endif
43
44
#define ZEND_BITSET_ALLOCA(n, use_heap) \
45
156k
  (zend_bitset)do_alloca((n) * ZEND_BITSET_ELM_SIZE, use_heap)
46
47
/* Number of trailing zero bits (0x01 -> 0; 0x40 -> 6; 0x00 -> LEN) */
48
ZEND_ATTRIBUTE_CONST static zend_always_inline int zend_ulong_ntz(zend_ulong num)
49
851k
{
50
851k
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
51
851k
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
52
851k
  return __builtin_ctzl(num);
53
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
54
  return __builtin_ctzll(num);
55
#elif defined(_WIN32)
56
  unsigned long index;
57
58
#if defined(_WIN64)
59
  if (!BitScanForward64(&index, num)) {
60
#else
61
  if (!BitScanForward(&index, num)) {
62
#endif
63
    return SIZEOF_ZEND_LONG * 8;
64
  }
65
66
  return (int) index;
67
#else
68
  int n;
69
70
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
71
72
  n = 1;
73
#if SIZEOF_ZEND_LONG == 8
74
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
75
#endif
76
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
77
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
78
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
79
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
80
  return n - (num & 1);
81
#endif
82
851k
}
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
49
95.7k
{
50
95.7k
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
51
95.7k
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
52
95.7k
  return __builtin_ctzl(num);
53
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
54
  return __builtin_ctzll(num);
55
#elif defined(_WIN32)
56
  unsigned long index;
57
58
#if defined(_WIN64)
59
  if (!BitScanForward64(&index, num)) {
60
#else
61
  if (!BitScanForward(&index, num)) {
62
#endif
63
    return SIZEOF_ZEND_LONG * 8;
64
  }
65
66
  return (int) index;
67
#else
68
  int n;
69
70
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
71
72
  n = 1;
73
#if SIZEOF_ZEND_LONG == 8
74
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
75
#endif
76
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
77
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
78
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
79
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
80
  return n - (num & 1);
81
#endif
82
95.7k
}
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
49
120k
{
50
120k
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
51
120k
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
52
120k
  return __builtin_ctzl(num);
53
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
54
  return __builtin_ctzll(num);
55
#elif defined(_WIN32)
56
  unsigned long index;
57
58
#if defined(_WIN64)
59
  if (!BitScanForward64(&index, num)) {
60
#else
61
  if (!BitScanForward(&index, num)) {
62
#endif
63
    return SIZEOF_ZEND_LONG * 8;
64
  }
65
66
  return (int) index;
67
#else
68
  int n;
69
70
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
71
72
  n = 1;
73
#if SIZEOF_ZEND_LONG == 8
74
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
75
#endif
76
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
77
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
78
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
79
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
80
  return n - (num & 1);
81
#endif
82
120k
}
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
49
634k
{
50
634k
#if (defined(__GNUC__) || __has_builtin(__builtin_ctzl)) \
51
634k
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CTZL)
52
634k
  return __builtin_ctzl(num);
53
#elif (defined(__GNUC__) || __has_builtin(__builtin_ctzll)) && defined(PHP_HAVE_BUILTIN_CTZLL)
54
  return __builtin_ctzll(num);
55
#elif defined(_WIN32)
56
  unsigned long index;
57
58
#if defined(_WIN64)
59
  if (!BitScanForward64(&index, num)) {
60
#else
61
  if (!BitScanForward(&index, num)) {
62
#endif
63
    return SIZEOF_ZEND_LONG * 8;
64
  }
65
66
  return (int) index;
67
#else
68
  int n;
69
70
  if (num == Z_UL(0)) return SIZEOF_ZEND_LONG * 8;
71
72
  n = 1;
73
#if SIZEOF_ZEND_LONG == 8
74
  if ((num & 0xffffffff) == 0) {n += 32; num = num >> Z_UL(32);}
75
#endif
76
  if ((num & 0x0000ffff) == 0) {n += 16; num = num >> 16;}
77
  if ((num & 0x000000ff) == 0) {n +=  8; num = num >>  8;}
78
  if ((num & 0x0000000f) == 0) {n +=  4; num = num >>  4;}
79
  if ((num & 0x00000003) == 0) {n +=  2; num = num >>  2;}
80
  return n - (num & 1);
81
#endif
82
634k
}
Unexecuted instantiation: zend_optimizer.c:zend_ulong_ntz
Unexecuted instantiation: zend_ssa.c:zend_ulong_ntz
Unexecuted instantiation: zend_alloc.c:zend_ulong_ntz
83
84
/* Number of leading zero bits (Undefined for zero) */
85
ZEND_ATTRIBUTE_CONST static zend_always_inline int zend_ulong_nlz(zend_ulong num)
86
0
{
87
0
#if (defined(__GNUC__) || __has_builtin(__builtin_clzl)) \
88
0
  && SIZEOF_ZEND_LONG == SIZEOF_LONG && defined(PHP_HAVE_BUILTIN_CLZL)
89
0
  return __builtin_clzl(num);
90
#elif (defined(__GNUC__) || __has_builtin(__builtin_clzll)) && defined(PHP_HAVE_BUILTIN_CLZLL)
91
  return __builtin_clzll(num);
92
#elif defined(_WIN32)
93
  unsigned long index;
94
95
#if defined(_WIN64)
96
  if (!BitScanReverse64(&index, num)) {
97
#else
98
  if (!BitScanReverse(&index, num)) {
99
#endif
100
    return SIZEOF_ZEND_LONG * 8;
101
  }
102
103
  return (int) (SIZEOF_ZEND_LONG * 8 - 1)- index;
104
#else
105
  zend_ulong x;
106
  int n;
107
108
#if SIZEOF_ZEND_LONG == 8
109
  n = 64;
110
  x = num >> 32; if (x != 0) {n -= 32; num = x;}
111
#else
112
  n = 32;
113
#endif
114
  x = num >> 16; if (x != 0) {n -= 16; num = x;}
115
  x = num >> 8;  if (x != 0) {n -=  8; num = x;}
116
  x = num >> 4;  if (x != 0) {n -=  4; num = x;}
117
  x = num >> 2;  if (x != 0) {n -=  2; num = x;}
118
  x = num >> 1;  if (x != 0) return n - 2;
119
  return n - num;
120
#endif
121
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
122
123
/* Returns the number of zend_ulong words needed to store a bitset that is N
124
   bits long.  */
125
static inline uint32_t zend_bitset_len(uint32_t n)
126
1.25M
{
127
1.25M
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
1.25M
}
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
126
108k
{
127
108k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
108k
}
compact_vars.c:zend_bitset_len
Line
Count
Source
126
51.4k
{
127
51.4k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
51.4k
}
dce.c:zend_bitset_len
Line
Count
Source
126
74.0k
{
127
74.0k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
74.0k
}
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
126
51.4k
{
127
51.4k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
51.4k
}
Unexecuted instantiation: sccp.c:zend_bitset_len
scdf.c:zend_bitset_len
Line
Count
Source
126
148k
{
127
148k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
148k
}
zend_call_graph.c:zend_bitset_len
Line
Count
Source
126
31.0k
{
127
31.0k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
31.0k
}
zend_cfg.c:zend_bitset_len
Line
Count
Source
126
420k
{
127
420k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
420k
}
zend_dfg.c:zend_bitset_len
Line
Count
Source
126
37.0k
{
127
37.0k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
37.0k
}
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
126
300k
{
127
300k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
300k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_len
zend_ssa.c:zend_bitset_len
Line
Count
Source
126
37.0k
{
127
37.0k
  return (n + ((sizeof(zend_long) * 8) - 1)) / (sizeof(zend_long) * 8);
128
37.0k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_len
129
130
static inline bool zend_bitset_in(zend_bitset set, uint32_t n)
131
68.6M
{
132
68.6M
  return ZEND_BIT_TEST(set, n);
133
68.6M
}
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
131
1.54M
{
132
1.54M
  return ZEND_BIT_TEST(set, n);
133
1.54M
}
compact_vars.c:zend_bitset_in
Line
Count
Source
131
371k
{
132
371k
  return ZEND_BIT_TEST(set, n);
133
371k
}
dce.c:zend_bitset_in
Line
Count
Source
131
1.07M
{
132
1.07M
  return ZEND_BIT_TEST(set, n);
133
1.07M
}
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
131
63.3M
{
132
63.3M
  return ZEND_BIT_TEST(set, n);
133
63.3M
}
sccp.c:zend_bitset_in
Line
Count
Source
131
166k
{
132
166k
  return ZEND_BIT_TEST(set, n);
133
166k
}
scdf.c:zend_bitset_in
Line
Count
Source
131
457k
{
132
457k
  return ZEND_BIT_TEST(set, n);
133
457k
}
zend_call_graph.c:zend_bitset_in
Line
Count
Source
131
11.5k
{
132
11.5k
  return ZEND_BIT_TEST(set, n);
133
11.5k
}
zend_cfg.c:zend_bitset_in
Line
Count
Source
131
986k
{
132
986k
  return ZEND_BIT_TEST(set, n);
133
986k
}
zend_dfg.c:zend_bitset_in
Line
Count
Source
131
645k
{
132
645k
  return ZEND_BIT_TEST(set, n);
133
645k
}
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
131
39.0k
{
132
39.0k
  return ZEND_BIT_TEST(set, n);
133
39.0k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_in
zend_ssa.c:zend_bitset_in
Line
Count
Source
131
31.6k
{
132
31.6k
  return ZEND_BIT_TEST(set, n);
133
31.6k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_in
134
135
static inline void zend_bitset_incl(zend_bitset set, uint32_t n)
136
9.27M
{
137
9.27M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
9.27M
}
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
136
1.50M
{
137
1.50M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
1.50M
}
compact_vars.c:zend_bitset_incl
Line
Count
Source
136
1.81M
{
137
1.81M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
1.81M
}
dce.c:zend_bitset_incl
Line
Count
Source
136
647k
{
137
647k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
647k
}
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
136
534k
{
137
534k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
534k
}
sccp.c:zend_bitset_incl
Line
Count
Source
136
751k
{
137
751k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
751k
}
scdf.c:zend_bitset_incl
Line
Count
Source
136
408k
{
137
408k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
408k
}
zend_call_graph.c:zend_bitset_incl
Line
Count
Source
136
11.1k
{
137
11.1k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
11.1k
}
zend_cfg.c:zend_bitset_incl
Line
Count
Source
136
734k
{
137
734k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
734k
}
zend_dfg.c:zend_bitset_incl
Line
Count
Source
136
977k
{
137
977k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
977k
}
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
136
1.86M
{
137
1.86M
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
1.86M
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_incl
zend_ssa.c:zend_bitset_incl
Line
Count
Source
136
29.1k
{
137
29.1k
  set[ZEND_BITSET_ELM_NUM(n)] |= Z_UL(1) << ZEND_BITSET_BIT_NUM(n);
138
29.1k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_incl
139
140
static inline void zend_bitset_excl(zend_bitset set, uint32_t n)
141
4.42M
{
142
4.42M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
143
4.42M
}
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
141
698k
{
142
698k
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
143
698k
}
Unexecuted instantiation: compact_vars.c:zend_bitset_excl
dce.c:zend_bitset_excl
Line
Count
Source
141
775k
{
142
775k
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
143
775k
}
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
141
534k
{
142
534k
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
143
534k
}
Unexecuted instantiation: sccp.c:zend_bitset_excl
scdf.c:zend_bitset_excl
Line
Count
Source
141
1.06M
{
142
1.06M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
143
1.06M
}
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
141
134k
{
142
134k
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
143
134k
}
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
141
1.22M
{
142
1.22M
  set[ZEND_BITSET_ELM_NUM(n)] &= ~(Z_UL(1) << ZEND_BITSET_BIT_NUM(n));
143
1.22M
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_excl
Unexecuted instantiation: zend_ssa.c:zend_bitset_excl
Unexecuted instantiation: zend_alloc.c:zend_bitset_excl
144
145
static inline void zend_bitset_clear(zend_bitset set, uint32_t len)
146
461k
{
147
461k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
461k
}
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
146
241k
{
147
241k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
241k
}
compact_vars.c:zend_bitset_clear
Line
Count
Source
146
51.4k
{
147
51.4k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
51.4k
}
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
146
51.4k
{
147
51.4k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
51.4k
}
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
146
4.33k
{
147
4.33k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
4.33k
}
zend_dfg.c:zend_bitset_clear
Line
Count
Source
146
37.5k
{
147
37.5k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
37.5k
}
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
146
38.3k
{
147
38.3k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
38.3k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_clear
zend_ssa.c:zend_bitset_clear
Line
Count
Source
146
37.0k
{
147
37.0k
  memset(set, 0, len * ZEND_BITSET_ELM_SIZE);
148
37.0k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_clear
149
150
static inline bool zend_bitset_empty(zend_bitset set, uint32_t len)
151
1.26M
{
152
1.26M
  uint32_t i;
153
7.66M
  for (i = 0; i < len; i++) {
154
7.24M
    if (set[i]) {
155
847k
      return 0;
156
847k
    }
157
7.24M
  }
158
419k
  return 1;
159
1.26M
}
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
151
83.9k
{
152
83.9k
  uint32_t i;
153
171k
  for (i = 0; i < len; i++) {
154
93.2k
    if (set[i]) {
155
5.49k
      return 0;
156
5.49k
    }
157
93.2k
  }
158
78.4k
  return 1;
159
83.9k
}
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
151
224k
{
152
224k
  uint32_t i;
153
419k
  for (i = 0; i < len; i++) {
154
234k
    if (set[i]) {
155
38.4k
      return 0;
156
38.4k
    }
157
234k
  }
158
185k
  return 1;
159
224k
}
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
151
171k
{
152
171k
  uint32_t i;
153
209k
  for (i = 0; i < len; i++) {
154
172k
    if (set[i]) {
155
134k
      return 0;
156
134k
    }
157
172k
  }
158
37.0k
  return 1;
159
171k
}
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
151
671k
{
152
671k
  uint32_t i;
153
6.43M
  for (i = 0; i < len; i++) {
154
6.40M
    if (set[i]) {
155
634k
      return 0;
156
634k
    }
157
6.40M
  }
158
37.0k
  return 1;
159
671k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_empty
zend_ssa.c:zend_bitset_empty
Line
Count
Source
151
115k
{
152
115k
  uint32_t i;
153
425k
  for (i = 0; i < len; i++) {
154
344k
    if (set[i]) {
155
34.1k
      return 0;
156
34.1k
    }
157
344k
  }
158
81.5k
  return 1;
159
115k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_empty
160
161
static inline void zend_bitset_fill(zend_bitset set, uint32_t len)
162
0
{
163
0
  memset(set, 0xff, len * ZEND_BITSET_ELM_SIZE);
164
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
165
166
static inline bool zend_bitset_equal(zend_bitset set1, zend_bitset set2, uint32_t len)
167
134k
{
168
134k
    return memcmp(set1, set2, len * ZEND_BITSET_ELM_SIZE) == 0;
169
134k
}
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
167
134k
{
168
134k
    return memcmp(set1, set2, len * ZEND_BITSET_ELM_SIZE) == 0;
169
134k
}
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
170
171
static inline void zend_bitset_copy(zend_bitset set1, zend_bitset set2, uint32_t len)
172
371k
{
173
371k
    memcpy(set1, set2, len * ZEND_BITSET_ELM_SIZE);
174
371k
}
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
172
176k
{
173
176k
    memcpy(set1, set2, len * ZEND_BITSET_ELM_SIZE);
174
176k
}
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
172
194k
{
173
194k
    memcpy(set1, set2, len * ZEND_BITSET_ELM_SIZE);
174
194k
}
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
175
176
static inline void zend_bitset_intersection(zend_bitset set1, zend_bitset set2, uint32_t len)
177
0
{
178
0
    uint32_t i;
179
180
0
    for (i = 0; i < len; i++) {
181
0
    set1[i] &= set2[i];
182
0
  }
183
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
184
185
static inline void zend_bitset_union(zend_bitset set1, zend_bitset set2, uint32_t len)
186
152k
{
187
152k
  uint32_t i;
188
189
1.00M
  for (i = 0; i < len; i++) {
190
847k
    set1[i] |= set2[i];
191
847k
  }
192
152k
}
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
186
70.6k
{
187
70.6k
  uint32_t i;
188
189
369k
  for (i = 0; i < len; i++) {
190
299k
    set1[i] |= set2[i];
191
299k
  }
192
70.6k
}
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
186
49.0k
{
187
49.0k
  uint32_t i;
188
189
342k
  for (i = 0; i < len; i++) {
190
293k
    set1[i] |= set2[i];
191
293k
  }
192
49.0k
}
Unexecuted instantiation: zend_dump.c:zend_bitset_union
Unexecuted instantiation: zend_func_info.c:zend_bitset_union
Unexecuted instantiation: zend_inference.c:zend_bitset_union
Unexecuted instantiation: zend_optimizer.c:zend_bitset_union
zend_ssa.c:zend_bitset_union
Line
Count
Source
186
33.1k
{
187
33.1k
  uint32_t i;
188
189
288k
  for (i = 0; i < len; i++) {
190
255k
    set1[i] |= set2[i];
191
255k
  }
192
33.1k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_union
193
194
static inline void zend_bitset_difference(zend_bitset set1, zend_bitset set2, uint32_t len)
195
0
{
196
0
  uint32_t i;
197
0
198
0
  for (i = 0; i < len; i++) {
199
0
    set1[i] = set1[i] & ~set2[i];
200
0
  }
201
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
202
203
static inline void zend_bitset_union_with_intersection(zend_bitset set1, zend_bitset set2, zend_bitset set3, zend_bitset set4, uint32_t len)
204
129k
{
205
129k
  uint32_t i;
206
207
804k
  for (i = 0; i < len; i++) {
208
674k
    set1[i] = set2[i] | (set3[i] & set4[i]);
209
674k
  }
210
129k
}
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
204
129k
{
205
129k
  uint32_t i;
206
207
804k
  for (i = 0; i < len; i++) {
208
674k
    set1[i] = set2[i] | (set3[i] & set4[i]);
209
674k
  }
210
129k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_union_with_intersection
211
212
static inline void zend_bitset_union_with_difference(zend_bitset set1, zend_bitset set2, zend_bitset set3, zend_bitset set4, uint32_t len)
213
134k
{
214
134k
  uint32_t i;
215
216
754k
  for (i = 0; i < len; i++) {
217
620k
    set1[i] = set2[i] | (set3[i] & ~set4[i]);
218
620k
  }
219
134k
}
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
213
134k
{
214
134k
  uint32_t i;
215
216
754k
  for (i = 0; i < len; i++) {
217
620k
    set1[i] = set2[i] | (set3[i] & ~set4[i]);
218
620k
  }
219
134k
}
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
220
221
static inline bool zend_bitset_subset(zend_bitset set1, zend_bitset set2, uint32_t len)
222
74.8k
{
223
74.8k
  uint32_t i;
224
225
354k
  for (i = 0; i < len; i++) {
226
312k
    if (set1[i] & ~set2[i]) {
227
33.1k
      return 0;
228
33.1k
    }
229
312k
  }
230
41.6k
  return 1;
231
74.8k
}
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
222
74.8k
{
223
74.8k
  uint32_t i;
224
225
354k
  for (i = 0; i < len; i++) {
226
312k
    if (set1[i] & ~set2[i]) {
227
33.1k
      return 0;
228
33.1k
    }
229
312k
  }
230
41.6k
  return 1;
231
74.8k
}
Unexecuted instantiation: zend_alloc.c:zend_bitset_subset
232
233
static inline int zend_bitset_first(zend_bitset set, uint32_t len)
234
1.01M
{
235
1.01M
  uint32_t i;
236
237
7.95M
  for (i = 0; i < len; i++) {
238
7.79M
    if (set[i]) {
239
851k
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
240
851k
    }
241
7.79M
  }
242
163k
  return -1; /* empty set */
243
1.01M
}
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
234
143k
{
235
143k
  uint32_t i;
236
237
1.12M
  for (i = 0; i < len; i++) {
238
1.07M
    if (set[i]) {
239
95.7k
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
240
95.7k
    }
241
1.07M
  }
242
48.0k
  return -1; /* empty set */
243
143k
}
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
234
235k
{
235
235k
  uint32_t i;
236
237
463k
  for (i = 0; i < len; i++) {
238
348k
    if (set[i]) {
239
120k
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
240
120k
    }
241
348k
  }
242
115k
  return -1; /* empty set */
243
235k
}
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
234
634k
{
235
634k
  uint32_t i;
236
237
6.36M
  for (i = 0; i < len; i++) {
238
6.36M
    if (set[i]) {
239
634k
      return ZEND_BITSET_ELM_SIZE * 8 * i + zend_ulong_ntz(set[i]);
240
634k
    }
241
6.36M
  }
242
0
  return -1; /* empty set */
243
634k
}
Unexecuted instantiation: zend_optimizer.c:zend_bitset_first
Unexecuted instantiation: zend_ssa.c:zend_bitset_first
Unexecuted instantiation: zend_alloc.c:zend_bitset_first
244
245
static inline int zend_bitset_last(zend_bitset set, uint32_t len)
246
134k
{
247
134k
  uint32_t i = len;
248
249
273k
  while (i > 0) {
250
273k
    i--;
251
273k
    if (set[i]) {
252
134k
      int j = ZEND_BITSET_ELM_SIZE * 8 * i - 1;
253
134k
      zend_ulong x = set[i];
254
2.27M
      while (x != Z_UL(0)) {
255
2.14M
        x = x >> Z_UL(1);
256
2.14M
        j++;
257
2.14M
      }
258
134k
      return j;
259
134k
    }
260
273k
  }
261
0
  return -1; /* empty set */
262
134k
}
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
246
134k
{
247
134k
  uint32_t i = len;
248
249
273k
  while (i > 0) {
250
273k
    i--;
251
273k
    if (set[i]) {
252
134k
      int j = ZEND_BITSET_ELM_SIZE * 8 * i - 1;
253
134k
      zend_ulong x = set[i];
254
2.27M
      while (x != Z_UL(0)) {
255
2.14M
        x = x >> Z_UL(1);
256
2.14M
        j++;
257
2.14M
      }
258
134k
      return j;
259
134k
    }
260
273k
  }
261
0
  return -1; /* empty set */
262
134k
}
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
263
264
364k
#define ZEND_BITSET_FOREACH(set, len, bit) do { \
265
364k
  zend_bitset _set = (set); \
266
364k
  uint32_t _i, _len = (len); \
267
1.40M
  for (_i = 0; _i < _len; _i++) { \
268
1.03M
    zend_ulong _x = _set[_i]; \
269
1.03M
    if (_x) { \
270
164k
      (bit) = ZEND_BITSET_ELM_SIZE * 8 * _i; \
271
3.96M
      for (; _x != 0; _x >>= Z_UL(1), (bit)++) { \
272
3.79M
        if (!(_x & Z_UL(1))) continue;
273
274
34.1k
#define ZEND_BITSET_REVERSE_FOREACH(set, len, bit) do { \
275
34.1k
  zend_bitset _set = (set); \
276
34.1k
  uint32_t _i = (len); \
277
34.1k
  zend_ulong _test = Z_UL(1) << (ZEND_BITSET_ELM_SIZE * 8 - 1); \
278
290k
  while (_i-- > 0) { \
279
256k
    zend_ulong _x = _set[_i]; \
280
256k
    if (_x) { \
281
50.3k
      (bit) = ZEND_BITSET_ELM_SIZE * 8 * (_i + 1) - 1; \
282
2.65M
      for (; _x != 0; _x <<= Z_UL(1), (bit)--) { \
283
2.60M
        if (!(_x & _test)) continue; \
284
285
#define ZEND_BITSET_FOREACH_END() \
286
669k
      } \
287
215k
    } \
288
1.29M
  } \
289
398k
} while (0)
290
291
379k
static inline int zend_bitset_pop_first(zend_bitset set, uint32_t len) {
292
379k
  int i = zend_bitset_first(set, len);
293
379k
  if (i >= 0) {
294
216k
    zend_bitset_excl(set, i);
295
216k
  }
296
379k
  return i;
297
379k
}
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
291
143k
static inline int zend_bitset_pop_first(zend_bitset set, uint32_t len) {
292
143k
  int i = zend_bitset_first(set, len);
293
143k
  if (i >= 0) {
294
95.7k
    zend_bitset_excl(set, i);
295
95.7k
  }
296
143k
  return i;
297
143k
}
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
291
235k
static inline int zend_bitset_pop_first(zend_bitset set, uint32_t len) {
292
235k
  int i = zend_bitset_first(set, len);
293
235k
  if (i >= 0) {
294
120k
    zend_bitset_excl(set, i);
295
120k
  }
296
235k
  return i;
297
235k
}
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
298
299
#endif /* _ZEND_BITSET_H_ */