[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[xen staging] xen/arm: dm: Bail out if padding != 0 for XEN_DMOP_set_irq_level



commit c29e5a16cb9c5331207edac5a8d495e7b22d6214
Author:     Michal Orzel <michal.orzel@xxxxxxx>
AuthorDate: Mon Mar 3 09:56:47 2025 +0100
Commit:     Michal Orzel <michal.orzel@xxxxxxx>
CommitDate: Tue Mar 4 08:54:53 2025 +0100

    xen/arm: dm: Bail out if padding != 0 for XEN_DMOP_set_irq_level
    
    XEN_DMOP_set_irq_level operation requires elements of pad array (being
    member of xen_dm_op_set_irq_level structure) to be 0. While handling the
    hypercall we validate this. If one of the elements is not zero, we set
    rc to -EINVAL. At this point we should stop further DM handling and bail
    out propagating the error to the caller. However, instead of goto the
    code uses break which has basically no meaningful effect. The rc value
    is never read and the code continues with the hypercall processing ending
    up (possibly) with the interrupt injection. Fix it.
    
    Fixes: 5d752df85f2c ("xen/dm: Introduce xendevicemodel_set_irq_level DM op")
    Signed-off-by: Michal Orzel <michal.orzel@xxxxxxx>
    Reviewed-by: Bertrand Marquis <bertrand.marquis@xxxxxxx>
---
 xen/arch/arm/dm.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/xen/arch/arm/dm.c b/xen/arch/arm/dm.c
index 773a0a2592..fdb3d967ec 100644
--- a/xen/arch/arm/dm.c
+++ b/xen/arch/arm/dm.c
@@ -93,7 +93,7 @@ int dm_op(const struct dmop_args *op_args)
             if ( data->pad[i] )
             {
                 rc = -EINVAL;
-                break;
+                goto out;
             }
         }
 
--
generated by git-patchbot for /home/xen/git/xen.git#staging



 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.