Input: matrix-keymap - switch to using __free() cleanup facility
authorDmitry Torokhov <dmitry.torokhov@gmail.com>
Sat, 24 Aug 2024 23:09:04 +0000 (16:09 -0700)
committerDmitry Torokhov <dmitry.torokhov@gmail.com>
Thu, 29 Aug 2024 17:59:30 +0000 (10:59 -0700)
Use __free(kfree) cleanup facility in matrix_keypad_parse_keymap() to
automatically free temporarily allocated memory.

Reviewed-by: Hans de Goede <hdegoede@redhat.com>
Link: https://lore.kernel.org/r/ZspoEPdTcH-hpciy@google.com
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
drivers/input/matrix-keymap.c

index 5d93043..3bea357 100644 (file)
@@ -73,10 +73,9 @@ static int matrix_keypad_parse_keymap(const char *propname,
        struct device *dev = input_dev->dev.parent;
        unsigned int row_shift = get_count_order(cols);
        unsigned int max_keys = rows << row_shift;
-       u32 *keys;
        int i;
        int size;
-       int retval;
+       int error;
 
        if (!propname)
                propname = "linux,keymap";
@@ -94,30 +93,24 @@ static int matrix_keypad_parse_keymap(const char *propname,
                return -EINVAL;
        }
 
-       keys = kmalloc_array(size, sizeof(u32), GFP_KERNEL);
+       u32 *keys __free(kfree) = kmalloc_array(size, sizeof(*keys), GFP_KERNEL);
        if (!keys)
                return -ENOMEM;
 
-       retval = device_property_read_u32_array(dev, propname, keys, size);
-       if (retval) {
+       error = device_property_read_u32_array(dev, propname, keys, size);
+       if (error) {
                dev_err(dev, "failed to read %s property: %d\n",
-                       propname, retval);
-               goto out;
+                       propname, error);
+               return error;
        }
 
        for (i = 0; i < size; i++) {
                if (!matrix_keypad_map_key(input_dev, rows, cols,
-                                          row_shift, keys[i])) {
-                       retval = -EINVAL;
-                       goto out;
-               }
+                                          row_shift, keys[i]))
+                       return -EINVAL;
        }
 
-       retval = 0;
-
-out:
-       kfree(keys);
-       return retval;
+       return 0;
 }
 
 /**