|
@@ -1466,6 +1466,16 @@ static void vgic_mmio_write_its_ctlr(struct kvm *kvm, struct vgic_its *its,
|
|
|
{
|
|
|
mutex_lock(&its->cmd_lock);
|
|
|
|
|
|
+ /*
|
|
|
+ * It is UNPREDICTABLE to enable the ITS if any of the CBASER or
|
|
|
+ * device/collection BASER are invalid
|
|
|
+ */
|
|
|
+ if (!its->enabled && (val & GITS_CTLR_ENABLE) &&
|
|
|
+ (!(its->baser_device_table & GITS_BASER_VALID) ||
|
|
|
+ !(its->baser_coll_table & GITS_BASER_VALID) ||
|
|
|
+ !(its->cbaser & GITS_CBASER_VALID)))
|
|
|
+ goto out;
|
|
|
+
|
|
|
its->enabled = !!(val & GITS_CTLR_ENABLE);
|
|
|
|
|
|
/*
|
|
@@ -1474,6 +1484,7 @@ static void vgic_mmio_write_its_ctlr(struct kvm *kvm, struct vgic_its *its,
|
|
|
*/
|
|
|
vgic_its_process_commands(kvm, its);
|
|
|
|
|
|
+out:
|
|
|
mutex_unlock(&its->cmd_lock);
|
|
|
}
|
|
|
|