[sheepdog] [PATCH v2 3/3] sheep: remove cache object for discard operation
Liu Yuan
namei.unix at gmail.com
Mon Jul 15 16:52:53 CEST 2013
no, never try to use coroutine please. use something smart but unnecessary
is bad practice
在 2013-7-15 PM10:49,"Hitoshi Mitake" <mitake.hitoshi at gmail.com>写道:
> At Mon, 15 Jul 2013 14:28:48 +0800,
> Liu Yuan wrote:
> >
> > Signed-off-by: Liu Yuan <namei.unix at gmail.com>
> > ---
> > sheep/object_cache.c | 28 ++++++++++++++++++++++++++++
> > sheep/sheep_priv.h | 1 +
> > sheep/store.c | 6 ++++++
> > 3 files changed, 35 insertions(+)
> >
> > diff --git a/sheep/object_cache.c b/sheep/object_cache.c
> > index e3270df..1579a30 100644
> > --- a/sheep/object_cache.c
> > +++ b/sheep/object_cache.c
> > @@ -1317,6 +1317,34 @@ out:
> > return ret;
> > }
> >
> > +int object_cache_remove(uint64_t oid)
> > +{
> > + /* Inc the entry refcount to exclude the reclaimer */
> > + struct object_cache_entry *entry = oid_to_entry(oid);
> > + struct object_cache *oc = entry->oc;
> > + int ret;
> > +
> > + if (!entry)
> > + return SD_RES_NO_OBJ;
> > +
> > + sd_dprintf("%" PRIx64, oid);
> > + while (refcount_read(&entry->refcnt) > 1)
> > + usleep(100000); /* Object might be in push */
>
> I believe this sort of magic number based coding should be
> avoided.
>
> coroutine would be suitable for writing this type of code cleanly. How
> about recover it? I've heard that the previous sheepdog had coroutine
> but it was reverted because of poor compatibility with valgrind.
>
> But I believe coroutine is worth considering to use, because other
> code in sheepdog (e.g. swithc_journal_file()) would be able to enjoy
> it.
>
> Thanks,
> Hitoshi
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.wpkg.org/pipermail/sheepdog/attachments/20130715/65e5526c/attachment-0002.html>
More information about the sheepdog
mailing list