Page MenuHomeFreeBSD

[PowerPC64] fix crash when using machdep.moea64_bpvo_pool_size tunable
ClosedPublic

Authored by alfredo on Jan 17 2020, 2:03 PM.
Referenced Files
Unknown Object (File)
Wed, Sep 17, 11:24 AM
Unknown Object (File)
Aug 14 2025, 4:55 AM
Unknown Object (File)
Jul 28 2025, 5:31 AM
Unknown Object (File)
Jul 26 2025, 3:12 PM
Unknown Object (File)
Jul 7 2025, 1:24 AM
Unknown Object (File)
Jul 2 2025, 7:31 PM
Unknown Object (File)
Jun 19 2025, 6:30 AM
Unknown Object (File)
Jun 17 2025, 2:02 AM
Subscribers

Details

Summary

This fixes kernel crashing when tunable "machdep.moea64_bpvo_pool_size" is set to a value higher then 327680 (default value).
Function moea64_mid_bootstrap() relies on moea64_bpvo_pool_size, but at time of the use the variable wan't yet updated with the new value provided by user.

Problem was detected after trying to use a VM with 64GB of RAM, and default moea64_bpvo_pool_size is insufficient (kernel boot used more than 470000) .
I think default value must be discussed to address this use case, or find a way to calculate pool size automatically based on amount of memory detected.

Test Plan

Tested on QEMU VM with 64GB of RAM using "set machdep.moea64_bpvo_pool_size=655360" on loader prompt

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

sys/powerpc/aim/mmu_oea64.c
917 ↗(On Diff #66909)

Having this here, shouldn't you delete the TUNABLE_INT() above on line 188?

This revision was not accepted when it landed; it landed in state Needs Review.Jan 19 2020, 9:18 PM
This revision was automatically updated to reflect the committed changes.