提交 705cd451 编写于 作者: E Emmanuel Grumbach 提交者: Wey-Yi Guy

iwlagn: store the irq number to iwl_bus just like dev

Since the irq number is just an unsigned int, store it inside iwl_bus
instead of calling the get_irq ops every time it is needed.
Signed-off-by: NEmmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: NWey-Yi Guy <wey-yi.w.guy@intel.com>
上级 4b55b07f
...@@ -3496,6 +3496,7 @@ int iwl_probe(void *bus_specific, struct iwl_bus_ops *bus_ops, ...@@ -3496,6 +3496,7 @@ int iwl_probe(void *bus_specific, struct iwl_bus_ops *bus_ops,
priv->bus.priv = priv; priv->bus.priv = priv;
priv->bus.bus_specific = bus_specific; priv->bus.bus_specific = bus_specific;
priv->bus.ops = bus_ops; priv->bus.ops = bus_ops;
priv->bus.irq = priv->bus.ops->get_irq(&priv->bus);
priv->bus.ops->set_drv_data(&priv->bus, priv); priv->bus.ops->set_drv_data(&priv->bus, priv);
priv->bus.dev = priv->bus.ops->get_dev(&priv->bus); priv->bus.dev = priv->bus.ops->get_dev(&priv->bus);
...@@ -3603,11 +3604,10 @@ int iwl_probe(void *bus_specific, struct iwl_bus_ops *bus_ops, ...@@ -3603,11 +3604,10 @@ int iwl_probe(void *bus_specific, struct iwl_bus_ops *bus_ops,
********************/ ********************/
iwl_alloc_isr_ict(priv); iwl_alloc_isr_ict(priv);
err = request_irq(priv->bus.ops->get_irq(&priv->bus), iwl_isr_ict, err = request_irq(priv->bus.irq, iwl_isr_ict, IRQF_SHARED,
IRQF_SHARED, DRV_NAME, priv); DRV_NAME, priv);
if (err) { if (err) {
IWL_ERR(priv, "Error allocating IRQ %d\n", IWL_ERR(priv, "Error allocating IRQ %d\n", priv->bus.irq);
priv->bus.ops->get_irq(&priv->bus));
goto out_uninit_drv; goto out_uninit_drv;
} }
...@@ -3644,7 +3644,7 @@ int iwl_probe(void *bus_specific, struct iwl_bus_ops *bus_ops, ...@@ -3644,7 +3644,7 @@ int iwl_probe(void *bus_specific, struct iwl_bus_ops *bus_ops,
out_destroy_workqueue: out_destroy_workqueue:
destroy_workqueue(priv->workqueue); destroy_workqueue(priv->workqueue);
priv->workqueue = NULL; priv->workqueue = NULL;
free_irq(priv->bus.ops->get_irq(&priv->bus), priv); free_irq(priv->bus.irq, priv);
iwl_free_isr_ict(priv); iwl_free_isr_ict(priv);
out_uninit_drv: out_uninit_drv:
iwl_uninit_drv(priv); iwl_uninit_drv(priv);
...@@ -3716,7 +3716,7 @@ void __devexit iwl_remove(struct iwl_priv * priv) ...@@ -3716,7 +3716,7 @@ void __devexit iwl_remove(struct iwl_priv * priv)
priv->workqueue = NULL; priv->workqueue = NULL;
iwl_free_traffic_mem(priv); iwl_free_traffic_mem(priv);
free_irq(priv->bus.ops->get_irq(&priv->bus), priv); free_irq(priv->bus.irq, priv);
priv->bus.ops->set_drv_data(&priv->bus, NULL); priv->bus.ops->set_drv_data(&priv->bus, NULL);
iwl_uninit_drv(priv); iwl_uninit_drv(priv);
......
...@@ -125,7 +125,7 @@ irqreturn_t iwl_isr_ict(int irq, void *data); ...@@ -125,7 +125,7 @@ irqreturn_t iwl_isr_ict(int irq, void *data);
static inline void iwl_synchronize_irq(struct iwl_priv *priv) static inline void iwl_synchronize_irq(struct iwl_priv *priv)
{ {
/* wait to make sure we flush pending tasklet*/ /* wait to make sure we flush pending tasklet*/
synchronize_irq(priv->bus.ops->get_irq(&priv->bus)); synchronize_irq(priv->bus.irq);
tasklet_kill(&priv->irq_tasklet); tasklet_kill(&priv->irq_tasklet);
} }
......
...@@ -1224,6 +1224,7 @@ struct iwl_bus { ...@@ -1224,6 +1224,7 @@ struct iwl_bus {
struct iwl_priv *priv; /* driver's context */ struct iwl_priv *priv; /* driver's context */
struct device *dev; struct device *dev;
struct iwl_bus_ops *ops; struct iwl_bus_ops *ops;
unsigned int irq;
}; };
struct iwl_priv { struct iwl_priv {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册