diff options
author | Marc Zyngier <[email protected]> | 2022-01-24 13:38:09 +0000 |
---|---|---|
committer | Marc Zyngier <[email protected]> | 2022-01-26 11:10:28 +0000 |
commit | c733ebb7cb67dfb146a07c0ae329a0de9ec52f36 (patch) | |
tree | 14c74e8d3462114d40faef82b9205cf4d53bde60 /tools/testing/selftests/bpf/progs/connect_unix_prog.c | |
parent | 16436f70abeebb29cd99444e27b310755806c1fa (diff) |
irqchip/gic-v3-its: Reset each ITS's BASERn register before probe
A recent bug report outlined that the way GICv4.1 is handled across
kexec is pretty bad. We can end-up in a situation where ITSs share
memory (this is the case when SVPET==1) and reprogram the base
registers, creating a situation where ITSs that are part of a given
affinity group see different pointers. Which is illegal. Boo.
In order to restore some sanity, reset the BASERn registers to 0
*before* probing any ITS. Although this isn't optimised at all,
this is only a once-per-boot cost, which shouldn't show up on
anyone's radar.
Cc: Jay Chen <[email protected]>
Signed-off-by: Marc Zyngier <[email protected]>
Reviewed-by: Lorenzo Pieralisi <[email protected]>
Link: https://lore.kernel.org/r/20211216190315.GA14220@lpieralisi
Link: https://lore.kernel.org/r/[email protected]
Diffstat (limited to 'tools/testing/selftests/bpf/progs/connect_unix_prog.c')
0 files changed, 0 insertions, 0 deletions