Commit 097acbef authored by Inaky Perez-Gonzalez's avatar Inaky Perez-Gonzalez

wimax/i2400m: make i2400m->bus_dev_{stop,start}() optional

In coming commits, the i2400m SDIO driver will not use
i2400m->bus_dev_stop().

Thus changed to check before calling, as an empty stub has more
overhead than a call to check if the function pointer is non-NULL.
Signed-off-by: default avatarInaky Perez-Gonzalez <inaky@linux.intel.com>
parent 4a78fd9a
...@@ -384,9 +384,11 @@ int __i2400m_dev_start(struct i2400m *i2400m, enum i2400m_bri flags) ...@@ -384,9 +384,11 @@ int __i2400m_dev_start(struct i2400m *i2400m, enum i2400m_bri flags)
dev_err(dev, "cannot create workqueue\n"); dev_err(dev, "cannot create workqueue\n");
goto error_create_workqueue; goto error_create_workqueue;
} }
if (i2400m->bus_dev_start) {
result = i2400m->bus_dev_start(i2400m); result = i2400m->bus_dev_start(i2400m);
if (result < 0) if (result < 0)
goto error_bus_dev_start; goto error_bus_dev_start;
}
i2400m->ready = 1; i2400m->ready = 1;
wmb(); /* see i2400m->ready's documentation */ wmb(); /* see i2400m->ready's documentation */
/* process pending reports from the device */ /* process pending reports from the device */
...@@ -413,6 +415,7 @@ int __i2400m_dev_start(struct i2400m *i2400m, enum i2400m_bri flags) ...@@ -413,6 +415,7 @@ int __i2400m_dev_start(struct i2400m *i2400m, enum i2400m_bri flags)
wmb(); /* see i2400m->ready's documentation */ wmb(); /* see i2400m->ready's documentation */
flush_workqueue(i2400m->work_queue); flush_workqueue(i2400m->work_queue);
error_fw_check: error_fw_check:
if (i2400m->bus_dev_stop)
i2400m->bus_dev_stop(i2400m); i2400m->bus_dev_stop(i2400m);
error_bus_dev_start: error_bus_dev_start:
destroy_workqueue(i2400m->work_queue); destroy_workqueue(i2400m->work_queue);
...@@ -480,6 +483,7 @@ void __i2400m_dev_stop(struct i2400m *i2400m) ...@@ -480,6 +483,7 @@ void __i2400m_dev_stop(struct i2400m *i2400m)
wmb(); /* see i2400m->ready's documentation */ wmb(); /* see i2400m->ready's documentation */
flush_workqueue(i2400m->work_queue); flush_workqueue(i2400m->work_queue);
if (i2400m->bus_dev_stop)
i2400m->bus_dev_stop(i2400m); i2400m->bus_dev_stop(i2400m);
destroy_workqueue(i2400m->work_queue); destroy_workqueue(i2400m->work_queue);
i2400m_rx_release(i2400m); i2400m_rx_release(i2400m);
......
...@@ -245,16 +245,16 @@ struct i2400m_barker_db; ...@@ -245,16 +245,16 @@ struct i2400m_barker_db;
* all the host resources created to handle communication with * all the host resources created to handle communication with
* the device. * the device.
* *
* @bus_dev_start: [fill] Function called by the bus-generic code * @bus_dev_start: [optional fill] Function called by the bus-generic
* [i2400m_dev_start()] to setup the bus-specific communications * code [i2400m_dev_start()] to do things needed to start the
* to the the device. See LIFE CYCLE above. * device. See LIFE CYCLE above.
* *
* NOTE: Doesn't need to upload the firmware, as that is taken * NOTE: Doesn't need to upload the firmware, as that is taken
* care of by the bus-generic code. * care of by the bus-generic code.
* *
* @bus_dev_stop: [fill] Function called by the bus-generic code * @bus_dev_stop: [optional fill] Function called by the bus-generic
* [i2400m_dev_stop()] to shutdown the bus-specific communications * code [i2400m_dev_stop()] to do things needed for stopping the
* to the the device. See LIFE CYCLE above. * device. See LIFE CYCLE above.
* *
* This function does not need to reset the device, just tear down * This function does not need to reset the device, just tear down
* all the host resources created to handle communication with * all the host resources created to handle communication with
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment