Commit d311edd
committed
Optimize generic args with refcounted sharing + fix type arg forwarding
Refcount zend_generic_args to eliminate per-object alloc/dealloc — new
Box<int>() now adds a refcount instead of deep-copying, removing 4
allocator round-trips per object lifecycle. Inline resolved_masks into
the args struct (single contiguous allocation). Fix crash when creating
generic objects inside generic methods (new Box<T>() inside Factory<int>
::create()) by resolving type param refs from the enclosing context.1 parent 1135bef commit d311edd
File tree
14 files changed
+314
-126
lines changed- Zend
- tests/generics
- ext/opcache
- jit
14 files changed
+314
-126
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5437 | 5437 | | |
5438 | 5438 | | |
5439 | 5439 | | |
5440 | | - | |
| 5440 | + | |
5441 | 5441 | | |
5442 | 5442 | | |
5443 | 5443 | | |
| |||
5541 | 5541 | | |
5542 | 5542 | | |
5543 | 5543 | | |
5544 | | - | |
| 5544 | + | |
5545 | 5545 | | |
5546 | 5546 | | |
5547 | 5547 | | |
| |||
11257 | 11257 | | |
11258 | 11258 | | |
11259 | 11259 | | |
11260 | | - | |
| 11260 | + | |
11261 | 11261 | | |
11262 | 11262 | | |
11263 | 11263 | | |
| |||
11286 | 11286 | | |
11287 | 11287 | | |
11288 | 11288 | | |
11289 | | - | |
| 11289 | + | |
11290 | 11290 | | |
11291 | 11291 | | |
11292 | 11292 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1038 | 1038 | | |
1039 | 1039 | | |
1040 | 1040 | | |
| 1041 | + | |
| 1042 | + | |
| 1043 | + | |
| 1044 | + | |
| 1045 | + | |
| 1046 | + | |
| 1047 | + | |
| 1048 | + | |
| 1049 | + | |
| 1050 | + | |
| 1051 | + | |
| 1052 | + | |
| 1053 | + | |
| 1054 | + | |
| 1055 | + | |
| 1056 | + | |
| 1057 | + | |
| 1058 | + | |
| 1059 | + | |
| 1060 | + | |
| 1061 | + | |
1041 | 1062 | | |
1042 | 1063 | | |
1043 | 1064 | | |
| |||
1051 | 1072 | | |
1052 | 1073 | | |
1053 | 1074 | | |
1054 | | - | |
| 1075 | + | |
1055 | 1076 | | |
1056 | 1077 | | |
1057 | 1078 | | |
| |||
1064 | 1085 | | |
1065 | 1086 | | |
1066 | 1087 | | |
1067 | | - | |
1068 | | - | |
| 1088 | + | |
| 1089 | + | |
1069 | 1090 | | |
1070 | 1091 | | |
1071 | 1092 | | |
| |||
1235 | 1256 | | |
1236 | 1257 | | |
1237 | 1258 | | |
1238 | | - | |
| 1259 | + | |
1239 | 1260 | | |
1240 | 1261 | | |
1241 | 1262 | | |
1242 | 1263 | | |
1243 | 1264 | | |
1244 | 1265 | | |
1245 | | - | |
| 1266 | + | |
1246 | 1267 | | |
1247 | 1268 | | |
1248 | 1269 | | |
| |||
1260 | 1281 | | |
1261 | 1282 | | |
1262 | 1283 | | |
1263 | | - | |
1264 | | - | |
| 1284 | + | |
| 1285 | + | |
1265 | 1286 | | |
1266 | 1287 | | |
1267 | 1288 | | |
| |||
1292 | 1313 | | |
1293 | 1314 | | |
1294 | 1315 | | |
1295 | | - | |
| 1316 | + | |
| 1317 | + | |
| 1318 | + | |
| 1319 | + | |
| 1320 | + | |
| 1321 | + | |
| 1322 | + | |
| 1323 | + | |
| 1324 | + | |
1296 | 1325 | | |
1297 | 1326 | | |
1298 | 1327 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
38 | 38 | | |
39 | 39 | | |
40 | 40 | | |
41 | | - | |
42 | | - | |
43 | | - | |
| 41 | + | |
| 42 | + | |
44 | 43 | | |
45 | | - | |
46 | 44 | | |
47 | 45 | | |
48 | 46 | | |
| 47 | + | |
49 | 48 | | |
50 | 49 | | |
51 | 50 | | |
52 | 51 | | |
53 | 52 | | |
54 | | - | |
55 | | - | |
56 | | - | |
57 | | - | |
| 53 | + | |
58 | 54 | | |
59 | 55 | | |
60 | 56 | | |
61 | 57 | | |
62 | | - | |
| 58 | + | |
63 | 59 | | |
64 | | - | |
| 60 | + | |
65 | 61 | | |
66 | 62 | | |
67 | 63 | | |
| |||
100 | 96 | | |
101 | 97 | | |
102 | 98 | | |
103 | | - | |
104 | | - | |
105 | | - | |
| 99 | + | |
| 100 | + | |
106 | 101 | | |
107 | 102 | | |
108 | 103 | | |
109 | 104 | | |
110 | | - | |
111 | | - | |
112 | | - | |
113 | | - | |
114 | | - | |
115 | | - | |
116 | | - | |
| 105 | + | |
| 106 | + | |
117 | 107 | | |
118 | 108 | | |
119 | 109 | | |
| |||
134 | 124 | | |
135 | 125 | | |
136 | 126 | | |
137 | | - | |
138 | | - | |
139 | | - | |
140 | 127 | | |
141 | 128 | | |
142 | 129 | | |
| |||
154 | 141 | | |
155 | 142 | | |
156 | 143 | | |
157 | | - | |
| 144 | + | |
158 | 145 | | |
159 | 146 | | |
160 | 147 | | |
| |||
173 | 160 | | |
174 | 161 | | |
175 | 162 | | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
176 | 197 | | |
177 | 198 | | |
178 | 199 | | |
| |||
461 | 482 | | |
462 | 483 | | |
463 | 484 | | |
464 | | - | |
| 485 | + | |
465 | 486 | | |
466 | 487 | | |
467 | 488 | | |
468 | 489 | | |
469 | 490 | | |
470 | | - | |
| 491 | + | |
471 | 492 | | |
472 | 493 | | |
473 | 494 | | |
| |||
479 | 500 | | |
480 | 501 | | |
481 | 502 | | |
482 | | - | |
483 | 503 | | |
484 | 504 | | |
485 | 505 | | |
486 | | - | |
487 | | - | |
488 | 506 | | |
489 | 507 | | |
490 | 508 | | |
491 | 509 | | |
492 | 510 | | |
493 | | - | |
494 | 511 | | |
495 | 512 | | |
496 | 513 | | |
497 | 514 | | |
498 | | - | |
499 | | - | |
500 | 515 | | |
501 | 516 | | |
502 | 517 | | |
503 | | - | |
504 | | - | |
505 | | - | |
506 | | - | |
507 | 518 | | |
508 | 519 | | |
509 | 520 | | |
| |||
0 commit comments