]> www.infradead.org Git - users/hch/misc.git/commitdiff
staging: gasket: interrupt: simplify interrupt init parameters
authorTodd Poynor <toddpoynor@google.com>
Fri, 10 Aug 2018 03:21:10 +0000 (20:21 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 27 Aug 2018 17:43:44 +0000 (19:43 +0200)
Pass the gasket driver descriptor to the interrupt init function, rather
than exploding out separate parameters from various fields of that
structure.  This allows us to make more localized changes to the types
of interrupts supported (MSIX vs. wire, etc.) without affecting the
calling sequence, and seems nicer for simplification purposes.

Signed-off-by: Todd Poynor <toddpoynor@google.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/gasket/gasket_core.c
drivers/staging/gasket/gasket_interrupt.c
drivers/staging/gasket/gasket_interrupt.h

index 99f3f11d75ce214d0ce891bca54340ca75c6bc8a..f230bec76ae4e06a9f989d62c3db26c1bec07cff 100644 (file)
@@ -1357,13 +1357,7 @@ int gasket_enable_device(struct gasket_dev *gasket_dev)
        const struct gasket_driver_desc *driver_desc =
                gasket_dev->internal_desc->driver_desc;
 
-       ret = gasket_interrupt_init(gasket_dev, driver_desc->name,
-                                   driver_desc->interrupt_type,
-                                   driver_desc->interrupts,
-                                   driver_desc->num_interrupts,
-                                   driver_desc->interrupt_pack_width,
-                                   driver_desc->interrupt_bar_index,
-                                   driver_desc->wire_interrupt_offsets);
+       ret = gasket_interrupt_init(gasket_dev);
        if (ret) {
                dev_err(gasket_dev->dev,
                        "Critical failure to allocate interrupts: %d\n", ret);
index f94e4ea9a7dedaf04e67a0713a82435cc94ece9f..eb5dfbe08e21477de6390dabd35a5be460316ab7 100644 (file)
@@ -331,31 +331,30 @@ static struct gasket_sysfs_attribute interrupt_sysfs_attrs[] = {
        GASKET_END_OF_ATTR_ARRAY,
 };
 
-int gasket_interrupt_init(struct gasket_dev *gasket_dev, const char *name,
-                         int type,
-                         const struct gasket_interrupt_desc *interrupts,
-                         int num_interrupts, int pack_width, int bar_index,
-                         const struct gasket_wire_interrupt_offsets *wire_int_offsets)
+int gasket_interrupt_init(struct gasket_dev *gasket_dev)
 {
        int ret;
        struct gasket_interrupt_data *interrupt_data;
+       const struct gasket_driver_desc *driver_desc =
+               gasket_get_driver_desc(gasket_dev);
 
        interrupt_data = kzalloc(sizeof(struct gasket_interrupt_data),
                                 GFP_KERNEL);
        if (!interrupt_data)
                return -ENOMEM;
        gasket_dev->interrupt_data = interrupt_data;
-       interrupt_data->name = name;
-       interrupt_data->type = type;
+       interrupt_data->name = driver_desc->name;
+       interrupt_data->type = driver_desc->interrupt_type;
        interrupt_data->pci_dev = gasket_dev->pci_dev;
-       interrupt_data->num_interrupts = num_interrupts;
-       interrupt_data->interrupts = interrupts;
-       interrupt_data->interrupt_bar_index = bar_index;
-       interrupt_data->pack_width = pack_width;
+       interrupt_data->num_interrupts = driver_desc->num_interrupts;
+       interrupt_data->interrupts = driver_desc->interrupts;
+       interrupt_data->interrupt_bar_index = driver_desc->interrupt_bar_index;
+       interrupt_data->pack_width = driver_desc->interrupt_pack_width;
        interrupt_data->num_configured = 0;
-       interrupt_data->wire_interrupt_offsets = wire_int_offsets;
+       interrupt_data->wire_interrupt_offsets =
+           driver_desc->wire_interrupt_offsets;
 
-       interrupt_data->eventfd_ctxs = kcalloc(num_interrupts,
+       interrupt_data->eventfd_ctxs = kcalloc(driver_desc->num_interrupts,
                                               sizeof(struct eventfd_ctx *),
                                               GFP_KERNEL);
        if (!interrupt_data->eventfd_ctxs) {
@@ -363,7 +362,7 @@ int gasket_interrupt_init(struct gasket_dev *gasket_dev, const char *name,
                return -ENOMEM;
        }
 
-       interrupt_data->interrupt_counts = kcalloc(num_interrupts,
+       interrupt_data->interrupt_counts = kcalloc(driver_desc->num_interrupts,
                                                   sizeof(ulong),
                                                   GFP_KERNEL);
        if (!interrupt_data->interrupt_counts) {
index 835af439e96a9cb7a437e5fd0fb0b48dfc1d1c26..85526a1374a1af10ac178e62cdff6fc147d49016 100644 (file)
@@ -24,30 +24,8 @@ struct gasket_interrupt_data;
 /*
  * Initialize the interrupt module.
  * @gasket_dev: The Gasket device structure for the device to be initted.
- * @type: Type of the interrupt. (See gasket_interrupt_type).
- * @name: The name to associate with these interrupts.
- * @interrupts: An array of all interrupt descriptions for this device.
- * @num_interrupts: The length of the @interrupts array.
- * @pack_width: The width, in bits, of a single field in a packed interrupt reg.
- * @bar_index: The bar containing all interrupt registers.
- *
- * Allocates and initializes data to track interrupt state for a device.
- * After this call, no interrupts will be configured/delivered; call
- * gasket_interrupt_set_vector[_packed] to associate each interrupt with an
- * __iomem location, then gasket_interrupt_set_eventfd to associate an eventfd
- * with an interrupt.
- *
- * If num_interrupts interrupts are not available, this call will return a
- * negative error code. In that case, gasket_interrupt_cleanup should still be
- * called. Returns 0 on success (which can include a device where interrupts
- * are not possible to set up, but is otherwise OK; that device will report
- * status LAMED.)
  */
-int gasket_interrupt_init(struct gasket_dev *gasket_dev, const char *name,
-                         int type,
-                         const struct gasket_interrupt_desc *interrupts,
-                         int num_interrupts, int pack_width, int bar_index,
-                         const struct gasket_wire_interrupt_offsets *wire_int_offsets);
+int gasket_interrupt_init(struct gasket_dev *gasket_dev);
 
 /*
  * Clean up a device's interrupt structure.