Commit 57a1dc89 authored by Emmanuel Grumbach's avatar Emmanuel Grumbach Committed by Wey-Yi Guy

iwlwifi: rename trans_ops->request_irq to trans_ops->start_hw

This handler will become thicker, reflect its real role now.
Signed-off-by: default avatarEmmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: default avatarWey-Yi Guy <wey-yi.w.guy@intel.com>
parent 8467ab4f
...@@ -1829,7 +1829,7 @@ int iwl_probe(struct iwl_bus *bus, const struct iwl_trans_ops *trans_ops, ...@@ -1829,7 +1829,7 @@ int iwl_probe(struct iwl_bus *bus, const struct iwl_trans_ops *trans_ops,
IWL_INFO(priv, "Detected %s, REV=0x%X\n", IWL_INFO(priv, "Detected %s, REV=0x%X\n",
cfg(priv)->name, hw_rev); cfg(priv)->name, hw_rev);
err = iwl_trans_request_irq(trans(priv)); err = iwl_trans_start_hw(trans(priv));
if (err) if (err)
goto out_free_traffic_mem; goto out_free_traffic_mem;
......
...@@ -201,6 +201,7 @@ struct iwl_tx_queue { ...@@ -201,6 +201,7 @@ struct iwl_tx_queue {
* @rxq: all the RX queue data * @rxq: all the RX queue data
* @rx_replenish: work that will be called when buffers need to be allocated * @rx_replenish: work that will be called when buffers need to be allocated
* @trans: pointer to the generic transport area * @trans: pointer to the generic transport area
* @irq_requested: true when the irq has been requested
* @scd_base_addr: scheduler sram base address in SRAM * @scd_base_addr: scheduler sram base address in SRAM
* @scd_bc_tbls: pointer to the byte count table of the scheduler * @scd_bc_tbls: pointer to the byte count table of the scheduler
* @kw: keep warm address * @kw: keep warm address
...@@ -225,6 +226,7 @@ struct iwl_trans_pcie { ...@@ -225,6 +226,7 @@ struct iwl_trans_pcie {
int ict_index; int ict_index;
u32 inta; u32 inta;
bool use_ict; bool use_ict;
bool irq_requested;
struct tasklet_struct irq_tasklet; struct tasklet_struct irq_tasklet;
struct isr_statistics isr_stats; struct isr_statistics isr_stats;
......
...@@ -1235,7 +1235,7 @@ static void iwl_trans_pcie_kick_nic(struct iwl_trans *trans) ...@@ -1235,7 +1235,7 @@ static void iwl_trans_pcie_kick_nic(struct iwl_trans *trans)
iwl_write32(trans, CSR_RESET, 0); iwl_write32(trans, CSR_RESET, 0);
} }
static int iwl_trans_pcie_request_irq(struct iwl_trans *trans) static int iwl_trans_pcie_start_hw(struct iwl_trans *trans)
{ {
struct iwl_trans_pcie *trans_pcie = struct iwl_trans_pcie *trans_pcie =
IWL_TRANS_GET_PCIE_TRANS(trans); IWL_TRANS_GET_PCIE_TRANS(trans);
...@@ -1243,6 +1243,7 @@ static int iwl_trans_pcie_request_irq(struct iwl_trans *trans) ...@@ -1243,6 +1243,7 @@ static int iwl_trans_pcie_request_irq(struct iwl_trans *trans)
trans_pcie->inta_mask = CSR_INI_SET_MASK; trans_pcie->inta_mask = CSR_INI_SET_MASK;
if (!trans_pcie->irq_requested) {
tasklet_init(&trans_pcie->irq_tasklet, (void (*)(unsigned long)) tasklet_init(&trans_pcie->irq_tasklet, (void (*)(unsigned long))
iwl_irq_tasklet, (unsigned long)trans); iwl_irq_tasklet, (unsigned long)trans);
...@@ -1251,12 +1252,17 @@ static int iwl_trans_pcie_request_irq(struct iwl_trans *trans) ...@@ -1251,12 +1252,17 @@ static int iwl_trans_pcie_request_irq(struct iwl_trans *trans)
err = request_irq(trans->irq, iwl_isr_ict, IRQF_SHARED, err = request_irq(trans->irq, iwl_isr_ict, IRQF_SHARED,
DRV_NAME, trans); DRV_NAME, trans);
if (err) { if (err) {
IWL_ERR(trans, "Error allocating IRQ %d\n", trans->irq); IWL_ERR(trans, "Error allocating IRQ %d\n",
trans->irq);
iwl_free_isr_ict(trans); iwl_free_isr_ict(trans);
tasklet_kill(&trans_pcie->irq_tasklet);
return err; return err;
} }
INIT_WORK(&trans_pcie->rx_replenish, iwl_bg_rx_replenish); INIT_WORK(&trans_pcie->rx_replenish, iwl_bg_rx_replenish);
trans_pcie->irq_requested = true;
}
return 0; return 0;
} }
...@@ -1325,8 +1331,10 @@ static void iwl_trans_pcie_free(struct iwl_trans *trans) ...@@ -1325,8 +1331,10 @@ static void iwl_trans_pcie_free(struct iwl_trans *trans)
#ifndef CONFIG_IWLWIFI_IDI #ifndef CONFIG_IWLWIFI_IDI
iwl_trans_pcie_rx_free(trans); iwl_trans_pcie_rx_free(trans);
#endif #endif
if (trans_pcie->irq_requested == true) {
free_irq(trans->irq, trans); free_irq(trans->irq, trans);
iwl_free_isr_ict(trans); iwl_free_isr_ict(trans);
}
pci_disable_msi(trans_pcie->pci_dev); pci_disable_msi(trans_pcie->pci_dev);
pci_iounmap(trans_pcie->pci_dev, trans_pcie->hw_base); pci_iounmap(trans_pcie->pci_dev, trans_pcie->hw_base);
...@@ -1920,7 +1928,7 @@ static int iwl_trans_pcie_dbgfs_register(struct iwl_trans *trans, ...@@ -1920,7 +1928,7 @@ static int iwl_trans_pcie_dbgfs_register(struct iwl_trans *trans,
#endif /*CONFIG_IWLWIFI_DEBUGFS */ #endif /*CONFIG_IWLWIFI_DEBUGFS */
const struct iwl_trans_ops trans_ops_pcie = { const struct iwl_trans_ops trans_ops_pcie = {
.request_irq = iwl_trans_pcie_request_irq, .start_hw = iwl_trans_pcie_start_hw,
.fw_alive = iwl_trans_pcie_fw_alive, .fw_alive = iwl_trans_pcie_fw_alive,
.start_device = iwl_trans_pcie_start_device, .start_device = iwl_trans_pcie_start_device,
.prepare_card_hw = iwl_trans_pcie_prepare_card_hw, .prepare_card_hw = iwl_trans_pcie_prepare_card_hw,
......
...@@ -133,7 +133,7 @@ struct iwl_host_cmd { ...@@ -133,7 +133,7 @@ struct iwl_host_cmd {
/** /**
* struct iwl_trans_ops - transport specific operations * struct iwl_trans_ops - transport specific operations
* @request_irq: requests IRQ - will be called before the FW load in probe flow * @start_hw: starts the HW- from that point on, the HW can send interrupts
* @start_device: allocates and inits all the resources for the transport * @start_device: allocates and inits all the resources for the transport
* layer. * layer.
* @prepare_card_hw: claim the ownership on the HW. Will be called during * @prepare_card_hw: claim the ownership on the HW. Will be called during
...@@ -164,7 +164,7 @@ struct iwl_host_cmd { ...@@ -164,7 +164,7 @@ struct iwl_host_cmd {
*/ */
struct iwl_trans_ops { struct iwl_trans_ops {
int (*request_irq)(struct iwl_trans *iwl_trans); int (*start_hw)(struct iwl_trans *iwl_trans);
int (*start_device)(struct iwl_trans *trans); int (*start_device)(struct iwl_trans *trans);
void (*fw_alive)(struct iwl_trans *trans); void (*fw_alive)(struct iwl_trans *trans);
int (*prepare_card_hw)(struct iwl_trans *trans); int (*prepare_card_hw)(struct iwl_trans *trans);
...@@ -269,9 +269,9 @@ struct iwl_trans { ...@@ -269,9 +269,9 @@ struct iwl_trans {
char trans_specific[0] __attribute__((__aligned__(sizeof(void *)))); char trans_specific[0] __attribute__((__aligned__(sizeof(void *))));
}; };
static inline int iwl_trans_request_irq(struct iwl_trans *trans) static inline int iwl_trans_start_hw(struct iwl_trans *trans)
{ {
return trans->ops->request_irq(trans); return trans->ops->start_hw(trans);
} }
static inline void iwl_trans_fw_alive(struct iwl_trans *trans) static inline void iwl_trans_fw_alive(struct iwl_trans *trans)
......
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