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)
Thu, Jun 4, 7:40 PM
Unknown Object (File)
Tue, Jun 2, 7:10 PM
Unknown Object (File)
Fri, May 29, 3:56 AM
Unknown Object (File)
Wed, May 27, 7:37 AM
Unknown Object (File)
Mon, May 25, 8:08 PM
Unknown Object (File)
Sun, May 24, 11:00 PM
Unknown Object (File)
Fri, May 22, 3:36 PM
Unknown Object (File)
Fri, May 22, 8:18 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.