Page MenuHomeFreeBSD

PPC64: use hwref instead of cpuid
ClosedPublic

Authored by wma on Jan 22 2018, 6:53 AM.
Tags
None
Referenced Files
Unknown Object (File)
May 9 2024, 5:12 AM
Unknown Object (File)
Dec 31 2023, 1:11 PM
Unknown Object (File)
Dec 12 2023, 3:57 PM
Unknown Object (File)
Nov 8 2023, 2:14 PM
Unknown Object (File)
Sep 25 2023, 9:18 AM
Unknown Object (File)
Sep 25 2023, 9:16 AM
Unknown Object (File)
Sep 25 2023, 9:13 AM
Unknown Object (File)
Sep 16 2023, 3:05 AM
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.