KVM: ia64: fix the error of ioctl KVM_IRQ_LINE if no irq chip
authorWei Yongjun <yjwei@cn.fujitsu.com>
Fri, 12 Mar 2010 02:11:15 +0000 (10:11 +0800)
committerAvi Kivity <avi@redhat.com>
Mon, 17 May 2010 09:15:33 +0000 (12:15 +0300)
If no irq chip in kernel, ioctl KVM_IRQ_LINE will return -EFAULT.
But I see in other place such as KVM_[GET|SET]IRQCHIP, -ENXIO is
return. So this patch used -ENXIO instead of -EFAULT.

Signed-off-by: Wei Yongjun <yjwei@cn.fujitsu.com>
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
arch/ia64/kvm/kvm-ia64.c

index 38d51302f5b3e44da3b5adeb97ad42ffe3699e6d..d7bac1f75af0acf0132f0f12a582da3cfbe36e11 100644 (file)
@@ -979,11 +979,13 @@ long kvm_arch_vm_ioctl(struct file *filp,
                r = -EFAULT;
                if (copy_from_user(&irq_event, argp, sizeof irq_event))
                        goto out;
+               r = -ENXIO;
                if (irqchip_in_kernel(kvm)) {
                        __s32 status;
                        status = kvm_set_irq(kvm, KVM_USERSPACE_IRQ_SOURCE_ID,
                                    irq_event.irq, irq_event.level);
                        if (ioctl == KVM_IRQ_LINE_STATUS) {
+                               r = -EFAULT;
                                irq_event.status = status;
                                if (copy_to_user(argp, &irq_event,
                                                        sizeof irq_event))