Skip to content

Commit 213e85d

Browse files
David WoodhouseDavid Woodhouse
authored andcommitted
solos-pci: clean up pclose() function
- Flush pending TX skbs from the queue rather than waiting for them all to complete (suggested by Krzysztof Mazur <[email protected]>). - Clear ATM_VF_ADDR only when the PKT_PCLOSE packet has been submitted. - Don't clear ATM_VF_READY at all — vcc_destroy_socket() does that for us. Signed-off-by: David Woodhouse <[email protected]>
1 parent 5b4d720 commit 213e85d

File tree

1 file changed

+14
-4
lines changed

1 file changed

+14
-4
lines changed

drivers/atm/solos-pci.c

Lines changed: 14 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -868,9 +868,19 @@ static void pclose(struct atm_vcc *vcc)
868868
{
869869
struct solos_card *card = vcc->dev->dev_data;
870870
unsigned char port = SOLOS_CHAN(vcc->dev);
871-
struct sk_buff *skb;
871+
struct sk_buff *skb, *tmpskb;
872872
struct pkt_hdr *header;
873873

874+
/* Remove any yet-to-be-transmitted packets from the pending queue */
875+
spin_lock(&card->tx_queue_lock);
876+
skb_queue_walk_safe(&card->tx_queue[port], skb, tmpskb) {
877+
if (SKB_CB(skb)->vcc == vcc) {
878+
skb_unlink(skb, &card->tx_queue[port]);
879+
solos_pop(vcc, skb);
880+
}
881+
}
882+
spin_unlock(&card->tx_queue_lock);
883+
874884
skb = alloc_skb(sizeof(*header), GFP_ATOMIC);
875885
if (!skb) {
876886
dev_warn(&card->dev->dev, "Failed to allocate sk_buff in pclose()\n");
@@ -886,9 +896,6 @@ static void pclose(struct atm_vcc *vcc)
886896
skb_get(skb);
887897
fpga_queue(card, port, skb, NULL);
888898

889-
clear_bit(ATM_VF_ADDR, &vcc->flags);
890-
clear_bit(ATM_VF_READY, &vcc->flags);
891-
892899
if (!wait_event_timeout(card->param_wq, !skb_shared(skb), 5 * HZ))
893900
dev_warn(&card->dev->dev,
894901
"Timeout waiting for VCC close on port %d\n", port);
@@ -899,6 +906,9 @@ static void pclose(struct atm_vcc *vcc)
899906
tasklet has finished processing any incoming packets (and, more to
900907
the point, using the vcc pointer). */
901908
tasklet_unlock_wait(&card->tlet);
909+
910+
clear_bit(ATM_VF_ADDR, &vcc->flags);
911+
902912
return;
903913
}
904914

0 commit comments

Comments
 (0)