簡體   English   中英

為什么在找到nf_conn之后內核函數:get_next_corpse增加計數器?

[英]Why does the kernel function:get_next_corpse increase counter after a nf_conn is found?

我正在閱讀內核源代碼,並嘗試了解ip conntrack的機制。 如何理解增加被發現要清除的nf_conn結構的計數器的函數get_next_corpse。

static struct nf_conn *
get_next_corpse(struct net *net, int (*iter)(struct nf_conn *i, void *data),
        void *data, unsigned int *bucket)
{
    struct nf_conntrack_tuple_hash *h;
    struct nf_conn *ct;
    struct hlist_nulls_node *n;

    spin_lock_bh(&nf_conntrack_lock);
    for (; *bucket < nf_conntrack_htable_size; (*bucket)++) {
        hlist_nulls_for_each_entry(h, n, &net->ct.hash[*bucket], hnnode) {
            ct = nf_ct_tuplehash_to_ctrack(h);
            if (iter(ct, data))
                goto found;
        }
    }
    hlist_nulls_for_each_entry(h, n, &net->ct.unconfirmed, hnnode) {
        ct = nf_ct_tuplehash_to_ctrack(h);
        if (iter(ct, data))
            set_bit(IPS_DYING_BIT, &ct->status);
    }
    spin_unlock_bh(&nf_conntrack_lock);
    return NULL;
found:
    atomic_inc(&ct->ct_general.use);    //Why ??!
    spin_unlock_bh(&nf_conntrack_lock);
    return ct;
}

由於發現ct已被清除,為什么需要atomic_inc(&ct-> ct_general.use)?

只是為了保持並發性/搶占性的一致性。

類似於OS教科書介紹的P / V操作。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM