Message ID | 20170901165156.30775-1-marc.zyngier@arm.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Hi, On 01/09/17 17:51, Marc Zyngier wrote: > For unknown reasons, the its_ite data structure carries an "lpi" field > which contains the intid of the LPI. This is an obvious duplication > of the vgic_irq->intid field, so let's fix the only user and remove > the now useless field. Interesting, I guess that comes from the dawn of time, before we had struct vgic_irq. And since the architecture says that the LPI ID is the actual information stored in the ITE, I never revisited this again. > Signed-off-by: Marc Zyngier <marc.zyngier@arm.com> Looks good to me! Reviewed-by: Andre Przywara <andre.przywara@arm.com> Thanks, Andre. > --- > virt/kvm/arm/vgic/vgic-its.c | 10 ++++------ > 1 file changed, 4 insertions(+), 6 deletions(-) > > diff --git a/virt/kvm/arm/vgic/vgic-its.c b/virt/kvm/arm/vgic/vgic-its.c > index dd85817a9b29..01aa4d9d405e 100644 > --- a/virt/kvm/arm/vgic/vgic-its.c > +++ b/virt/kvm/arm/vgic/vgic-its.c > @@ -142,7 +142,6 @@ struct its_ite { > > struct vgic_irq *irq; > struct its_collection *collection; > - u32 lpi; > u32 event_id; > }; > > @@ -851,7 +850,7 @@ static void vgic_its_free_collection(struct vgic_its *its, u32 coll_id) > /* Must be called with its_lock mutex held */ > static struct its_ite *vgic_its_alloc_ite(struct its_device *device, > struct its_collection *collection, > - u32 lpi_id, u32 event_id) > + u32 event_id) > { > struct its_ite *ite; > > @@ -861,7 +860,6 @@ static struct its_ite *vgic_its_alloc_ite(struct its_device *device, > > ite->event_id = event_id; > ite->collection = collection; > - ite->lpi = lpi_id; > > list_add_tail(&ite->ite_list, &device->itt_head); > return ite; > @@ -911,7 +909,7 @@ static int vgic_its_cmd_handle_mapi(struct kvm *kvm, struct vgic_its *its, > new_coll = collection; > } > > - ite = vgic_its_alloc_ite(device, collection, lpi_nr, event_id); > + ite = vgic_its_alloc_ite(device, collection, event_id); > if (IS_ERR(ite)) { > if (new_coll) > vgic_its_free_collection(its, coll_id); > @@ -1902,7 +1900,7 @@ static int vgic_its_save_ite(struct vgic_its *its, struct its_device *dev, > > next_offset = compute_next_eventid_offset(&dev->itt_head, ite); > val = ((u64)next_offset << KVM_ITS_ITE_NEXT_SHIFT) | > - ((u64)ite->lpi << KVM_ITS_ITE_PINTID_SHIFT) | > + ((u64)ite->irq->intid << KVM_ITS_ITE_PINTID_SHIFT) | > ite->collection->collection_id; > val = cpu_to_le64(val); > return kvm_write_guest(kvm, gpa, &val, ite_esz); > @@ -1949,7 +1947,7 @@ static int vgic_its_restore_ite(struct vgic_its *its, u32 event_id, > if (!collection) > return -EINVAL; > > - ite = vgic_its_alloc_ite(dev, collection, lpi_id, event_id); > + ite = vgic_its_alloc_ite(dev, collection, event_id); > if (IS_ERR(ite)) > return PTR_ERR(ite); > >
On Fri, Sep 01, 2017 at 05:51:56PM +0100, Marc Zyngier wrote: > For unknown reasons, the its_ite data structure carries an "lpi" field > which contains the intid of the LPI. This is an obvious duplication > of the vgic_irq->intid field, so let's fix the only user and remove > the now useless field. > > Signed-off-by: Marc Zyngier <marc.zyngier@arm.com> Applied, thanks. -Christoffer > --- > virt/kvm/arm/vgic/vgic-its.c | 10 ++++------ > 1 file changed, 4 insertions(+), 6 deletions(-) > > diff --git a/virt/kvm/arm/vgic/vgic-its.c b/virt/kvm/arm/vgic/vgic-its.c > index dd85817a9b29..01aa4d9d405e 100644 > --- a/virt/kvm/arm/vgic/vgic-its.c > +++ b/virt/kvm/arm/vgic/vgic-its.c > @@ -142,7 +142,6 @@ struct its_ite { > > struct vgic_irq *irq; > struct its_collection *collection; > - u32 lpi; > u32 event_id; > }; > > @@ -851,7 +850,7 @@ static void vgic_its_free_collection(struct vgic_its *its, u32 coll_id) > /* Must be called with its_lock mutex held */ > static struct its_ite *vgic_its_alloc_ite(struct its_device *device, > struct its_collection *collection, > - u32 lpi_id, u32 event_id) > + u32 event_id) > { > struct its_ite *ite; > > @@ -861,7 +860,6 @@ static struct its_ite *vgic_its_alloc_ite(struct its_device *device, > > ite->event_id = event_id; > ite->collection = collection; > - ite->lpi = lpi_id; > > list_add_tail(&ite->ite_list, &device->itt_head); > return ite; > @@ -911,7 +909,7 @@ static int vgic_its_cmd_handle_mapi(struct kvm *kvm, struct vgic_its *its, > new_coll = collection; > } > > - ite = vgic_its_alloc_ite(device, collection, lpi_nr, event_id); > + ite = vgic_its_alloc_ite(device, collection, event_id); > if (IS_ERR(ite)) { > if (new_coll) > vgic_its_free_collection(its, coll_id); > @@ -1902,7 +1900,7 @@ static int vgic_its_save_ite(struct vgic_its *its, struct its_device *dev, > > next_offset = compute_next_eventid_offset(&dev->itt_head, ite); > val = ((u64)next_offset << KVM_ITS_ITE_NEXT_SHIFT) | > - ((u64)ite->lpi << KVM_ITS_ITE_PINTID_SHIFT) | > + ((u64)ite->irq->intid << KVM_ITS_ITE_PINTID_SHIFT) | > ite->collection->collection_id; > val = cpu_to_le64(val); > return kvm_write_guest(kvm, gpa, &val, ite_esz); > @@ -1949,7 +1947,7 @@ static int vgic_its_restore_ite(struct vgic_its *its, u32 event_id, > if (!collection) > return -EINVAL; > > - ite = vgic_its_alloc_ite(dev, collection, lpi_id, event_id); > + ite = vgic_its_alloc_ite(dev, collection, event_id); > if (IS_ERR(ite)) > return PTR_ERR(ite); > > -- > 2.11.0 >
diff --git a/virt/kvm/arm/vgic/vgic-its.c b/virt/kvm/arm/vgic/vgic-its.c index dd85817a9b29..01aa4d9d405e 100644 --- a/virt/kvm/arm/vgic/vgic-its.c +++ b/virt/kvm/arm/vgic/vgic-its.c @@ -142,7 +142,6 @@ struct its_ite { struct vgic_irq *irq; struct its_collection *collection; - u32 lpi; u32 event_id; }; @@ -851,7 +850,7 @@ static void vgic_its_free_collection(struct vgic_its *its, u32 coll_id) /* Must be called with its_lock mutex held */ static struct its_ite *vgic_its_alloc_ite(struct its_device *device, struct its_collection *collection, - u32 lpi_id, u32 event_id) + u32 event_id) { struct its_ite *ite; @@ -861,7 +860,6 @@ static struct its_ite *vgic_its_alloc_ite(struct its_device *device, ite->event_id = event_id; ite->collection = collection; - ite->lpi = lpi_id; list_add_tail(&ite->ite_list, &device->itt_head); return ite; @@ -911,7 +909,7 @@ static int vgic_its_cmd_handle_mapi(struct kvm *kvm, struct vgic_its *its, new_coll = collection; } - ite = vgic_its_alloc_ite(device, collection, lpi_nr, event_id); + ite = vgic_its_alloc_ite(device, collection, event_id); if (IS_ERR(ite)) { if (new_coll) vgic_its_free_collection(its, coll_id); @@ -1902,7 +1900,7 @@ static int vgic_its_save_ite(struct vgic_its *its, struct its_device *dev, next_offset = compute_next_eventid_offset(&dev->itt_head, ite); val = ((u64)next_offset << KVM_ITS_ITE_NEXT_SHIFT) | - ((u64)ite->lpi << KVM_ITS_ITE_PINTID_SHIFT) | + ((u64)ite->irq->intid << KVM_ITS_ITE_PINTID_SHIFT) | ite->collection->collection_id; val = cpu_to_le64(val); return kvm_write_guest(kvm, gpa, &val, ite_esz); @@ -1949,7 +1947,7 @@ static int vgic_its_restore_ite(struct vgic_its *its, u32 event_id, if (!collection) return -EINVAL; - ite = vgic_its_alloc_ite(dev, collection, lpi_id, event_id); + ite = vgic_its_alloc_ite(dev, collection, event_id); if (IS_ERR(ite)) return PTR_ERR(ite);
For unknown reasons, the its_ite data structure carries an "lpi" field which contains the intid of the LPI. This is an obvious duplication of the vgic_irq->intid field, so let's fix the only user and remove the now useless field. Signed-off-by: Marc Zyngier <marc.zyngier@arm.com> --- virt/kvm/arm/vgic/vgic-its.c | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-)