All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] fixup! vgic-new: make vgic_register_redist_iodevs more readable
@ 2016-05-12 12:44 Andre Przywara
  2016-05-12 19:44 ` Christoffer Dall
  0 siblings, 1 reply; 2+ messages in thread
From: Andre Przywara @ 2016-05-12 12:44 UTC (permalink / raw)
  To: Christoffer Dall, Marc Zyngier; +Cc: kvmarm

Signed-off-by: Andre Przywara <andre.przywara@arm.com>
---
 virt/kvm/arm/vgic/vgic-mmio-v3.c | 42 ++++++++++++++++++++--------------------
 1 file changed, 21 insertions(+), 21 deletions(-)

diff --git a/virt/kvm/arm/vgic/vgic-mmio-v3.c b/virt/kvm/arm/vgic/vgic-mmio-v3.c
index 97995e2..1985d56 100644
--- a/virt/kvm/arm/vgic/vgic-mmio-v3.c
+++ b/virt/kvm/arm/vgic/vgic-mmio-v3.c
@@ -318,7 +318,7 @@ int vgic_register_redist_iodevs(struct kvm *kvm, gpa_t redist_base_address)
 {
 	int nr_vcpus = atomic_read(&kvm->online_vcpus);
 	struct kvm_vcpu *vcpu;
-	struct vgic_io_device *devices, *device;
+	struct vgic_io_device *devices;
 	int c, ret = 0;
 
 	devices = kmalloc(sizeof(struct vgic_io_device) * nr_vcpus * 2,
@@ -326,45 +326,45 @@ int vgic_register_redist_iodevs(struct kvm *kvm, gpa_t redist_base_address)
 	if (!devices)
 		return -ENOMEM;
 
-	device = devices;
 	kvm_for_each_vcpu(c, vcpu, kvm) {
-		kvm_iodevice_init(&device->dev, &kvm_io_gic_ops);
-		device->base_addr = redist_base_address;
-		device->regions = vgic_v3_rdbase_registers;
-		device->nr_regions = ARRAY_SIZE(vgic_v3_rdbase_registers);
-		device->redist_vcpu = vcpu;
+		gpa_t rd_base = redist_base_address + c * SZ_64K * 2;
+		gpa_t sgi_base = rd_base + SZ_64K;
+		struct vgic_io_device *rd_dev = &devices[c * 2];
+		struct vgic_io_device *sgi_dev = &devices[c * 2 + 1];
+
+		kvm_iodevice_init(&rd_dev->dev, &kvm_io_gic_ops);
+		rd_dev->base_addr = rd_base;
+		rd_dev->regions = vgic_v3_rdbase_registers;
+		rd_dev->nr_regions = ARRAY_SIZE(vgic_v3_rdbase_registers);
+		rd_dev->redist_vcpu = vcpu;
 
 		mutex_lock(&kvm->slots_lock);
-		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS,
-					      redist_base_address,
-					      SZ_64K, &device->dev);
+		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, rd_base,
+					      SZ_64K, &rd_dev->dev);
 		mutex_unlock(&kvm->slots_lock);
 
 		if (ret)
 			break;
 
-		device++;
-		kvm_iodevice_init(&device->dev, &kvm_io_gic_ops);
-		device->base_addr = redist_base_address + SZ_64K;
-		device->regions = vgic_v3_sgibase_registers;
-		device->nr_regions = ARRAY_SIZE(vgic_v3_sgibase_registers);
-		device->redist_vcpu = vcpu;
+		kvm_iodevice_init(&sgi_dev->dev, &kvm_io_gic_ops);
+		sgi_dev->base_addr = sgi_base;
+		sgi_dev->regions = vgic_v3_sgibase_registers;
+		sgi_dev->nr_regions = ARRAY_SIZE(vgic_v3_sgibase_registers);
+		sgi_dev->redist_vcpu = vcpu;
 
 		mutex_lock(&kvm->slots_lock);
-		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS,
-					      redist_base_address + SZ_64K,
-					      SZ_64K, &device->dev);
+		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, sgi_base,
+					      SZ_64K, &sgi_dev->dev);
 		mutex_unlock(&kvm->slots_lock);
 		if (ret) {
 			kvm_io_bus_unregister_dev(kvm, KVM_MMIO_BUS,
 						  &devices[c * 2].dev);
 			break;
 		}
-		device++;
-		redist_base_address += 2 * SZ_64K;
 	}
 
 	if (ret) {
+		/* The current c failed, so we start with the previous one. */
 		for (c--; c >= 0; c--) {
 			kvm_io_bus_unregister_dev(kvm, KVM_MMIO_BUS,
 						  &devices[c * 2].dev);
-- 
2.8.2

^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] fixup! vgic-new: make vgic_register_redist_iodevs more readable
  2016-05-12 12:44 [PATCH] fixup! vgic-new: make vgic_register_redist_iodevs more readable Andre Przywara
@ 2016-05-12 19:44 ` Christoffer Dall
  0 siblings, 0 replies; 2+ messages in thread
