Page MenuHomeFreeBSD

[PPC64] Fix NUMA on POWER8
ClosedPublic

Authored by luporl on Jan 29 2020, 4:16 PM.
Referenced Files
Unknown Object (File)
Sun, Jan 5, 5:47 PM
Unknown Object (File)
Mon, Dec 30, 5:46 PM
Unknown Object (File)
Sun, Dec 29, 2:54 PM
Unknown Object (File)
Sat, Dec 28, 3:09 PM
Unknown Object (File)
Fri, Dec 27, 5:56 PM
Unknown Object (File)
Nov 6 2024, 2:26 PM
Unknown Object (File)
Oct 3 2024, 4:47 PM
Unknown Object (File)
Sep 30 2024, 5:55 PM

Details

Summary

On some POWER8 machines, 'ibm,associativity' property may have 6
cells, which would overflow the 5 cells buffer being used.
There was also an issue with the "check if node is root" part,
that have been fixed too.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 29018
Build 26990: arc lint + arc unit

Event Timeline

sys/powerpc/powernv/platform_powernv.c
531–534

I would suggest you just move this up, and not bother with the OF_getproplen(), just do

res = OF_getencprop(...)

if (res < 0) {
  ...
}
luporl added inline comments.
sys/powerpc/powernv/platform_powernv.c
531–534

Right, it's better indeed.

sys/powerpc/powernv/platform_powernv.c
532–534

I think this KASSERT() is unnecessary. A violation of this "invariant" is really a broken device tree, not a kernel bug. Maybe "if (res < sizeof(cell_t) * (platform_associativity + 1))" up above instead?

We can limp along with a busted device tree, we don't need to panic.

  • Address review comments
sys/powerpc/powernv/platform_powernv.c
532–534

Right, do you think it's ok now?

This revision is now accepted and ready to land.Jan 29 2020, 5:59 PM
This revision was automatically updated to reflect the committed changes.