Commit 2acf5fc8 authored by Alex Elder's avatar Alex Elder Committed by Jakub Kicinski

net: ipa: kill ipa_power_modem_queue_active()

All ipa_power_modem_queue_active() does now is call netif_wake_queue().
Just call netif_wake_queue() in the two places it's needed, and get
rid of ipa_power_modem_queue_active().
Signed-off-by: default avatarAlex Elder <elder@linaro.org>
Link: https://lore.kernel.org/r/20240130192305.250915-7-elder@linaro.orgSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 30cdaea2
...@@ -163,7 +163,7 @@ ipa_start_xmit(struct sk_buff *skb, struct net_device *netdev) ...@@ -163,7 +163,7 @@ ipa_start_xmit(struct sk_buff *skb, struct net_device *netdev)
if (ret < 1) { if (ret < 1) {
/* If a resume won't happen, just drop the packet */ /* If a resume won't happen, just drop the packet */
if (ret < 0 && ret != -EINPROGRESS) { if (ret < 0 && ret != -EINPROGRESS) {
ipa_power_modem_queue_active(ipa); netif_wake_queue(netdev);
pm_runtime_put_noidle(dev); pm_runtime_put_noidle(dev);
goto err_drop_skb; goto err_drop_skb;
} }
...@@ -173,7 +173,7 @@ ipa_start_xmit(struct sk_buff *skb, struct net_device *netdev) ...@@ -173,7 +173,7 @@ ipa_start_xmit(struct sk_buff *skb, struct net_device *netdev)
return NETDEV_TX_BUSY; return NETDEV_TX_BUSY;
} }
ipa_power_modem_queue_active(ipa); netif_wake_queue(netdev);
ret = ipa_endpoint_skb_tx(endpoint, skb); ret = ipa_endpoint_skb_tx(endpoint, skb);
......
...@@ -227,30 +227,19 @@ void ipa_power_suspend_handler(struct ipa *ipa, enum ipa_irq_id irq_id) ...@@ -227,30 +227,19 @@ void ipa_power_suspend_handler(struct ipa *ipa, enum ipa_irq_id irq_id)
ipa_interrupt_suspend_clear_all(ipa->interrupt); ipa_interrupt_suspend_clear_all(ipa->interrupt);
} }
/* The next two functions are used when stopping and starting the modem /* Transmit can run concurrent with power resume. When transmitting,
* network device transmit queue.
*
* Transmit can run concurrent with power resume. When transmitting,
* we disable further transmits until we can determine whether power * we disable further transmits until we can determine whether power
* is ACTIVE. If it is, future transmits are re-enabled and the buffer * is ACTIVE. If it is, future transmits are re-enabled and the buffer
* gets sent (or dropped). If power is not ACTIVE, it will eventually * gets sent (or dropped). If power is not ACTIVE, it will eventually
* be, and transmits stay disabled until after it is. * be, and transmits stay disabled until after it is. This function
* * starts the transmit queue and is used in the power resume path after
* The first function starts the transmit queue and is used in the power * power has become ACTIVE.
* resume path after power has become ACTIVE. The second function also
* enables transmits again, and is used by ipa_start_xmit() once it
* knows power is active.
*/ */
void ipa_power_modem_queue_wake(struct ipa *ipa) void ipa_power_modem_queue_wake(struct ipa *ipa)
{ {
netif_wake_queue(ipa->modem_netdev); netif_wake_queue(ipa->modem_netdev);
} }
void ipa_power_modem_queue_active(struct ipa *ipa)
{
netif_wake_queue(ipa->modem_netdev);
}
static int ipa_power_retention_init(struct ipa_power *power) static int ipa_power_retention_init(struct ipa_power *power)
{ {
struct qmp *qmp = qmp_get(power->dev); struct qmp *qmp = qmp_get(power->dev);
......
...@@ -29,12 +29,6 @@ u32 ipa_core_clock_rate(struct ipa *ipa); ...@@ -29,12 +29,6 @@ u32 ipa_core_clock_rate(struct ipa *ipa);
*/ */
void ipa_power_modem_queue_wake(struct ipa *ipa); void ipa_power_modem_queue_wake(struct ipa *ipa);
/**
* ipa_power_modem_queue_active() - Report modem netdev TX queue active
* @ipa: IPA pointer
*/
void ipa_power_modem_queue_active(struct ipa *ipa);
/** /**
* ipa_power_retention() - Control register retention on power collapse * ipa_power_retention() - Control register retention on power collapse
* @ipa: IPA pointer * @ipa: IPA pointer
......
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