Commit e7fb87e
committed
Populate ivar caches for types other than T_OBJECT
`vm_setinstancevariable` had a codepath to try to match the inline
cache for types other than T_OBJECT, but the cache population path
in `vm_setivar_slowpath` was exclusive to T_OBJECT, so `vm_setivar_default`
would never match anything.
This commit improves `vm_setivar_slowpath` so that it is capable of
filling the cache for all types, and adds a `vm_setivar_class` codepath
for `T_CLASS` and `T_MODULE`.
`vm_setivar`, `vm_setivar_default` and `vm_setivar_class` could be unified,
but based on the very explicit `NOINLINE` I assume they were split to minimize
codesize.
```
compare-ruby: ruby 3.5.0dev (2025-08-27T14:58:58Z merge-vm-setivar-d.. 5b749d8e53) +PRISM [arm64-darwin24]
built-ruby: ruby 3.5.0dev (2025-08-27T16:30:31Z setivar-cache-gene.. 4fe78ff) +PRISM [arm64-darwin24]
| |compare-ruby|built-ruby|
|:------------------------|-----------:|---------:|
|vm_ivar_set_on_instance | 161.809| 164.688|
| | -| 1.02x|
|vm_ivar_set_on_generic | 58.769| 115.638|
| | -| 1.97x|
|vm_ivar_set_on_class | 70.034| 141.042|
| | -| 2.01x|
```1 parent b85b2b8 commit e7fb87e
5 files changed
Lines changed: 233 additions & 51 deletions
File tree
- benchmark
- internal
- test/ruby
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
| 4 | + | |
4 | 5 | | |
5 | 6 | | |
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 | + | |
7 | 32 | | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
8 | 36 | | |
9 | 37 | | |
10 | 38 | | |
11 | | - | |
| 39 | + | |
12 | 40 | | |
13 | | - | |
| 41 | + | |
14 | 42 | | |
15 | 43 | | |
16 | 44 | | |
| |||
28 | 56 | | |
29 | 57 | | |
30 | 58 | | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
31 | 86 | | |
32 | 87 | | |
33 | 88 | | |
34 | 89 | | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
35 | 94 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
51 | 51 | | |
52 | 52 | | |
53 | 53 | | |
54 | | - | |
| 54 | + | |
| 55 | + | |
55 | 56 | | |
56 | 57 | | |
57 | 58 | | |
| |||
67 | 68 | | |
68 | 69 | | |
69 | 70 | | |
70 | | - | |
71 | 71 | | |
72 | 72 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
388 | 388 | | |
389 | 389 | | |
390 | 390 | | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
| 445 | + | |
391 | 446 | | |
392 | 447 | | |
393 | 448 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1300 | 1300 | | |
1301 | 1301 | | |
1302 | 1302 | | |
1303 | | - | |
| 1303 | + | |
1304 | 1304 | | |
1305 | 1305 | | |
1306 | 1306 | | |
| |||
1555 | 1555 | | |
1556 | 1556 | | |
1557 | 1557 | | |
| 1558 | + | |
| 1559 | + | |
| 1560 | + | |
| 1561 | + | |
1558 | 1562 | | |
1559 | 1563 | | |
1560 | 1564 | | |
| |||
1764 | 1768 | | |
1765 | 1769 | | |
1766 | 1770 | | |
1767 | | - | |
| 1771 | + | |
1768 | 1772 | | |
1769 | 1773 | | |
1770 | 1774 | | |
| |||
1776 | 1780 | | |
1777 | 1781 | | |
1778 | 1782 | | |
| 1783 | + | |
1779 | 1784 | | |
1780 | 1785 | | |
1781 | 1786 | | |
| |||
1800 | 1805 | | |
1801 | 1806 | | |
1802 | 1807 | | |
1803 | | - | |
| 1808 | + | |
1804 | 1809 | | |
1805 | 1810 | | |
1806 | 1811 | | |
1807 | 1812 | | |
1808 | | - | |
| 1813 | + | |
1809 | 1814 | | |
1810 | 1815 | | |
1811 | 1816 | | |
| |||
1886 | 1891 | | |
1887 | 1892 | | |
1888 | 1893 | | |
1889 | | - | |
1890 | | - | |
| 1894 | + | |
| 1895 | + | |
1891 | 1896 | | |
1892 | 1897 | | |
1893 | 1898 | | |
| |||
1902 | 1907 | | |
1903 | 1908 | | |
1904 | 1909 | | |
1905 | | - | |
| 1910 | + | |
1906 | 1911 | | |
1907 | 1912 | | |
1908 | 1913 | | |
| |||
1922 | 1927 | | |
1923 | 1928 | | |
1924 | 1929 | | |
1925 | | - | |
| 1930 | + | |
| 1931 | + | |
| 1932 | + | |
1926 | 1933 | | |
1927 | 1934 | | |
1928 | 1935 | | |
1929 | 1936 | | |
1930 | 1937 | | |
1931 | 1938 | | |
1932 | | - | |
1933 | | - | |
1934 | | - | |
1935 | | - | |
| 1939 | + | |
1936 | 1940 | | |
1937 | 1941 | | |
1938 | | - | |
1939 | | - | |
1940 | | - | |
1941 | | - | |
| 1942 | + | |
| 1943 | + | |
| 1944 | + | |
| 1945 | + | |
| 1946 | + | |
1942 | 1947 | | |
1943 | | - | |
1944 | | - | |
| 1948 | + | |
1945 | 1949 | | |
1946 | 1950 | | |
1947 | 1951 | | |
| |||
1953 | 1957 | | |
1954 | 1958 | | |
1955 | 1959 | | |
| 1960 | + | |
| 1961 | + | |
| 1962 | + | |
| 1963 | + | |
| 1964 | + | |
| 1965 | + | |
1956 | 1966 | | |
1957 | 1967 | | |
1958 | 1968 | | |
| |||
1962 | 1972 | | |
1963 | 1973 | | |
1964 | 1974 | | |
1965 | | - | |
| 1975 | + | |
1966 | 1976 | | |
1967 | 1977 | | |
1968 | 1978 | | |
1969 | 1979 | | |
1970 | | - | |
1971 | | - | |
| 1980 | + | |
1972 | 1981 | | |
1973 | 1982 | | |
1974 | 1983 | | |
1975 | 1984 | | |
1976 | 1985 | | |
1977 | 1986 | | |
1978 | | - | |
1979 | | - | |
| 1987 | + | |
1980 | 1988 | | |
1981 | 1989 | | |
1982 | 1990 | | |
| |||
4483 | 4491 | | |
4484 | 4492 | | |
4485 | 4493 | | |
4486 | | - | |
4487 | | - | |
| 4494 | + | |
| 4495 | + | |
4488 | 4496 | | |
4489 | 4497 | | |
4490 | 4498 | | |
| |||
4531 | 4539 | | |
4532 | 4540 | | |
4533 | 4541 | | |
4534 | | - | |
| 4542 | + | |
| 4543 | + | |
4535 | 4544 | | |
4536 | 4545 | | |
4537 | 4546 | | |
| |||
4552 | 4561 | | |
4553 | 4562 | | |
4554 | 4563 | | |
4555 | | - | |
| 4564 | + | |
| 4565 | + | |
4556 | 4566 | | |
4557 | 4567 | | |
4558 | | - | |
4559 | | - | |
| 4568 | + | |
| 4569 | + | |
4560 | 4570 | | |
4561 | | - | |
4562 | | - | |
4563 | | - | |
4564 | 4571 | | |
4565 | 4572 | | |
4566 | 4573 | | |
4567 | 4574 | | |
4568 | 4575 | | |
4569 | | - | |
| 4576 | + | |
4570 | 4577 | | |
4571 | 4578 | | |
4572 | 4579 | | |
4573 | 4580 | | |
4574 | 4581 | | |
4575 | 4582 | | |
4576 | 4583 | | |
4577 | | - | |
4578 | | - | |
| 4584 | + | |
4579 | 4585 | | |
| 4586 | + | |
| 4587 | + | |
4580 | 4588 | | |
| 4589 | + | |
| 4590 | + | |
| 4591 | + | |
| 4592 | + | |
| 4593 | + | |
| 4594 | + | |
| 4595 | + | |
| 4596 | + | |
4581 | 4597 | | |
4582 | 4598 | | |
4583 | 4599 | | |
| |||
0 commit comments