Hardware prefetchers is a fundamental performance issue, RandomX accesses memory randomly, so prefetchers just don't work. All places where prefetching can help already have explicit prefetch instructions in the code. Sometimes prefetchers can be disabled in BIOS, for Intel it usually Hardware Prefetcher and Adjacent Cache Line Prefetch, but some prefetchers not possible disable even in BIOS.
Solution is configure prefetchers by using MSR registers from OS level.
If you use recent XMRig with root privileges (Linux) or admin privileges (Windows) the miner configure all MSR registers automatically.
If all good, the miner got all required privileges and your CPU supported you will saw line like below in miner log.
msr register values for "intel" preset has been set successfully (16 ms)
With some hardware/software configurations is also need to disable Secure Boot to make MSR mod works, please check issue #1891 on github.
XMRig revert initial MSR values on exit by default, anyway changes is not persistent, computer reboot always reset any changes.
For configuration 2 options available in "randomx"
object: "rdmsr"
and "wrmsr"
Use "rdmsr": false
to disable reverting initial MSR values on exit.
"wrmsr": true
(by default) enable MSR feature or "wrmsr": false
to disable MSR feature.
"wrmsr": 15
Only available for Intel. Default value 15 for Intel good in general, but may not best, please check issue #1433 on github for details.
Very advanced format, for precise configuration with caution. Preset values shipped with the miner:
"wrmsr": ["0x1a4:0xf"]
Intel preset."wrmsr": ["0xc0011020:0x4480000000000", "0xc0011021:0x1c000200000040:0xffffffffffffffdf", "0xc0011022:0xc000000401500000", "0xc001102b:0x2000cc14"]
AMD Ryzen (Zen3)."wrmsr": ["0xc0011020:0x0", "0xc0011021:0x40:0xffffffffffffffdf", "0xc0011022:0x1510000", "0xc001102b:0x2000cc16"]
AMD Ryzen (Zen1/Zen2)."wrmsr": ["0xc0011020:0x0", "0xc0011021:0x60", "0xc0011022:0x510000", "0xc001102b:0x1808cc16"]
Special custom value for first generation Zen CPUs (with known hardware bug) to disable opcache and enable MSR mod.