Page MenuHomeFreeBSD

PPC64: use hwref instead of cpuid
ClosedPublic

Authored by wma on Jan 22 2018, 6:53 AM.
Tags
None
Referenced Files
F125072249: D14011.diff
Sun, Aug 3, 3:03 AM
F125048886: D14011.diff
Sat, Aug 2, 8:56 PM
Unknown Object (File)
Wed, Jul 23, 9:47 AM
Unknown Object (File)
Wed, Jul 23, 3:08 AM
Unknown Object (File)
Tue, Jul 22, 6:40 AM
Unknown Object (File)
Tue, Jul 15, 8:55 AM
Unknown Object (File)
Sat, Jul 5, 7:50 PM
Unknown Object (File)
Jun 30 2025, 9:07 PM
Subscribers

Details

Summary

On CHRP and PowerNV, use the interrupt server number in the cpuref and pcpu
hwref field instead of the device-tree phandle and make the CPU IDs reported
to the scheduler dense and with the BSP at 0.

WARNING: tested on PowerNV. Does work only when BSP is CPU[0]. TBD if wokrs on other ppc64 boards.

Diff Detail

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

Event Timeline

I like the approach. Why doesn't it work if BSP is non-zero? Doesn't this code arrange for the BSP to always be zero?

It SHOULD work on PowerNV as the code for cpuid swap is there, however I did not run much of testing, so I'd rather consider this as experimental/not-working. The CHRP platform has no such code, so there the BSP must be at CPU0.

This revision was not accepted when it landed; it landed in state Needs Review.Jan 29 2018, 9:15 AM
This revision was automatically updated to reflect the committed changes.

There is intrinsically no difference between CHRP and PowerNV. Could you please update CHRP to match, including the BSP 0 code, (copy-and-paste is fine) and test it on your POWER8 system? I don't have access to any POWER8 hardware and the moment and the risk of breaking Power[K]VM is high.