| I notice there is other functionality here also... | | > +/** | > + * tfrc_tx_hist_when - Retrieve send time of past packet | > + * If successful, it garbage-collects older (irrelevant) entries and returns 1. | > + */ | > +int tfrc_tx_hist_when(ktime_t *stamp, struct tfrc_tx_hist_head *head, u64 ackno) | > +{ | > + | > + if (tail) | > + __tfrc_tx_hist_remove_tail(tail, head->cache); | > + | | Can you explain the rationale behind this? | You have cut out half of the code, I therefore need to copy again below: +int tfrc_tx_hist_when(ktime_t *stamp, struct tfrc_tx_hist_head *head, u64 ackno) +{ + struct tfrc_tx_hist *cur, *tail = NULL; + + write_lock_bh(&tfrc_tx_hist_lock); + for (cur = head->first; cur != NULL; cur = cur->next) + if (cur->seqno == ackno) { + *stamp = cur->stamp; + tail = cur->next; + cur->next = NULL; + break; + } + write_unlock_bh(&tfrc_tx_hist_lock); + + if (tail) + __tfrc_tx_hist_remove_tail(tail, head->cache); + + return (cur != NULL); +} The patch first performs a lookup. If the lookup is successful, tail != NULL and all entries older than `cur' (LIFO order) are cut off; at the same time tail is set to the `tail' starting at the now old/obsolete entries. Removing the tail is not done when under lock, since this may take time (you never know how long the list is). So this uses a common trick of first `orphaning' the old tail, and then doing the cleanup outside the lock-protected region, when there is more time to do so. Maybe you have noted that the subsequent patch (6/6) has the following hunk: @@ -492,9 +488,6 @@ static void ccid3_hc_tx_packet_recv(stru /* unschedule no feedback timer */ sk_stop_timer(sk, &hctx->ccid3hctx_no_feedback_timer); - /* remove all packets older than the one acked from history */ - dccp_tx_hist_purge_older(ccid3_tx_hist, - &hctx->ccid3hctx_hist, packet); /* * As we have calculated new ipi, delta, t_nom it is possible * that we now can send a packet, so wake up dccp_wait_for_ccid => The above effectively replaces this in one go. This is better since otherwise the same lock would need to be acquired twice - once for reading, then for writing (to perform the purge). This would introduce a race condition. => You can find this also in the documentation of patch 5/6: + * tfrc_tx_hist_when - Retrieve send time of past packet + + * If successful, it garbage-collects older (irrelevant) entries and returns 1. + */ - To unsubscribe from this list: send the line "unsubscribe dccp" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html