linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Christoph Hellwig <hch@infradead.org>
To: mchristi@redhat.com
Cc: linux-f2fs-devel@lists.sourceforge.net,
	linux-ext4@vger.kernel.org, konrad.wilk@oracle.com,
	drbd-dev@lists.linbit.com, philipp.reisner@linbit.com,
	lars.ellenberg@linbit.com, linux-raid@vger.kernel.org,
	dm-devel@redhat.com, linux-fsdevel@vger.kernel.org,
	linux-bcache@vger.kernel.org, linux-block@vger.kernel.org,
	linux-kernel@vger.kernel.org, linux-scsi@vger.kernel.org,
	linux-mtd@lists.infradead.org, target-devel@vger.kernel.org,
	linux-btrfs@vger.kernel.org, osd-dev@open-osd.org,
	xfs@oss.sgi.com, ocfs2-devel@oss.oracle.com
Subject: Re: [PATCH 01/35] block/fs/drivers: remove rw argument from submit_bio
Date: Sat, 9 Jan 2016 05:34:09 -0800	[thread overview]
Message-ID: <20160109133409.GA26660@infradead.org> (raw)
In-Reply-To: <1452027218-32303-2-git-send-email-mchristi@redhat.com>

On Tue, Jan 05, 2016 at 02:53:04PM -0600, mchristi@redhat.com wrote:
> From: Mike Christie <mchristi@redhat.com>
> 
> This has callers of submit_bio/submit_bio_wait set the bio->bi_rw
> instead of passing it in. This makes that use the same as
> generic_make_request and how we set the other bio fields.
> 
> Signed-off-by: Mike Christie <mchristi@redhat.com>
> ---
>  block/bio.c                         |  7 +++----
>  block/blk-core.c                    | 11 ++++-------
>  block/blk-flush.c                   |  3 ++-
>  block/blk-lib.c                     |  9 ++++++---
>  drivers/block/drbd/drbd_actlog.c    |  2 +-
>  drivers/block/drbd/drbd_bitmap.c    |  4 ++--
>  drivers/block/floppy.c              |  3 ++-
>  drivers/block/xen-blkback/blkback.c |  4 +++-
>  drivers/block/xen-blkfront.c        |  4 ++--
>  drivers/md/bcache/debug.c           |  6 ++++--
>  drivers/md/bcache/journal.c         |  2 +-
>  drivers/md/bcache/super.c           |  4 ++--
>  drivers/md/dm-bufio.c               |  3 ++-
>  drivers/md/dm-io.c                  |  3 ++-
>  drivers/md/dm-log-writes.c          |  9 ++++++---
>  drivers/md/dm-thin.c                |  3 ++-
>  drivers/md/md.c                     | 10 +++++++---
>  drivers/md/raid1.c                  |  3 ++-
>  drivers/md/raid10.c                 |  4 +++-
>  drivers/md/raid5-cache.c            |  7 ++++---
>  drivers/target/target_core_iblock.c | 24 +++++++++++++-----------
>  fs/btrfs/check-integrity.c          | 18 ++++++++++--------
>  fs/btrfs/check-integrity.h          |  4 ++--
>  fs/btrfs/disk-io.c                  |  3 ++-
>  fs/btrfs/extent_io.c                |  7 ++++---
>  fs/btrfs/raid56.c                   | 16 +++++++++++-----
>  fs/btrfs/scrub.c                    | 16 +++++++++++-----
>  fs/btrfs/volumes.c                  | 14 +++++++-------
>  fs/buffer.c                         |  3 ++-
>  fs/direct-io.c                      |  3 ++-
>  fs/ext4/crypto.c                    |  3 ++-
>  fs/ext4/page-io.c                   |  3 ++-
>  fs/ext4/readpage.c                  |  9 +++++----
>  fs/f2fs/data.c                      | 13 ++++++++-----
>  fs/f2fs/segment.c                   |  6 ++++--
>  fs/gfs2/lops.c                      |  3 ++-
>  fs/gfs2/meta_io.c                   |  3 ++-
>  fs/gfs2/ops_fstype.c                |  3 ++-
>  fs/hfsplus/wrapper.c                |  3 ++-
>  fs/jfs/jfs_logmgr.c                 |  6 ++++--
>  fs/jfs/jfs_metapage.c               | 10 ++++++----
>  fs/logfs/dev_bdev.c                 | 15 ++++++++++-----
>  fs/mpage.c                          |  3 ++-
>  fs/nfs/blocklayout/blocklayout.c    | 22 ++++++++++++----------
>  fs/nilfs2/segbuf.c                  |  3 ++-
>  fs/ocfs2/cluster/heartbeat.c        | 12 +++++++-----
>  fs/xfs/xfs_aops.c                   |  3 ++-
>  fs/xfs/xfs_buf.c                    |  4 ++--
>  include/linux/bio.h                 |  2 +-
>  include/linux/fs.h                  |  2 +-
>  kernel/power/swap.c                 |  5 +++--
>  mm/page_io.c                        | 10 ++++++----
>  52 files changed, 211 insertions(+), 141 deletions(-)
> 
> diff --git a/block/bio.c b/block/bio.c
> index dbabd48..921112b 100644
> --- a/block/bio.c
> +++ b/block/bio.c
> @@ -859,21 +859,20 @@ static void submit_bio_wait_endio(struct bio *bio)
>  
>  /**
>   * submit_bio_wait - submit a bio, and wait until it completes
> - * @rw: whether to %READ or %WRITE, or maybe to %READA (read ahead)
>   * @bio: The &struct bio which describes the I/O
>   *
>   * Simple wrapper around submit_bio(). Returns 0 on success, or the error from
>   * bio_endio() on failure.
>   */
> -int submit_bio_wait(int rw, struct bio *bio)
> +int submit_bio_wait(struct bio *bio)
>  {
>  	struct submit_bio_ret ret;
>  
> -	rw |= REQ_SYNC;
>  	init_completion(&ret.event);
>  	bio->bi_private = &ret;
>  	bio->bi_end_io = submit_bio_wait_endio;
> -	submit_bio(rw, bio);
> +	bio->bi_rw |= REQ_SYNC;
> +	submit_bio(bio);
>  	wait_for_completion(&ret.event);
>  
>  	return ret.error;
> diff --git a/block/blk-core.c b/block/blk-core.c
> index ab51685..9b887e3 100644
> --- a/block/blk-core.c
> +++ b/block/blk-core.c
> @@ -2092,7 +2092,6 @@ EXPORT_SYMBOL(generic_make_request);
>  
>  /**
>   * submit_bio - submit a bio to the block device layer for I/O
> - * @rw: whether to %READ or %WRITE, or maybe to %READA (read ahead)
>   * @bio: The &struct bio which describes the I/O
>   *
>   * submit_bio() is very similar in purpose to generic_make_request(), and
> @@ -2100,10 +2099,8 @@ EXPORT_SYMBOL(generic_make_request);
>   * interfaces; @bio must be presetup and ready for I/O.
>   *
>   */
> -blk_qc_t submit_bio(int rw, struct bio *bio)
> +blk_qc_t submit_bio(struct bio *bio)
>  {
> -	bio->bi_rw |= rw;
> -
>  	/*
>  	 * If it's a regular read/write or a barrier with data attached,
>  	 * go through the normal accounting stuff before submission.
> @@ -2111,12 +2108,12 @@ blk_qc_t submit_bio(int rw, struct bio *bio)
>  	if (bio_has_data(bio)) {
>  		unsigned int count;
>  
> -		if (unlikely(rw & REQ_WRITE_SAME))
> +		if (unlikely(bio->bi_rw & REQ_WRITE_SAME))
>  			count = bdev_logical_block_size(bio->bi_bdev) >> 9;
>  		else
>  			count = bio_sectors(bio);
>  
> -		if (rw & WRITE) {
> +		if (bio->bi_rw & WRITE) {
>  			count_vm_events(PGPGOUT, count);
>  		} else {
>  			task_io_account_read(bio->bi_iter.bi_size);
> @@ -2127,7 +2124,7 @@ blk_qc_t submit_bio(int rw, struct bio *bio)
>  			char b[BDEVNAME_SIZE];
>  			printk(KERN_DEBUG "%s(%d): %s block %Lu on %s (%u sectors)\n",
>  			current->comm, task_pid_nr(current),
> -				(rw & WRITE) ? "WRITE" : "READ",
> +				(bio->bi_rw & WRITE) ? "WRITE" : "READ",
>  				(unsigned long long)bio->bi_iter.bi_sector,
>  				bdevname(bio->bi_bdev, b),
>  				count);
> diff --git a/block/blk-flush.c b/block/blk-flush.c
> index 9c423e5..e092e13 100644
> --- a/block/blk-flush.c
> +++ b/block/blk-flush.c
> @@ -484,8 +484,9 @@ int blkdev_issue_flush(struct block_device *bdev, gfp_t gfp_mask,
>  
>  	bio = bio_alloc(gfp_mask, 0);
>  	bio->bi_bdev = bdev;
> +	bio->bi_rw |= WRITE_FLUSH;

Shouldn't the |= be a = here and in many other places?

Otherwise this loks fine to me.

  parent reply	other threads:[~2016-01-09 13:34 UTC|newest]

Thread overview: 59+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-01-05 20:53 [PATCH 00/35 v2] separate operations from flags in the bio/request structs mchristi
2016-01-05 20:53 ` [PATCH 01/35] block/fs/drivers: remove rw argument from submit_bio mchristi
2016-01-06 15:59   ` [dm-devel] " Bart Van Assche
2016-01-09 13:34   ` Christoph Hellwig [this message]
2016-01-10  0:43     ` Mike Christie
2016-01-05 20:53 ` [PATCH 02/35] block: add REQ_OP definitions and bi_op/op fields mchristi
2016-01-06 23:17   ` Martin K. Petersen
2016-01-09 13:37   ` Christoph Hellwig
2016-01-10  0:56     ` [dm-devel] " Mike Christie
2016-01-10  1:21       ` Mike Christie
2016-01-10  7:15         ` Christoph Hellwig
2016-01-10  7:14       ` Christoph Hellwig
2016-01-05 20:53 ` [PATCH 03/35] block, fs, mm, drivers: set bi_op to REQ_OP mchristi
2016-01-05 20:53 ` [PATCH 04/35] fs: have submit_bh users pass in op and flags separately mchristi
2016-01-05 20:53 ` [PATCH 05/35] fs: have ll_rw_block " mchristi
2016-01-05 23:20   ` kbuild test robot
2016-01-05 20:53 ` [PATCH 06/35] direct-io: set bi_op to REQ_OP mchristi
2016-01-05 20:53 ` [PATCH 07/35] btrfs: have submit_one_bio users setup bio bi_op mchristi
2016-01-05 20:53 ` [PATCH 08/35] btrfs: set bi_op tp REQ_OP mchristi
2016-01-05 20:53 ` [PATCH 09/35] btrfs: update __btrfs_map_block for bi_op transition mchristi
2016-01-05 20:53 ` [PATCH 10/35] btrfs: don't pass rq_flag_bits if there is a bio mchristi
2016-01-05 20:53 ` [PATCH 11/35] f2fs: set bi_op to REQ_OP mchristi
2016-01-05 20:53 ` [PATCH 12/35] gfs2: " mchristi
2016-01-05 20:53 ` [PATCH 13/35] xfs: " mchristi
2016-01-07  3:11   ` Dave Chinner
2016-01-05 20:53 ` [PATCH 14/35] hfsplus: " mchristi
2016-01-05 20:53 ` [PATCH 15/35] mpage: " mchristi
2016-01-05 20:53 ` [PATCH 16/35] nilfs: " mchristi
2016-01-05 20:53 ` [PATCH 17/35] ocfs2: " mchristi
2016-01-05 20:53 ` [PATCH 18/35] pm: " mchristi
2016-01-05 20:53 ` [PATCH 19/35] dm: " mchristi
2016-01-05 20:53 ` [PATCH 20/35] dm: pass dm stats data dir instead of bi_rw mchristi
2016-01-05 20:53 ` [PATCH 21/35] bcache: set bi_op to REQ_OP mchristi
2016-01-05 20:53 ` [PATCH 22/35] drbd: " mchristi
2016-01-05 20:53 ` [PATCH 23/35] md/raid: " mchristi
2016-01-05 20:53 ` [PATCH 24/35] xen: " mchristi
2016-01-05 20:53 ` [PATCH 25/35] target: " mchristi
2016-01-06 19:06   ` Nicholas A. Bellinger
2016-01-05 20:53 ` [PATCH 26/35] block: set op " mchristi
2016-01-09 13:39   ` Christoph Hellwig
2016-01-05 20:53 ` [PATCH 27/35] drivers: set request " mchristi
2016-01-05 20:53 ` [PATCH 28/35] blktrace: get op from req->op/bio->bi_op mchristi
2016-01-05 20:53 ` [PATCH 29/35] ide cd: do not set REQ_WRITE on requests mchristi
2016-01-05 20:53 ` [PATCH 30/35] block, fs, drivers: do not test bi_rw for REQ_OPs mchristi
2016-01-05 20:53 ` [PATCH 31/35] block, fs: remove old REQ definitions mchristi
2016-01-05 20:53 ` [PATCH 32/35] block: shrink bi_rw and bi_op mchristi
2016-01-05 20:53 ` [PATCH 33/35] block, drivers: add REQ_OP_FLUSH operation mchristi
2016-01-05 20:53 ` [PATCH 34/35] block: add QUEUE_FLAGs for flush and fua mchristi
2016-01-05 23:46   ` kbuild test robot
2016-01-09  8:04   ` Christoph Hellwig
2016-01-05 20:53 ` [PATCH 35/35] block, drivers, fs: rename REQ_FLUSH to REQ_PREFLUSH mchristi
2016-01-05 23:53   ` kbuild test robot
2016-01-07  1:40 ` [PATCH 00/35 v2] separate operations from flags in the bio/request structs Martin K. Petersen
2016-01-07  3:13   ` Dave Chinner
2016-01-08 13:32 ` Christoph Hellwig
2016-01-08 20:50   ` Mike Christie
2016-01-08 23:07     ` Mike Snitzer
  -- strict thread matches above, loose matches on Subject: below --
2016-01-11 20:20 [PATCH 00/35 v3] eparate " mchristi
2016-01-11 20:20 ` [PATCH 01/35] block/fs/drivers: remove rw argument from submit_bio mchristi
2016-02-24 19:47 [PATCH 00/35 v4] separate operations from flags in the bio/request structs mchristi
2016-02-24 19:47 ` [PATCH 01/35] block/fs/drivers: remove rw argument from submit_bio mchristi

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=20160109133409.GA26660@infradead.org \
    --to=hch@infradead.org \
    --cc=dm-devel@redhat.com \
    --cc=drbd-dev@lists.linbit.com \
    --cc=konrad.wilk@oracle.com \
    --cc=lars.ellenberg@linbit.com \
    --cc=linux-bcache@vger.kernel.org \
    --cc=linux-block@vger.kernel.org \
    --cc=linux-btrfs@vger.kernel.org \
    --cc=linux-ext4@vger.kernel.org \
    --cc=linux-f2fs-devel@lists.sourceforge.net \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mtd@lists.infradead.org \
    --cc=linux-raid@vger.kernel.org \
    --cc=linux-scsi@vger.kernel.org \
    --cc=mchristi@redhat.com \
    --cc=ocfs2-devel@oss.oracle.com \
    --cc=osd-dev@open-osd.org \
    --cc=philipp.reisner@linbit.com \
    --cc=target-devel@vger.kernel.org \
    --cc=xfs@oss.sgi.com \
    /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;
as well as URLs for NNTP newsgroup(s).