if (ret) {
                        dev_err(&dev_info->dev,
                                "Could not get chrdev interface\n");
-                       goto error_free_setup_ev_ints;
+                       goto error_free_setup_event_lines;
                }
 
                dev_set_drvdata(&dev_info->event_interfaces[i].dev,
                if (ret) {
                        dev_err(&dev_info->dev,
                                "Failed to register sysfs for event attrs");
-                       goto error_remove_sysfs_interfaces;
+                       iio_free_ev_int(&dev_info->event_interfaces[i]);
+                       goto error_free_setup_event_lines;
                }
-       }
-
-       for (i = 0; i < dev_info->info->num_interrupt_lines; i++) {
                ret = __iio_add_event_config_attrs(dev_info, i);
-               if (ret)
-                       goto error_unregister_config_attrs;
+               if (ret) {
+                       if (dev_info->info->event_attrs != NULL)
+                               sysfs_remove_group(&dev_info
+                                                  ->event_interfaces[i]
+                                                  .dev.kobj,
+                                                  &dev_info->info
+                                                  ->event_attrs[i]);
+                       iio_free_ev_int(&dev_info->event_interfaces[i]);
+                       goto error_free_setup_event_lines;
+               }
        }
 
        return 0;
 
-error_unregister_config_attrs:
-       for (j = 0; j < i; j++)
-               __iio_remove_event_config_attrs(dev_info, i);
-       i = dev_info->info->num_interrupt_lines - 1;
-error_remove_sysfs_interfaces:
-       for (j = 0; j < i; j++)
+error_free_setup_event_lines:
+       for (j = 0; j < i; j++) {
+               __iio_remove_event_config_attrs(dev_info, j);
                if (dev_info->info->event_attrs != NULL)
                        sysfs_remove_group(&dev_info
-                                  ->event_interfaces[j].dev.kobj,
-                                  &dev_info->info->event_attrs[j]);
-error_free_setup_ev_ints:
-       for (j = 0; j < i; j++)
+                                          ->event_interfaces[j].dev.kobj,
+                                          &dev_info->info->event_attrs[j]);
                iio_free_ev_int(&dev_info->event_interfaces[j]);
+       }
        kfree(dev_info->event_interfaces);
 error_ret:
 
                        sysfs_remove_group(&dev_info
                                           ->event_interfaces[i].dev.kobj,
                                           &dev_info->info->event_attrs[i]);
-       }
-
-       for (i = 0; i < dev_info->info->num_interrupt_lines; i++)
                iio_free_ev_int(&dev_info->event_interfaces[i]);
+       }
        kfree(dev_info->event_interfaces);
 }