| 1 | make[1]: Entering directory `/home/compudj/doc/userspace-rcu/formal-model/urcu-controldataflow-intel-no-ipi' |
| 2 | rm -f pan* trail.out .input.spin* *.spin.trail .input.define |
| 3 | touch .input.define |
| 4 | cat .input.define > pan.ltl |
| 5 | cat DEFINES >> pan.ltl |
| 6 | spin -f "!(`cat urcu_progress.ltl | grep -v ^//`)" >> pan.ltl |
| 7 | cp urcu_progress_writer.define .input.define |
| 8 | cat .input.define > .input.spin |
| 9 | cat DEFINES >> .input.spin |
| 10 | cat urcu.spin >> .input.spin |
| 11 | rm -f .input.spin.trail |
| 12 | spin -a -X -N pan.ltl .input.spin |
| 13 | Exit-Status 0 |
| 14 | gcc -O2 -w -DHASH64 -o pan pan.c |
| 15 | ./pan -a -f -v -c1 -X -m10000000 -w20 |
| 16 | warning: for p.o. reduction to be valid the never claim must be stutter-invariant |
| 17 | (never claims generated from LTL formulae are stutter-invariant) |
| 18 | depth 0: Claim reached state 5 (line 1295) |
| 19 | depth 23: Claim reached state 9 (line 1300) |
| 20 | depth 1404: Claim reached state 9 (line 1299) |
| 21 | Depth= 4122 States= 1e+06 Transitions= 2.18e+07 Memory= 494.377 t= 63.1 R= 2e+04 |
| 22 | Depth= 4237 States= 2e+06 Transitions= 4.19e+07 Memory= 522.209 t= 122 R= 2e+04 |
| 23 | Depth= 4557 States= 3e+06 Transitions= 6.67e+07 Memory= 550.139 t= 195 R= 2e+04 |
| 24 | pan: resizing hashtable to -w22.. done |
| 25 | Depth= 4762 States= 4e+06 Transitions= 9.06e+07 Memory= 609.190 t= 264 R= 2e+04 |
| 26 | Depth= 4793 States= 5e+06 Transitions= 1.25e+08 Memory= 666.709 t= 366 R= 1e+04 |
| 27 | Depth= 4793 States= 6e+06 Transitions= 1.62e+08 Memory= 713.877 t= 473 R= 1e+04 |
| 28 | Depth= 4980 States= 7e+06 Transitions= 1.97e+08 Memory= 760.752 t= 578 R= 1e+04 |
| 29 | Depth= 4980 States= 8e+06 Transitions= 2.29e+08 Memory= 809.190 t= 674 R= 1e+04 |
| 30 | Depth= 4980 States= 9e+06 Transitions= 2.66e+08 Memory= 862.803 t= 784 R= 1e+04 |
| 31 | pan: resizing hashtable to -w24.. done |
| 32 | Depth= 4980 States= 1e+07 Transitions= 2.98e+08 Memory= 1029.377 t= 880 R= 1e+04 |
| 33 | Depth= 4980 States= 1.1e+07 Transitions= 3.34e+08 Memory= 1080.061 t= 987 R= 1e+04 |
| 34 | Depth= 4980 States= 1.2e+07 Transitions= 3.69e+08 Memory= 1129.279 t= 1.09e+03 R= 1e+04 |
| 35 | Depth= 4980 States= 1.3e+07 Transitions= 4.01e+08 Memory= 1177.912 t= 1.18e+03 R= 1e+04 |
| 36 | Depth= 4980 States= 1.4e+07 Transitions= 4.4e+08 Memory= 1226.447 t= 1.3e+03 R= 1e+04 |
| 37 | |
| 38 | (Spin Version 5.1.7 -- 23 December 2008) |
| 39 | + Partial Order Reduction |
| 40 | |
| 41 | Full statespace search for: |
| 42 | never claim + |
| 43 | assertion violations + (if within scope of claim) |
| 44 | acceptance cycles + (fairness enabled) |
| 45 | invalid end states - (disabled by never claim) |
| 46 | |
| 47 | State-vector 88 byte, depth reached 4980, errors: 0 |
| 48 | 7808338 states, stored (1.48869e+07 visited) |
| 49 | 4.5734827e+08 states, matched |
| 50 | 4.7223515e+08 transitions (= visited+matched) |
| 51 | 7.5648218e+09 atomic steps |
| 52 | hash conflicts: 1.2909926e+08 (resolved) |
| 53 | |
| 54 | Stats on memory usage (in Megabytes): |
| 55 | 863.807 equivalent memory usage for states (stored*(State-vector + overhead)) |
| 56 | 691.866 actual memory usage for states (compression: 80.09%) |
| 57 | state-vector as stored = 65 byte + 28 byte overhead |
| 58 | 128.000 memory used for hash table (-w24) |
| 59 | 457.764 memory used for DFS stack (-m10000000) |
| 60 | 1277.131 total actual memory usage |
| 61 | |
| 62 | unreached in proctype urcu_reader |
| 63 | line 411, "pan.___", state 17, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 64 | line 420, "pan.___", state 49, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 65 | line 424, "pan.___", state 63, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 66 | line 249, "pan.___", state 81, "(1)" |
| 67 | line 257, "pan.___", state 101, "(1)" |
| 68 | line 261, "pan.___", state 109, "(1)" |
| 69 | line 597, "pan.___", state 128, "_proc_urcu_reader = (_proc_urcu_reader|((1<<2)<<1))" |
| 70 | line 411, "pan.___", state 135, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 71 | line 420, "pan.___", state 167, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 72 | line 424, "pan.___", state 181, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 73 | line 249, "pan.___", state 199, "(1)" |
| 74 | line 257, "pan.___", state 219, "(1)" |
| 75 | line 261, "pan.___", state 227, "(1)" |
| 76 | line 411, "pan.___", state 246, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 77 | line 420, "pan.___", state 278, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 78 | line 424, "pan.___", state 292, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 79 | line 249, "pan.___", state 310, "(1)" |
| 80 | line 257, "pan.___", state 330, "(1)" |
| 81 | line 261, "pan.___", state 338, "(1)" |
| 82 | line 411, "pan.___", state 359, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 83 | line 411, "pan.___", state 361, "(1)" |
| 84 | line 411, "pan.___", state 362, "((cache_dirty_urcu_gp_ctr.bitfield&(1<<_pid)))" |
| 85 | line 411, "pan.___", state 362, "else" |
| 86 | line 411, "pan.___", state 365, "(1)" |
| 87 | line 415, "pan.___", state 373, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 88 | line 415, "pan.___", state 375, "(1)" |
| 89 | line 415, "pan.___", state 376, "((cache_dirty_urcu_active_readers.bitfield&(1<<_pid)))" |
| 90 | line 415, "pan.___", state 376, "else" |
| 91 | line 415, "pan.___", state 379, "(1)" |
| 92 | line 415, "pan.___", state 380, "(1)" |
| 93 | line 415, "pan.___", state 380, "(1)" |
| 94 | line 413, "pan.___", state 385, "((i<1))" |
| 95 | line 413, "pan.___", state 385, "((i>=1))" |
| 96 | line 420, "pan.___", state 391, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 97 | line 420, "pan.___", state 393, "(1)" |
| 98 | line 420, "pan.___", state 394, "((cache_dirty_rcu_ptr.bitfield&(1<<_pid)))" |
| 99 | line 420, "pan.___", state 394, "else" |
| 100 | line 420, "pan.___", state 397, "(1)" |
| 101 | line 420, "pan.___", state 398, "(1)" |
| 102 | line 420, "pan.___", state 398, "(1)" |
| 103 | line 424, "pan.___", state 405, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 104 | line 424, "pan.___", state 407, "(1)" |
| 105 | line 424, "pan.___", state 408, "((cache_dirty_rcu_data[i].bitfield&(1<<_pid)))" |
| 106 | line 424, "pan.___", state 408, "else" |
| 107 | line 424, "pan.___", state 411, "(1)" |
| 108 | line 424, "pan.___", state 412, "(1)" |
| 109 | line 424, "pan.___", state 412, "(1)" |
| 110 | line 422, "pan.___", state 417, "((i<2))" |
| 111 | line 422, "pan.___", state 417, "((i>=2))" |
| 112 | line 249, "pan.___", state 423, "(1)" |
| 113 | line 253, "pan.___", state 431, "(1)" |
| 114 | line 253, "pan.___", state 432, "(!((cache_dirty_urcu_active_readers.bitfield&(1<<_pid))))" |
| 115 | line 253, "pan.___", state 432, "else" |
| 116 | line 251, "pan.___", state 437, "((i<1))" |
| 117 | line 251, "pan.___", state 437, "((i>=1))" |
| 118 | line 257, "pan.___", state 443, "(1)" |
| 119 | line 257, "pan.___", state 444, "(!((cache_dirty_rcu_ptr.bitfield&(1<<_pid))))" |
| 120 | line 257, "pan.___", state 444, "else" |
| 121 | line 261, "pan.___", state 451, "(1)" |
| 122 | line 261, "pan.___", state 452, "(!((cache_dirty_rcu_data[i].bitfield&(1<<_pid))))" |
| 123 | line 261, "pan.___", state 452, "else" |
| 124 | line 259, "pan.___", state 457, "((i<2))" |
| 125 | line 259, "pan.___", state 457, "((i>=2))" |
| 126 | line 266, "pan.___", state 461, "(!((cache_dirty_urcu_gp_ctr.bitfield&(1<<_pid))))" |
| 127 | line 266, "pan.___", state 461, "else" |
| 128 | line 431, "pan.___", state 463, "(1)" |
| 129 | line 431, "pan.___", state 463, "(1)" |
| 130 | line 597, "pan.___", state 466, "cached_urcu_active_readers.val[_pid] = (tmp+1)" |
| 131 | line 597, "pan.___", state 467, "_proc_urcu_reader = (_proc_urcu_reader|(1<<5))" |
| 132 | line 597, "pan.___", state 468, "(1)" |
| 133 | line 272, "pan.___", state 472, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 134 | line 276, "pan.___", state 483, "(1)" |
| 135 | line 280, "pan.___", state 494, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 136 | line 284, "pan.___", state 503, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 137 | line 249, "pan.___", state 519, "(1)" |
| 138 | line 253, "pan.___", state 527, "(1)" |
| 139 | line 257, "pan.___", state 539, "(1)" |
| 140 | line 261, "pan.___", state 547, "(1)" |
| 141 | line 411, "pan.___", state 565, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 142 | line 415, "pan.___", state 579, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 143 | line 420, "pan.___", state 597, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 144 | line 424, "pan.___", state 611, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 145 | line 249, "pan.___", state 629, "(1)" |
| 146 | line 253, "pan.___", state 637, "(1)" |
| 147 | line 257, "pan.___", state 649, "(1)" |
| 148 | line 261, "pan.___", state 657, "(1)" |
| 149 | line 411, "pan.___", state 683, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 150 | line 420, "pan.___", state 715, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 151 | line 424, "pan.___", state 729, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 152 | line 249, "pan.___", state 747, "(1)" |
| 153 | line 257, "pan.___", state 767, "(1)" |
| 154 | line 261, "pan.___", state 775, "(1)" |
| 155 | line 411, "pan.___", state 794, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 156 | line 411, "pan.___", state 796, "(1)" |
| 157 | line 411, "pan.___", state 797, "((cache_dirty_urcu_gp_ctr.bitfield&(1<<_pid)))" |
| 158 | line 411, "pan.___", state 797, "else" |
| 159 | line 411, "pan.___", state 800, "(1)" |
| 160 | line 415, "pan.___", state 808, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 161 | line 415, "pan.___", state 810, "(1)" |
| 162 | line 415, "pan.___", state 811, "((cache_dirty_urcu_active_readers.bitfield&(1<<_pid)))" |
| 163 | line 415, "pan.___", state 811, "else" |
| 164 | line 415, "pan.___", state 814, "(1)" |
| 165 | line 415, "pan.___", state 815, "(1)" |
| 166 | line 415, "pan.___", state 815, "(1)" |
| 167 | line 413, "pan.___", state 820, "((i<1))" |
| 168 | line 413, "pan.___", state 820, "((i>=1))" |
| 169 | line 420, "pan.___", state 826, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 170 | line 420, "pan.___", state 828, "(1)" |
| 171 | line 420, "pan.___", state 829, "((cache_dirty_rcu_ptr.bitfield&(1<<_pid)))" |
| 172 | line 420, "pan.___", state 829, "else" |
| 173 | line 420, "pan.___", state 832, "(1)" |
| 174 | line 420, "pan.___", state 833, "(1)" |
| 175 | line 420, "pan.___", state 833, "(1)" |
| 176 | line 424, "pan.___", state 840, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 177 | line 424, "pan.___", state 842, "(1)" |
| 178 | line 424, "pan.___", state 843, "((cache_dirty_rcu_data[i].bitfield&(1<<_pid)))" |
| 179 | line 424, "pan.___", state 843, "else" |
| 180 | line 424, "pan.___", state 846, "(1)" |
| 181 | line 424, "pan.___", state 847, "(1)" |
| 182 | line 424, "pan.___", state 847, "(1)" |
| 183 | line 422, "pan.___", state 852, "((i<2))" |
| 184 | line 422, "pan.___", state 852, "((i>=2))" |
| 185 | line 249, "pan.___", state 858, "(1)" |
| 186 | line 253, "pan.___", state 866, "(1)" |
| 187 | line 253, "pan.___", state 867, "(!((cache_dirty_urcu_active_readers.bitfield&(1<<_pid))))" |
| 188 | line 253, "pan.___", state 867, "else" |
| 189 | line 251, "pan.___", state 872, "((i<1))" |
| 190 | line 251, "pan.___", state 872, "((i>=1))" |
| 191 | line 257, "pan.___", state 878, "(1)" |
| 192 | line 257, "pan.___", state 879, "(!((cache_dirty_rcu_ptr.bitfield&(1<<_pid))))" |
| 193 | line 257, "pan.___", state 879, "else" |
| 194 | line 261, "pan.___", state 886, "(1)" |
| 195 | line 261, "pan.___", state 887, "(!((cache_dirty_rcu_data[i].bitfield&(1<<_pid))))" |
| 196 | line 261, "pan.___", state 887, "else" |
| 197 | line 259, "pan.___", state 892, "((i<2))" |
| 198 | line 259, "pan.___", state 892, "((i>=2))" |
| 199 | line 266, "pan.___", state 896, "(!((cache_dirty_urcu_gp_ctr.bitfield&(1<<_pid))))" |
| 200 | line 266, "pan.___", state 896, "else" |
| 201 | line 431, "pan.___", state 898, "(1)" |
| 202 | line 431, "pan.___", state 898, "(1)" |
| 203 | line 605, "pan.___", state 902, "_proc_urcu_reader = (_proc_urcu_reader|(1<<11))" |
| 204 | line 411, "pan.___", state 907, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 205 | line 415, "pan.___", state 921, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 206 | line 420, "pan.___", state 939, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 207 | line 424, "pan.___", state 953, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 208 | line 249, "pan.___", state 971, "(1)" |
| 209 | line 253, "pan.___", state 979, "(1)" |
| 210 | line 257, "pan.___", state 991, "(1)" |
| 211 | line 261, "pan.___", state 999, "(1)" |
| 212 | line 411, "pan.___", state 1021, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 213 | line 420, "pan.___", state 1053, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 214 | line 424, "pan.___", state 1067, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 215 | line 249, "pan.___", state 1085, "(1)" |
| 216 | line 257, "pan.___", state 1105, "(1)" |
| 217 | line 261, "pan.___", state 1113, "(1)" |
| 218 | line 411, "pan.___", state 1136, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 219 | line 420, "pan.___", state 1168, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 220 | line 424, "pan.___", state 1182, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 221 | line 249, "pan.___", state 1200, "(1)" |
| 222 | line 257, "pan.___", state 1220, "(1)" |
| 223 | line 261, "pan.___", state 1228, "(1)" |
| 224 | line 411, "pan.___", state 1247, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 225 | line 420, "pan.___", state 1279, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 226 | line 424, "pan.___", state 1293, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 227 | line 249, "pan.___", state 1311, "(1)" |
| 228 | line 257, "pan.___", state 1331, "(1)" |
| 229 | line 261, "pan.___", state 1339, "(1)" |
| 230 | line 272, "pan.___", state 1360, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 231 | line 280, "pan.___", state 1382, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 232 | line 284, "pan.___", state 1391, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 233 | line 249, "pan.___", state 1407, "(1)" |
| 234 | line 253, "pan.___", state 1415, "(1)" |
| 235 | line 257, "pan.___", state 1427, "(1)" |
| 236 | line 261, "pan.___", state 1435, "(1)" |
| 237 | line 411, "pan.___", state 1453, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 238 | line 415, "pan.___", state 1467, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 239 | line 420, "pan.___", state 1485, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 240 | line 424, "pan.___", state 1499, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 241 | line 249, "pan.___", state 1517, "(1)" |
| 242 | line 253, "pan.___", state 1525, "(1)" |
| 243 | line 257, "pan.___", state 1537, "(1)" |
| 244 | line 261, "pan.___", state 1545, "(1)" |
| 245 | line 411, "pan.___", state 1564, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 246 | line 415, "pan.___", state 1578, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 247 | line 420, "pan.___", state 1596, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 248 | line 424, "pan.___", state 1610, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 249 | line 249, "pan.___", state 1628, "(1)" |
| 250 | line 253, "pan.___", state 1636, "(1)" |
| 251 | line 257, "pan.___", state 1648, "(1)" |
| 252 | line 261, "pan.___", state 1656, "(1)" |
| 253 | line 411, "pan.___", state 1678, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 254 | line 420, "pan.___", state 1710, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 255 | line 424, "pan.___", state 1724, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 256 | line 249, "pan.___", state 1742, "(1)" |
| 257 | line 257, "pan.___", state 1762, "(1)" |
| 258 | line 261, "pan.___", state 1770, "(1)" |
| 259 | line 644, "pan.___", state 1789, "_proc_urcu_reader = (_proc_urcu_reader|((1<<2)<<19))" |
| 260 | line 411, "pan.___", state 1796, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 261 | line 420, "pan.___", state 1828, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 262 | line 424, "pan.___", state 1842, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 263 | line 249, "pan.___", state 1860, "(1)" |
| 264 | line 257, "pan.___", state 1880, "(1)" |
| 265 | line 261, "pan.___", state 1888, "(1)" |
| 266 | line 411, "pan.___", state 1907, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 267 | line 420, "pan.___", state 1939, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 268 | line 424, "pan.___", state 1953, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 269 | line 249, "pan.___", state 1971, "(1)" |
| 270 | line 257, "pan.___", state 1991, "(1)" |
| 271 | line 261, "pan.___", state 1999, "(1)" |
| 272 | line 411, "pan.___", state 2020, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 273 | line 411, "pan.___", state 2022, "(1)" |
| 274 | line 411, "pan.___", state 2023, "((cache_dirty_urcu_gp_ctr.bitfield&(1<<_pid)))" |
| 275 | line 411, "pan.___", state 2023, "else" |
| 276 | line 411, "pan.___", state 2026, "(1)" |
| 277 | line 415, "pan.___", state 2034, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 278 | line 415, "pan.___", state 2036, "(1)" |
| 279 | line 415, "pan.___", state 2037, "((cache_dirty_urcu_active_readers.bitfield&(1<<_pid)))" |
| 280 | line 415, "pan.___", state 2037, "else" |
| 281 | line 415, "pan.___", state 2040, "(1)" |
| 282 | line 415, "pan.___", state 2041, "(1)" |
| 283 | line 415, "pan.___", state 2041, "(1)" |
| 284 | line 413, "pan.___", state 2046, "((i<1))" |
| 285 | line 413, "pan.___", state 2046, "((i>=1))" |
| 286 | line 420, "pan.___", state 2052, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 287 | line 420, "pan.___", state 2054, "(1)" |
| 288 | line 420, "pan.___", state 2055, "((cache_dirty_rcu_ptr.bitfield&(1<<_pid)))" |
| 289 | line 420, "pan.___", state 2055, "else" |
| 290 | line 420, "pan.___", state 2058, "(1)" |
| 291 | line 420, "pan.___", state 2059, "(1)" |
| 292 | line 420, "pan.___", state 2059, "(1)" |
| 293 | line 424, "pan.___", state 2066, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 294 | line 424, "pan.___", state 2068, "(1)" |
| 295 | line 424, "pan.___", state 2069, "((cache_dirty_rcu_data[i].bitfield&(1<<_pid)))" |
| 296 | line 424, "pan.___", state 2069, "else" |
| 297 | line 424, "pan.___", state 2072, "(1)" |
| 298 | line 424, "pan.___", state 2073, "(1)" |
| 299 | line 424, "pan.___", state 2073, "(1)" |
| 300 | line 422, "pan.___", state 2078, "((i<2))" |
| 301 | line 422, "pan.___", state 2078, "((i>=2))" |
| 302 | line 249, "pan.___", state 2084, "(1)" |
| 303 | line 253, "pan.___", state 2092, "(1)" |
| 304 | line 253, "pan.___", state 2093, "(!((cache_dirty_urcu_active_readers.bitfield&(1<<_pid))))" |
| 305 | line 253, "pan.___", state 2093, "else" |
| 306 | line 251, "pan.___", state 2098, "((i<1))" |
| 307 | line 251, "pan.___", state 2098, "((i>=1))" |
| 308 | line 257, "pan.___", state 2104, "(1)" |
| 309 | line 257, "pan.___", state 2105, "(!((cache_dirty_rcu_ptr.bitfield&(1<<_pid))))" |
| 310 | line 257, "pan.___", state 2105, "else" |
| 311 | line 261, "pan.___", state 2112, "(1)" |
| 312 | line 261, "pan.___", state 2113, "(!((cache_dirty_rcu_data[i].bitfield&(1<<_pid))))" |
| 313 | line 261, "pan.___", state 2113, "else" |
| 314 | line 259, "pan.___", state 2118, "((i<2))" |
| 315 | line 259, "pan.___", state 2118, "((i>=2))" |
| 316 | line 266, "pan.___", state 2122, "(!((cache_dirty_urcu_gp_ctr.bitfield&(1<<_pid))))" |
| 317 | line 266, "pan.___", state 2122, "else" |
| 318 | line 431, "pan.___", state 2124, "(1)" |
| 319 | line 431, "pan.___", state 2124, "(1)" |
| 320 | line 644, "pan.___", state 2127, "cached_urcu_active_readers.val[_pid] = (tmp+1)" |
| 321 | line 644, "pan.___", state 2128, "_proc_urcu_reader = (_proc_urcu_reader|(1<<23))" |
| 322 | line 644, "pan.___", state 2129, "(1)" |
| 323 | line 272, "pan.___", state 2133, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 324 | line 280, "pan.___", state 2155, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 325 | line 284, "pan.___", state 2164, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 326 | line 249, "pan.___", state 2180, "(1)" |
| 327 | line 253, "pan.___", state 2188, "(1)" |
| 328 | line 257, "pan.___", state 2200, "(1)" |
| 329 | line 261, "pan.___", state 2208, "(1)" |
| 330 | line 411, "pan.___", state 2226, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 331 | line 415, "pan.___", state 2240, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 332 | line 420, "pan.___", state 2258, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 333 | line 424, "pan.___", state 2272, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 334 | line 249, "pan.___", state 2290, "(1)" |
| 335 | line 253, "pan.___", state 2298, "(1)" |
| 336 | line 257, "pan.___", state 2310, "(1)" |
| 337 | line 261, "pan.___", state 2318, "(1)" |
| 338 | line 272, "pan.___", state 2340, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 339 | line 276, "pan.___", state 2349, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 340 | line 280, "pan.___", state 2362, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 341 | line 284, "pan.___", state 2371, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 342 | line 249, "pan.___", state 2387, "(1)" |
| 343 | line 253, "pan.___", state 2395, "(1)" |
| 344 | line 257, "pan.___", state 2407, "(1)" |
| 345 | line 261, "pan.___", state 2415, "(1)" |
| 346 | line 411, "pan.___", state 2433, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 347 | line 415, "pan.___", state 2447, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 348 | line 420, "pan.___", state 2465, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 349 | line 424, "pan.___", state 2479, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 350 | line 249, "pan.___", state 2497, "(1)" |
| 351 | line 253, "pan.___", state 2505, "(1)" |
| 352 | line 257, "pan.___", state 2517, "(1)" |
| 353 | line 261, "pan.___", state 2525, "(1)" |
| 354 | line 411, "pan.___", state 2544, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 355 | line 415, "pan.___", state 2558, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 356 | line 420, "pan.___", state 2576, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 357 | line 424, "pan.___", state 2590, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 358 | line 249, "pan.___", state 2608, "(1)" |
| 359 | line 253, "pan.___", state 2616, "(1)" |
| 360 | line 257, "pan.___", state 2628, "(1)" |
| 361 | line 261, "pan.___", state 2636, "(1)" |
| 362 | line 249, "pan.___", state 2667, "(1)" |
| 363 | line 257, "pan.___", state 2687, "(1)" |
| 364 | line 261, "pan.___", state 2695, "(1)" |
| 365 | line 249, "pan.___", state 2710, "(1)" |
| 366 | line 253, "pan.___", state 2718, "(1)" |
| 367 | line 257, "pan.___", state 2730, "(1)" |
| 368 | line 261, "pan.___", state 2738, "(1)" |
| 369 | line 898, "pan.___", state 2755, "-end-" |
| 370 | (259 of 2755 states) |
| 371 | unreached in proctype urcu_writer |
| 372 | line 411, "pan.___", state 18, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 373 | line 415, "pan.___", state 32, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 374 | line 420, "pan.___", state 50, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 375 | line 249, "pan.___", state 82, "(1)" |
| 376 | line 253, "pan.___", state 90, "(1)" |
| 377 | line 257, "pan.___", state 102, "(1)" |
| 378 | line 272, "pan.___", state 131, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 379 | line 276, "pan.___", state 140, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 380 | line 280, "pan.___", state 153, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 381 | line 411, "pan.___", state 193, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 382 | line 415, "pan.___", state 207, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 383 | line 420, "pan.___", state 225, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 384 | line 424, "pan.___", state 239, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 385 | line 249, "pan.___", state 257, "(1)" |
| 386 | line 253, "pan.___", state 265, "(1)" |
| 387 | line 257, "pan.___", state 277, "(1)" |
| 388 | line 261, "pan.___", state 285, "(1)" |
| 389 | line 415, "pan.___", state 320, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 390 | line 420, "pan.___", state 338, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 391 | line 424, "pan.___", state 352, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 392 | line 253, "pan.___", state 378, "(1)" |
| 393 | line 257, "pan.___", state 390, "(1)" |
| 394 | line 261, "pan.___", state 398, "(1)" |
| 395 | line 415, "pan.___", state 441, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 396 | line 420, "pan.___", state 459, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 397 | line 424, "pan.___", state 473, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 398 | line 253, "pan.___", state 499, "(1)" |
| 399 | line 257, "pan.___", state 511, "(1)" |
| 400 | line 261, "pan.___", state 519, "(1)" |
| 401 | line 415, "pan.___", state 552, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 402 | line 420, "pan.___", state 570, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 403 | line 424, "pan.___", state 584, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 404 | line 253, "pan.___", state 610, "(1)" |
| 405 | line 257, "pan.___", state 622, "(1)" |
| 406 | line 261, "pan.___", state 630, "(1)" |
| 407 | line 415, "pan.___", state 665, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 408 | line 420, "pan.___", state 683, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 409 | line 424, "pan.___", state 697, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 410 | line 253, "pan.___", state 723, "(1)" |
| 411 | line 257, "pan.___", state 735, "(1)" |
| 412 | line 261, "pan.___", state 743, "(1)" |
| 413 | line 272, "pan.___", state 796, "cache_dirty_urcu_gp_ctr.bitfield = (cache_dirty_urcu_gp_ctr.bitfield&~((1<<_pid)))" |
| 414 | line 276, "pan.___", state 805, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 415 | line 280, "pan.___", state 820, "(1)" |
| 416 | line 284, "pan.___", state 827, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 417 | line 249, "pan.___", state 843, "(1)" |
| 418 | line 253, "pan.___", state 851, "(1)" |
| 419 | line 257, "pan.___", state 863, "(1)" |
| 420 | line 261, "pan.___", state 871, "(1)" |
| 421 | line 276, "pan.___", state 896, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 422 | line 280, "pan.___", state 909, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 423 | line 284, "pan.___", state 918, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 424 | line 249, "pan.___", state 934, "(1)" |
| 425 | line 253, "pan.___", state 942, "(1)" |
| 426 | line 257, "pan.___", state 954, "(1)" |
| 427 | line 261, "pan.___", state 962, "(1)" |
| 428 | line 276, "pan.___", state 987, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 429 | line 280, "pan.___", state 1000, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 430 | line 284, "pan.___", state 1009, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 431 | line 249, "pan.___", state 1025, "(1)" |
| 432 | line 253, "pan.___", state 1033, "(1)" |
| 433 | line 257, "pan.___", state 1045, "(1)" |
| 434 | line 261, "pan.___", state 1053, "(1)" |
| 435 | line 276, "pan.___", state 1078, "cache_dirty_urcu_active_readers.bitfield = (cache_dirty_urcu_active_readers.bitfield&~((1<<_pid)))" |
| 436 | line 280, "pan.___", state 1091, "cache_dirty_rcu_ptr.bitfield = (cache_dirty_rcu_ptr.bitfield&~((1<<_pid)))" |
| 437 | line 284, "pan.___", state 1100, "cache_dirty_rcu_data[i].bitfield = (cache_dirty_rcu_data[i].bitfield&~((1<<_pid)))" |
| 438 | line 249, "pan.___", state 1116, "(1)" |
| 439 | line 253, "pan.___", state 1124, "(1)" |
| 440 | line 257, "pan.___", state 1136, "(1)" |
| 441 | line 261, "pan.___", state 1144, "(1)" |
| 442 | line 1237, "pan.___", state 1159, "-end-" |
| 443 | (71 of 1159 states) |
| 444 | unreached in proctype :init: |
| 445 | (0 of 78 states) |
| 446 | unreached in proctype :never: |
| 447 | line 1302, "pan.___", state 11, "-end-" |
| 448 | (1 of 11 states) |
| 449 | |
| 450 | pan: elapsed time 1.4e+03 seconds |
| 451 | pan: rate 10667.087 states/second |
| 452 | pan: avg transition delay 2.9553e-06 usec |
| 453 | cp .input.spin urcu_progress_writer.spin.input |
| 454 | cp .input.spin.trail urcu_progress_writer.spin.input.trail |
| 455 | make[1]: Leaving directory `/home/compudj/doc/userspace-rcu/formal-model/urcu-controldataflow-intel-no-ipi' |