hw/loongarch/virt: Set iocsr address space per-board rather than percpu
authorBibo Mao <maobibo@loongson.cn>
Wed, 13 Dec 2023 04:13:14 +0000 (12:13 +0800)
committerSong Gao <gaosong@loongson.cn>
Thu, 11 Jan 2024 11:22:47 +0000 (19:22 +0800)
commit5e90b8db382418165a4295fbe4ae9cc45b22d6ea
tree6a038a3548330d6bc6724fa39fa57f507a057a47
parentfdd6ee0b7653e5b195e0b351fb53bb1e6d4c84bd
hw/loongarch/virt: Set iocsr address space per-board rather than percpu

LoongArch system has iocsr address space, most iocsr registers are
per-board, however some iocsr register spaces banked for percpu such
as ipi mailbox and extioi interrupt status. For banked iocsr space,
each cpu has the same iocsr space, but separate data.

This patch changes iocsr address space per-board rather percpu,
for iocsr registers specified for cpu, MemTxAttrs.requester_id
can be parsed for the cpu. With this patches, the total address space
on board will be simple, only iocsr address space and system memory,
rather than the number of cpu and system memory.

Signed-off-by: Bibo Mao <maobibo@loongson.cn>
Reviewed-by: Song Gao <gaosong@loongson.cn>
Message-Id: <20231215100333.3933632-3-maobibo@loongson.cn>
Signed-off-by: Song Gao <gaosong@loongson.cn>
hw/intc/loongarch_extioi.c
hw/intc/loongarch_ipi.c
hw/loongarch/virt.c
include/hw/intc/loongarch_extioi.h
include/hw/intc/loongarch_ipi.h
include/hw/loongarch/virt.h
target/loongarch/cpu.c
target/loongarch/cpu.h
target/loongarch/kvm/kvm.c
target/loongarch/tcg/iocsr_helper.c