From mboxrd@z Thu Jan 1 00:00:00 1970 From: Thomas Graf Subject: Re: [PATCH RFC 5/6] net: Generic resolver backend Date: Wed, 14 Sep 2016 11:49:11 +0200 Message-ID: <20160914094911.GE11841@pox.localdomain> References: <1473463197-3076903-1-git-send-email-tom@herbertland.com> <1473463197-3076903-6-git-send-email-tom@herbertland.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: davem@davemloft.net, netdev@vger.kernel.org, kernel-team@fb.com To: Tom Herbert Return-path: Received: from mail-wm0-f50.google.com ([74.125.82.50]:35309 "EHLO mail-wm0-f50.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751621AbcINJtN (ORCPT ); Wed, 14 Sep 2016 05:49:13 -0400 Received: by mail-wm0-f50.google.com with SMTP id i130so38802291wmf.0 for ; Wed, 14 Sep 2016 02:49:13 -0700 (PDT) Content-Disposition: inline In-Reply-To: <1473463197-3076903-6-git-send-email-tom@herbertland.com> Sender: netdev-owner@vger.kernel.org List-ID: On 09/09/16 at 04:19pm, Tom Herbert wrote: > diff --git a/net/core/resolver.c b/net/core/resolver.c > new file mode 100644 > index 0000000..61b36c5 > --- /dev/null > +++ b/net/core/resolver.c > @@ -0,0 +1,267 @@ > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include > +#include This include list could be stripped down a bit. ila, lwt, fib, ... > + > +static struct net_rslv_ent *net_rslv_new_ent(struct net_rslv *nrslv, > + void *key) Comment above that net_rslv_get_lock() must be held? > +{ > + struct net_rslv_ent *nrent; > + int err; > + > + nrent = kzalloc(sizeof(*nrent) + nrslv->obj_size, GFP_KERNEL); GFP_ATOMIC since you typically hold net_rslv_get_lock() spinlock? > + if (!nrent) > + return ERR_PTR(-EAGAIN); > + > + /* Key is always at beginning of object data */ > + memcpy(nrent->object, key, nrslv->params.key_len); > + > + /* Initialize user data */ > + if (nrslv->rslv_init) > + nrslv->rslv_init(nrslv, nrent); > + > + /* Put in hash table */ > + err = rhashtable_lookup_insert_fast(&nrslv->rhash_table, > + &nrent->node, nrslv->params); > + if (err) > + return ERR_PTR(err); > + > + if (nrslv->timeout) { > + /* Schedule timeout for resolver */ > + INIT_DELAYED_WORK(&nrent->timeout_work, net_rslv_delayed_work); Should this be done before inserting into rhashtable? > + schedule_delayed_work(&nrent->timeout_work, nrslv->timeout); > + } > + > + nrent->nrslv = nrslv; Same here. net_rslv_cancel_all_delayed_work() walking the rhashtable could see ->nrslv as NULL.