*/
 static void send_pending(struct adapter *adap, struct l2t_entry *e)
 {
-       while (e->arpq_head) {
-               struct sk_buff *skb = e->arpq_head;
+       struct sk_buff *skb;
 
-               e->arpq_head = skb->next;
-               skb->next = NULL;
+       while ((skb = __skb_dequeue(&e->arpq)) != NULL)
                t4_ofld_send(adap, skb);
-       }
-       e->arpq_tail = NULL;
 }
 
 /*
  */
 static inline void arpq_enqueue(struct l2t_entry *e, struct sk_buff *skb)
 {
-       skb->next = NULL;
-       if (e->arpq_head)
-               e->arpq_tail->next = skb;
-       else
-               e->arpq_head = skb;
-       e->arpq_tail = skb;
+       __skb_queue_tail(&e->arpq, skb);
 }
 
 int cxgb4_l2t_send(struct net_device *dev, struct sk_buff *skb,
                if (e->state == L2T_STATE_RESOLVING &&
                    !neigh_event_send(e->neigh, NULL)) {
                        spin_lock_bh(&e->lock);
-                       if (e->state == L2T_STATE_RESOLVING && e->arpq_head)
+                       if (e->state == L2T_STATE_RESOLVING &&
+                           !skb_queue_empty(&e->arpq))
                                write_l2e(adap, e, 1);
                        spin_unlock_bh(&e->lock);
                }
 static void _t4_l2e_free(struct l2t_entry *e)
 {
        struct l2t_data *d;
+       struct sk_buff *skb;
 
        if (atomic_read(&e->refcnt) == 0) {  /* hasn't been recycled */
                if (e->neigh) {
                        neigh_release(e->neigh);
                        e->neigh = NULL;
                }
-               while (e->arpq_head) {
-                       struct sk_buff *skb = e->arpq_head;
-
-                       e->arpq_head = skb->next;
+               while ((skb = __skb_dequeue(&e->arpq)) != NULL)
                        kfree_skb(skb);
-               }
-               e->arpq_tail = NULL;
        }
 
        d = container_of(e, struct l2t_data, l2tab[e->idx]);
 static void t4_l2e_free(struct l2t_entry *e)
 {
        struct l2t_data *d;
+       struct sk_buff *skb;
 
        spin_lock_bh(&e->lock);
        if (atomic_read(&e->refcnt) == 0) {  /* hasn't been recycled */
                        neigh_release(e->neigh);
                        e->neigh = NULL;
                }
-               while (e->arpq_head) {
-                       struct sk_buff *skb = e->arpq_head;
-
-                       e->arpq_head = skb->next;
+               while ((skb = __skb_dequeue(&e->arpq)) != NULL)
                        kfree_skb(skb);
-               }
-               e->arpq_tail = NULL;
        }
        spin_unlock_bh(&e->lock);
 
  * on the arpq head.  If a packet specifies a failure handler it is invoked,
  * otherwise the packet is sent to the device.
  */
-static void handle_failed_resolution(struct adapter *adap, struct sk_buff *arpq)
+static void handle_failed_resolution(struct adapter *adap, struct l2t_entry *e)
 {
-       while (arpq) {
-               struct sk_buff *skb = arpq;
+       struct sk_buff *skb;
+
+       while ((skb = __skb_dequeue(&e->arpq)) != NULL) {
                const struct l2t_skb_cb *cb = L2T_SKB_CB(skb);
 
-               arpq = skb->next;
-               skb->next = NULL;
+               spin_unlock(&e->lock);
                if (cb->arp_err_handler)
                        cb->arp_err_handler(cb->handle, skb);
                else
                        t4_ofld_send(adap, skb);
+               spin_lock(&e->lock);
        }
 }
 
 void t4_l2t_update(struct adapter *adap, struct neighbour *neigh)
 {
        struct l2t_entry *e;
-       struct sk_buff *arpq = NULL;
+       struct sk_buff_head *arpq = NULL;
        struct l2t_data *d = adap->l2t;
        int addr_len = neigh->tbl->key_len;
        u32 *addr = (u32 *) neigh->primary_key;
 
        if (e->state == L2T_STATE_RESOLVING) {
                if (neigh->nud_state & NUD_FAILED) {
-                       arpq = e->arpq_head;
-                       e->arpq_head = e->arpq_tail = NULL;
+                       arpq = &e->arpq;
                } else if ((neigh->nud_state & (NUD_CONNECTED | NUD_STALE)) &&
-                          e->arpq_head) {
+                          !skb_queue_empty(&e->arpq)) {
                        write_l2e(adap, e, 1);
                }
        } else {
                        write_l2e(adap, e, 0);
        }
 
-       spin_unlock_bh(&e->lock);
-
        if (arpq)
-               handle_failed_resolution(adap, arpq);
+               handle_failed_resolution(adap, e);
+       spin_unlock_bh(&e->lock);
 }
 
 /* Allocate an L2T entry for use by a switching rule.  Such need to be
                d->l2tab[i].state = L2T_STATE_UNUSED;
                spin_lock_init(&d->l2tab[i].lock);
                atomic_set(&d->l2tab[i].refcnt, 0);
+               skb_queue_head_init(&d->l2tab[i].arpq);
        }
        return d;
 }
        case L2T_STATE_VALID: return 'V';
        case L2T_STATE_STALE: return 'S';
        case L2T_STATE_SYNC_WRITE: return 'W';
-       case L2T_STATE_RESOLVING: return e->arpq_head ? 'A' : 'R';
+       case L2T_STATE_RESOLVING:
+               return skb_queue_empty(&e->arpq) ? 'R' : 'A';
        case L2T_STATE_SWITCHING: return 'X';
        default:
                return 'U';