mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 01:33:56 -06:00
hw/intc/arm_gicv3: Implement new GICv4 redistributor registers
Implement the new GICv4 redistributor registers: GICR_VPROPBASER and GICR_VPENDBASER; for the moment we implement these as simple reads-as-written stubs, together with the necessary migration and reset handling. We don't put ID-register checks on the handling of these registers, because they are all in the only-in-v4 extra register frames, so they're not accessible in a GICv3. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20220408141550.1271295-24-peter.maydell@linaro.org
This commit is contained in:
parent
ae3b3ba15c
commit
641be69745
4 changed files with 102 additions and 0 deletions
|
@ -77,6 +77,7 @@
|
|||
* Redistributor frame offsets from RD_base
|
||||
*/
|
||||
#define GICR_SGI_OFFSET 0x10000
|
||||
#define GICR_VLPI_OFFSET 0x20000
|
||||
|
||||
/*
|
||||
* Redistributor registers, offsets from RD_base
|
||||
|
@ -109,6 +110,10 @@
|
|||
#define GICR_IGRPMODR0 (GICR_SGI_OFFSET + 0x0D00)
|
||||
#define GICR_NSACR (GICR_SGI_OFFSET + 0x0E00)
|
||||
|
||||
/* VLPI redistributor registers, offsets from VLPI_base */
|
||||
#define GICR_VPROPBASER (GICR_VLPI_OFFSET + 0x70)
|
||||
#define GICR_VPENDBASER (GICR_VLPI_OFFSET + 0x78)
|
||||
|
||||
#define GICR_CTLR_ENABLE_LPIS (1U << 0)
|
||||
#define GICR_CTLR_CES (1U << 1)
|
||||
#define GICR_CTLR_RWP (1U << 3)
|
||||
|
@ -143,6 +148,22 @@ FIELD(GICR_PENDBASER, PTZ, 62, 1)
|
|||
|
||||
#define GICR_PROPBASER_IDBITS_THRESHOLD 0xd
|
||||
|
||||
/* These are the GICv4 VPROPBASER and VPENDBASER layouts; v4.1 is different */
|
||||
FIELD(GICR_VPROPBASER, IDBITS, 0, 5)
|
||||
FIELD(GICR_VPROPBASER, INNERCACHE, 7, 3)
|
||||
FIELD(GICR_VPROPBASER, SHAREABILITY, 10, 2)
|
||||
FIELD(GICR_VPROPBASER, PHYADDR, 12, 40)
|
||||
FIELD(GICR_VPROPBASER, OUTERCACHE, 56, 3)
|
||||
|
||||
FIELD(GICR_VPENDBASER, INNERCACHE, 7, 3)
|
||||
FIELD(GICR_VPENDBASER, SHAREABILITY, 10, 2)
|
||||
FIELD(GICR_VPENDBASER, PHYADDR, 16, 36)
|
||||
FIELD(GICR_VPENDBASER, OUTERCACHE, 56, 3)
|
||||
FIELD(GICR_VPENDBASER, DIRTY, 60, 1)
|
||||
FIELD(GICR_VPENDBASER, PENDINGLAST, 61, 1)
|
||||
FIELD(GICR_VPENDBASER, IDAI, 62, 1)
|
||||
FIELD(GICR_VPENDBASER, VALID, 63, 1)
|
||||
|
||||
#define ICC_CTLR_EL1_CBPR (1U << 0)
|
||||
#define ICC_CTLR_EL1_EOIMODE (1U << 1)
|
||||
#define ICC_CTLR_EL1_PMHE (1U << 6)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue