Page MenuHomeFreeBSD

PPC64: use hwref instead of cpuid
ClosedPublic

Authored by wma on Jan 22 2018, 6:53 AM.
Tags
None
Referenced Files
F107150915: D14011.diff
Fri, Jan 10, 9:48 PM
Unknown Object (File)
Tue, Jan 7, 1:28 AM
Unknown Object (File)
Oct 3 2024, 9:38 PM
Unknown Object (File)
Oct 2 2024, 7:11 AM
Unknown Object (File)
Oct 1 2024, 7:03 PM
Unknown Object (File)
Oct 1 2024, 12:39 PM
Unknown Object (File)
Sep 19 2024, 5:39 PM
Unknown Object (File)
Sep 17 2024, 8:31 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 Skipped
Unit
Tests Skipped

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.