Distributed Replicated Block Device (DRBD) development
 help / color / mirror / Atom feed
From: Joe Perches <joe@perches.com>
To: Kent Overstreet <koverstreet@google.com>
Cc: axboe@kernel.dk, yehuda@hq.newdream.net, dm-devel@redhat.com,
	neilb@suse.de, linux-kernel@vger.kernel.org, tj@kernel.org,
	linux-bcache@vger.kernel.org, mpatocka@redhat.com,
	vgoyal@redhat.com, bharrosh@panasas.com,
	linux-fsdevel@vger.kernel.org, sage@newdream.net, agk@redhat.com,
	drbd-dev@lists.linbit.com
Subject: Re: [Drbd-dev] [PATCH v3 12/16] Closures
Date: Fri, 25 May 2012 13:57:04 -0700	[thread overview]
Message-ID: <1337979424.30100.19.camel@joe2Laptop> (raw)
In-Reply-To: <1337977539-16977-13-git-send-email-koverstreet@google.com>

On Fri, 2012-05-25 at 13:25 -0700, Kent Overstreet wrote:
> Asynchronous refcounty thingies; they embed a refcount and a work
> struct. Extensive documentation follows in include/linux/closure.h
[]
> diff --git a/include/linux/closure.h b/include/linux/closure.h
[]
> +enum closure_type {
> +	TYPE_closure				= 0,

I still think these should be
	CLOSURE_TYPE_closure
etc.

> +#define __CLOSURE_TYPE(cl, _t)						\
> +	  __builtin_types_compatible_p(typeof(cl), struct _t)		\
> +		? TYPE_ ## _t :						\
	CLOSURE_TYPE_##_t

> +#define __closure_type(cl)						\
> +(									\
> +	__CLOSURE_TYPE(cl, closure)					\
> +	__CLOSURE_TYPE(cl, closure_with_waitlist)			\
> +	__CLOSURE_TYPE(cl, closure_with_timer)				\
> +	__CLOSURE_TYPE(cl, closure_with_waitlist_and_timer)		\
> +	invalid_closure_type()						\
> +)

You should still feel dirty about this...

> +#define continue_at(_cl, _fn, _wq, ...)					\
> +do {									\
> +	BUG_ON(!(_cl) || object_is_on_stack(_cl));			\
> +	closure_set_ip(_cl);						\
> +	set_closure_fn(_cl, _fn, _wq);					\
> +	closure_sub(_cl, CLOSURE_RUNNING + 1);				\
> +	return __VA_ARGS__;						\
> +} while (0)

Does this have to be a macro?

> diff --git a/lib/closure.c b/lib/closure.c
[]
> +#define CL_FIELD(type, field)					\
> +	case TYPE_ ## type:					\
> +	return &container_of(cl, struct type, cl)->field
> +
> +static struct closure_waitlist *closure_waitlist(struct closure *cl)
> +{
> +	switch (cl->type) {
> +		CL_FIELD(closure_with_waitlist, wait);
> +		CL_FIELD(closure_with_waitlist_and_timer, wait);
> +	default:
> +		return NULL;
> +	}
> +}

Here:

static struct closure_waitlist *closure_waitlist(struct closure *cl)
{
	switch (cl->type) {
	case CLOSURE_TYPE_closure_with_waitlist:
		return &container_of(cl, struct closure_with_waitlist, cl)->wait;
	case CLOSURE_TYPE_closure_with_waitlist_and_timer:
		return &container_of(cl, struct closure_with_waitlist_and_timer, cl)->wait;
	}

	return NULL;
}



  reply	other threads:[~2012-05-25 21:14 UTC|newest]

Thread overview: 52+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-05-25 20:25 [Drbd-dev] [PATCH v3 00/16] Block cleanups Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 01/16] block: Generalized bio pool freeing Kent Overstreet
2012-05-28  1:15   ` Tejun Heo
2012-05-28 10:04   ` Boaz Harrosh
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 02/16] dm: Use bioset's front_pad for dm_rq_clone_bio_info Kent Overstreet
2012-05-28  0:57   ` [Drbd-dev] [dm-devel] " Jun'ichi Nomura
2012-05-28 11:41     ` Jun'ichi Nomura
2012-05-28  1:21   ` [Drbd-dev] " Tejun Heo
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 03/16] block: Add bio_reset() Kent Overstreet
2012-05-28  1:23   ` Tejun Heo
2012-05-28 10:02     ` Boaz Harrosh
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 04/16] pktcdvd: Switch to bio_kmalloc() Kent Overstreet
2012-05-28  1:30   ` Tejun Heo
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 05/16] block: Kill bi_destructor Kent Overstreet
2012-05-28  1:36   ` Tejun Heo
2012-05-29  2:10     ` Kent Overstreet
2012-05-29  2:20       ` Tejun Heo
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 06/16] block: Add an explicit bio flag for bios that own their bvec Kent Overstreet
2012-05-28  1:52   ` Tejun Heo
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 07/16] block: Rename bio_split() -> bio_pair_split() Kent Overstreet
2012-05-28 10:15   ` Boaz Harrosh
2012-05-29  2:15     ` Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 08/16] block: Rework bio splitting Kent Overstreet
2012-05-28 16:12   ` Mikulas Patocka
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 09/16] block: Add bio_clone_kmalloc() Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 10/16] block: Add bio_clone_bioset() Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 11/16] block: Only clone bio vecs that are in use Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 12/16] Closures Kent Overstreet
2012-05-25 20:57   ` Joe Perches [this message]
2012-05-25 21:35     ` Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 13/16] Make generic_make_request handle arbitrarily large bios Kent Overstreet
2012-05-25 22:58   ` Alasdair G Kergon
2012-05-25 23:12     ` Alasdair G Kergon
2012-05-26  0:18       ` Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 14/16] Gut bio_add_page() Kent Overstreet
2012-05-25 20:46   ` Mike Snitzer
2012-05-25 21:09     ` Kent Overstreet
2012-05-25 22:39       ` Alasdair G Kergon
2012-05-28 16:07         ` Mikulas Patocka
2012-05-28 20:28           ` Tejun Heo
2012-05-28 21:27             ` Mikulas Patocka
2012-05-28 21:38               ` Tejun Heo
2012-05-28 23:02                 ` Tejun Heo
2012-05-29  2:08                   ` Dave Chinner
2012-05-29  2:15                     ` Tejun Heo
2012-05-29  3:36                       ` Kent Overstreet
2012-05-29  2:07                 ` Dave Chinner
2012-05-29  1:54       ` Dave Chinner
2012-05-29  3:34         ` Kent Overstreet
2012-06-05  0:33           ` Dave Chinner
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 15/16] md: Kill merge_bvec_fn()s Kent Overstreet
2012-05-25 20:25 ` [Drbd-dev] [PATCH v3 16/16] dm: Kill merge_bvec_fn() Kent Overstreet

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1337979424.30100.19.camel@joe2Laptop \
    --to=joe@perches.com \
    --cc=agk@redhat.com \
    --cc=axboe@kernel.dk \
    --cc=bharrosh@panasas.com \
    --cc=dm-devel@redhat.com \
    --cc=drbd-dev@lists.linbit.com \
    --cc=koverstreet@google.com \
    --cc=linux-bcache@vger.kernel.org \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mpatocka@redhat.com \
    --cc=neilb@suse.de \
    --cc=sage@newdream.net \
    --cc=tj@kernel.org \
    --cc=vgoyal@redhat.com \
    --cc=yehuda@hq.newdream.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox