Page MenuHomeFreeBSD

gicv3: If the LPI is already allocated, remember it
ClosedPublic

Authored by imp on Feb 23 2024, 4:47 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 13, 10:40 PM
Unknown Object (File)
Fri, Jan 10, 9:17 PM
Unknown Object (File)
Fri, Jan 10, 5:44 AM
Unknown Object (File)
Thu, Jan 9, 10:17 PM
Unknown Object (File)
Dec 8 2024, 7:29 PM
Unknown Object (File)
Dec 5 2024, 4:50 PM
Unknown Object (File)
Nov 29 2024, 8:14 AM
Unknown Object (File)
Nov 25 2024, 4:19 AM
Subscribers

Details

Summary

If the LPI has been pre-allocated by the boot loader, then we have to
remember PROPBASER and use it rather than allocating memory for it
ourselves. Linux provides us with a reserved table that contains all the
gicv3 allocates, so make sure what we read from PROPBASER matches
something in that table. Normally, the boot loader would leave the gic
in a reset state. However, Linux brings it up fully so it can do I/O to
boot the next kernel (us in this case). Since the gicv3 can't be
restarted due to undefined behavior, we have to use the mapping we
discover.

With this commit, the workaround is complete. Details are at
https://lkml.iu.edu/hypermail/linux/kernel/1809.2/06246.html
and pointers in the thread.

Sponsored by: Netflix

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 56264
Build 53152: arc lint + arc unit

Event Timeline

Better panic message
Fix GICV3_ITS_MASK usage and definition

With this, I can now boot on all the same hardware that the old, hacky version did.

andrew added inline comments.
sys/arm64/arm64/gicv3_its.c
729–730

Should this be behind bootverbose?

This revision is now accepted and ready to land.Feb 27 2024, 10:19 AM
This revision now requires review to proceed.Feb 27 2024, 4:31 PM

Toss this message behind a bootverbose.

This revision is now accepted and ready to land.Feb 28 2024, 10:20 AM