Commit f89a114
committed
Add L1 block cache and direct-mapped BHT
This introduces two lookup optimizations:
1. L1 Direct-Mapped Block Cache (256 entries, interpreter only):
- Separated tag/pointer arrays: tag array (1KB) checked first, pointer
loaded only on hit for cache efficiency
- Invalid tag sentinel (0xFFFFFFFF) for clean miss detection
- EXT_C-aware index shift (1 vs 2 bits) to reduce conflict misses
- New block_lookup_or_find() as primary lookup with hash fallback
2. Direct-Mapped Branch History Table (both JIT and non-JIT):
- O(1) lookup replacing O(n) linear search: index = (PC >> 2) & mask
- Remove idx field (non-JIT) and bht_find_min_idx() - no longer needed
- Update bht_find_max_idx() to scan all entries since zeros can appear
at any index with direct-mapped scheme
- Add static assert for power-of-2 HISTORY_SIZE
Benchmarks on Intel Xeon E5-2650:
- CoreMark: 804.66 -> ~887 iterations/sec (+10.2%)
- Dhrystone: 1366 -> ~1382 DMIPS (+1.2%)1 parent 7187278 commit f89a114
File tree
5 files changed
+147
-66
lines changed- src
5 files changed
+147
-66
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
366 | 366 | | |
367 | 367 | | |
368 | 368 | | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
369 | 373 | | |
370 | | - | |
| 374 | + | |
371 | 375 | | |
372 | | - | |
373 | | - | |
| 376 | + | |
374 | 377 | | |
375 | | - | |
| 378 | + | |
376 | 379 | | |
377 | | - | |
| 380 | + | |
378 | 381 | | |
379 | 382 | | |
380 | 383 | | |
381 | 384 | | |
382 | 385 | | |
383 | 386 | | |
384 | 387 | | |
| 388 | + | |
| 389 | + | |
385 | 390 | | |
386 | 391 | | |
387 | 392 | | |
388 | 393 | | |
389 | | - | |
390 | | - | |
391 | | - | |
392 | | - | |
| 394 | + | |
| 395 | + | |
393 | 396 | | |
394 | 397 | | |
395 | 398 | | |
396 | 399 | | |
397 | 400 | | |
398 | | - | |
399 | | - | |
400 | | - | |
401 | | - | |
402 | | - | |
403 | | - | |
404 | | - | |
405 | | - | |
406 | | - | |
407 | | - | |
408 | | - | |
409 | | - | |
410 | | - | |
411 | | - | |
412 | 401 | | |
413 | 402 | | |
414 | 403 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
530 | 530 | | |
531 | 531 | | |
532 | 532 | | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
533 | 543 | | |
534 | | - | |
| 544 | + | |
535 | 545 | | |
536 | 546 | | |
537 | 547 | | |
| |||
545 | 555 | | |
546 | 556 | | |
547 | 557 | | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
548 | 561 | | |
549 | 562 | | |
550 | 563 | | |
| |||
565 | 578 | | |
566 | 579 | | |
567 | 580 | | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
| 597 | + | |
| 598 | + | |
| 599 | + | |
| 600 | + | |
| 601 | + | |
| 602 | + | |
| 603 | + | |
| 604 | + | |
| 605 | + | |
| 606 | + | |
568 | 607 | | |
569 | 608 | | |
570 | 609 | | |
| |||
1808 | 1847 | | |
1809 | 1848 | | |
1810 | 1849 | | |
1811 | | - | |
1812 | | - | |
| 1850 | + | |
| 1851 | + | |
1813 | 1852 | | |
1814 | 1853 | | |
1815 | 1854 | | |
| |||
1861 | 1900 | | |
1862 | 1901 | | |
1863 | 1902 | | |
1864 | | - | |
1865 | | - | |
| 1903 | + | |
| 1904 | + | |
1866 | 1905 | | |
1867 | 1906 | | |
1868 | 1907 | | |
| |||
2096 | 2135 | | |
2097 | 2136 | | |
2098 | 2137 | | |
2099 | | - | |
| 2138 | + | |
2100 | 2139 | | |
2101 | 2140 | | |
2102 | 2141 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
80 | 80 | | |
81 | 81 | | |
82 | 82 | | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
83 | 91 | | |
84 | 92 | | |
85 | 93 | | |
| |||
872 | 880 | | |
873 | 881 | | |
874 | 882 | | |
| 883 | + | |
| 884 | + | |
| 885 | + | |
| 886 | + | |
| 887 | + | |
875 | 888 | | |
876 | 889 | | |
877 | 890 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
188 | 188 | | |
189 | 189 | | |
190 | 190 | | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
191 | 232 | | |
192 | 233 | | |
193 | 234 | | |
194 | 235 | | |
195 | | - | |
| 236 | + | |
196 | 237 | | |
197 | | - | |
198 | | - | |
199 | | - | |
200 | | - | |
201 | | - | |
| 238 | + | |
202 | 239 | | |
203 | 240 | | |
204 | 241 | | |
205 | | - | |
| 242 | + | |
206 | 243 | | |
207 | 244 | | |
208 | | - | |
209 | | - | |
210 | | - | |
| 245 | + | |
211 | 246 | | |
212 | 247 | | |
213 | 248 | | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
214 | 257 | | |
215 | 258 | | |
216 | 259 | | |
| |||
270 | 313 | | |
271 | 314 | | |
272 | 315 | | |
273 | | - | |
| 316 | + | |
274 | 317 | | |
275 | 318 | | |
276 | 319 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
104 | 104 | | |
105 | 105 | | |
106 | 106 | | |
107 | | - | |
| 107 | + | |
108 | 108 | | |
109 | 109 | | |
110 | 110 | | |
| |||
116 | 116 | | |
117 | 117 | | |
118 | 118 | | |
119 | | - | |
120 | | - | |
121 | | - | |
122 | | - | |
123 | | - | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
124 | 125 | | |
125 | 126 | | |
126 | 127 | | |
127 | | - | |
128 | | - | |
129 | | - | |
130 | | - | |
131 | | - | |
132 | | - | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
133 | 131 | | |
134 | 132 | | |
135 | 133 | | |
| |||
141 | 139 | | |
142 | 140 | | |
143 | 141 | | |
144 | | - | |
145 | | - | |
146 | | - | |
147 | | - | |
148 | | - | |
149 | | - | |
150 | | - | |
151 | | - | |
152 | | - | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
153 | 151 | | |
154 | 152 | | |
155 | | - | |
156 | | - | |
157 | | - | |
158 | | - | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
159 | 156 | | |
160 | | - | |
| 157 | + | |
161 | 158 | | |
162 | 159 | | |
163 | 160 | | |
| |||
0 commit comments