struct xhci_segment *first, struct xhci_segment *last,
                unsigned int num_segs)
 {
-       struct xhci_segment *next;
+       struct xhci_segment *next, *seg;
        bool chain_links;
 
        if (!ring || !first || !last)
                        |= cpu_to_le32(LINK_TOGGLE);
                ring->last_seg = last;
        }
+
+       for (seg = last; seg != ring->last_seg; seg = seg->next)
+               seg->next->num = seg->num + 1;
 }
 
 /*
 /* Allocate segments and link them for a ring */
 static int xhci_alloc_segments_for_ring(struct xhci_hcd *xhci,
                struct xhci_segment **first, struct xhci_segment **last,
-               unsigned int num_segs, unsigned int cycle_state,
-               enum xhci_ring_type type, unsigned int max_packet, gfp_t flags)
+               unsigned int num_segs, unsigned int num,
+               unsigned int cycle_state, enum xhci_ring_type type,
+               unsigned int max_packet, gfp_t flags)
 {
        struct xhci_segment *prev;
-       unsigned int num = 0;
        bool chain_links;
 
        /* Set chain bit for 0.95 hosts, and for isoc rings on AMD 0.96 host */
                return ring;
 
        ret = xhci_alloc_segments_for_ring(xhci, &ring->first_seg,
-                       &ring->last_seg, num_segs, cycle_state, type,
+                       &ring->last_seg, num_segs, 0, cycle_state, type,
                        max_packet, flags);
        if (ret)
                goto fail;
        int                     ret;
 
        ret = xhci_alloc_segments_for_ring(xhci, &first, &last,
-                       num_new_segs, ring->cycle_state, ring->type,
+                       num_new_segs, ring->enq_seg->num + 1,
+                       ring->cycle_state, ring->type,
                        ring->bounce_buf_len, flags);
        if (ret)
                return -ENOMEM;