mirror of
https://github.com/xemu-project/xemu.git
synced 2024-11-23 19:49:43 +00:00
hw/intc/arm_gicv3_its: Don't allow intid 1023 in MAPI/MAPTI
When handling MAPI/MAPTI, we allow the supplied interrupt ID to be either 1023 or something in the valid LPI range. This is a mistake: only a real valid LPI is allowed. (The general behaviour of the ITS is that most interrupt ID fields require a value in the LPI range; the exception is that fields specifying a doorbell value, which are all in GICv4 commands, allow also 1023 to mean "no doorbell".) Remove the condition that incorrectly allows 1023 here. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20220201193207.2771604-13-peter.maydell@linaro.org
This commit is contained in:
parent
84d43d2e82
commit
3330241407
@ -406,8 +406,7 @@ static ItsCmdResult process_mapti(GICv3ITSState *s, const uint64_t *cmdpkt,
|
||||
|
||||
if ((icid >= s->ct.num_entries)
|
||||
|| !dte.valid || (eventid >= num_eventids) ||
|
||||
(((pIntid < GICV3_LPI_INTID_START) || (pIntid >= num_intids)) &&
|
||||
(pIntid != INTID_SPURIOUS))) {
|
||||
(((pIntid < GICV3_LPI_INTID_START) || (pIntid >= num_intids)))) {
|
||||
qemu_log_mask(LOG_GUEST_ERROR,
|
||||
"%s: invalid command attributes "
|
||||
"icid %d or eventid %d or pIntid %d or"
|
||||
|
Loading…
Reference in New Issue
Block a user