From: Christoffer Dall @ 2016-05-12 19:44 UTC (permalink / raw)
  To: Andre Przywara; +Cc: Marc Zyngier, kvmarm

On Thu, May 12, 2016 at 01:44:28PM +0100, Andre Przywara wrote:
> Signed-off-by: Andre Przywara <andre.przywara@arm.com>
> ---
>  virt/kvm/arm/vgic/vgic-mmio-v3.c | 42 ++++++++++++++++++++--------------------
>  1 file changed, 21 insertions(+), 21 deletions(-)
> 
> diff --git a/virt/kvm/arm/vgic/vgic-mmio-v3.c b/virt/kvm/arm/vgic/vgic-mmio-v3.c
> index 97995e2..1985d56 100644
> --- a/virt/kvm/arm/vgic/vgic-mmio-v3.c
> +++ b/virt/kvm/arm/vgic/vgic-mmio-v3.c
> @@ -318,7 +318,7 @@ int vgic_register_redist_iodevs(struct kvm *kvm, gpa_t redist_base_address)
>  {
>  	int nr_vcpus = atomic_read(&kvm->online_vcpus);
>  	struct kvm_vcpu *vcpu;
> -	struct vgic_io_device *devices, *device;
> +	struct vgic_io_device *devices;
>  	int c, ret = 0;
>  
>  	devices = kmalloc(sizeof(struct vgic_io_device) * nr_vcpus * 2,
> @@ -326,45 +326,45 @@ int vgic_register_redist_iodevs(struct kvm *kvm, gpa_t redist_base_address)
>  	if (!devices)
>  		return -ENOMEM;
>  
> -	device = devices;
>  	kvm_for_each_vcpu(c, vcpu, kvm) {
> -		kvm_iodevice_init(&device->dev, &kvm_io_gic_ops);
> -		device->base_addr = redist_base_address;
> -		device->regions = vgic_v3_rdbase_registers;
> -		device->nr_regions = ARRAY_SIZE(vgic_v3_rdbase_registers);
> -		device->redist_vcpu = vcpu;
> +		gpa_t rd_base = redist_base_address + c * SZ_64K * 2;
> +		gpa_t sgi_base = rd_base + SZ_64K;
> +		struct vgic_io_device *rd_dev = &devices[c * 2];
> +		struct vgic_io_device *sgi_dev = &devices[c * 2 + 1];
> +
> +		kvm_iodevice_init(&rd_dev->dev, &kvm_io_gic_ops);
> +		rd_dev->base_addr = rd_base;
> +		rd_dev->regions = vgic_v3_rdbase_registers;
> +		rd_dev->nr_regions = ARRAY_SIZE(vgic_v3_rdbase_registers);
> +		rd_dev->redist_vcpu = vcpu;
>  
>  		mutex_lock(&kvm->slots_lock);
> -		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS,
> -					      redist_base_address,
> -					      SZ_64K, &device->dev);
> +		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, rd_base,
> +					      SZ_64K, &rd_dev->dev);
>  		mutex_unlock(&kvm->slots_lock);
>  
>  		if (ret)
>  			break;
>  
> -		device++;
> -		kvm_iodevice_init(&device->dev, &kvm_io_gic_ops);
> -		device->base_addr = redist_base_address + SZ_64K;
> -		device->regions = vgic_v3_sgibase_registers;
> -		device->nr_regions = ARRAY_SIZE(vgic_v3_sgibase_registers);
> -		device->redist_vcpu = vcpu;
> +		kvm_iodevice_init(&sgi_dev->dev, &kvm_io_gic_ops);
> +		sgi_dev->base_addr = sgi_base;
> +		sgi_dev->regions = vgic_v3_sgibase_registers;
> +		sgi_dev->nr_regions = ARRAY_SIZE(vgic_v3_sgibase_registers);
> +		sgi_dev->redist_vcpu = vcpu;
>  
>  		mutex_lock(&kvm->slots_lock);
> -		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS,
> -					      redist_base_address + SZ_64K,
> -					      SZ_64K, &device->dev);
> +		ret = kvm_io_bus_register_dev(kvm, KVM_MMIO_BUS, sgi_base,
> +					      SZ_64K, &sgi_dev->dev);
>  		mutex_unlock(&kvm->slots_lock);
>  		if (ret) {
>  			kvm_io_bus_unregister_dev(kvm, KVM_MMIO_BUS,
>  						  &devices[c * 2].dev);
>  			break;
>  		}
> -		device++;
> -		redist_base_address += 2 * SZ_64K;
>  	}
>  
>  	if (ret) {
> +		/* The current c failed, so we start with the previous one. */
>  		for (c--; c >= 0; c--) {
>  			kvm_io_bus_unregister_dev(kvm, KVM_MMIO_BUS,
>  						  &devices[c * 2].dev);
> -- 
> 2.8.2
> 

Thanks for this, also the comment on the error path !

Looks good,
-Christoffer

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2016-05-12 19:40 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-05-12 12:44 [PATCH] fixup! vgic-new: make vgic_register_redist_iodevs more readable Andre Przywara
2016-05-12 19:44 ` Christoffer Dall

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.