Re: linux-next: manual merge of the md tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wednesday October 15, sfr@xxxxxxxxxxxxxxxx wrote:
> Hi Neil,
> 
> Today's linux-next merge of the md tree got a conflict in
> drivers/md/linear.c between commits
> c9959059161ddd7bf4670cf47367033d6b2f79c4 ("block: fix diskstats access")
> and 6feef531f55cf4a20fd9eb39f5352e5745203603 ("block: mark bio_split_pool
> static") from Linus' tree and commit
> 2bc5b53551d8246e18562fa8e0cf5fe64b5f8184 ("md: linear: Represent
> dev_info->size and dev_info->offset in sectors") from the md tree.
> 
> Just overlapping changes.  I fixed it up (see below).

Thanks.
I pushed out a new for-next just a couple of hours before I got this
email which resolves that, so the conflict should disappear in your
next merge.

NeilBrown


> -- 
> Cheers,
> Stephen Rothwell                    sfr@xxxxxxxxxxxxxxxx
> http://www.canb.auug.org.au/~sfr/
> 
> diff --cc drivers/md/linear.c
> index b9cbee68,9b0c5b0..0000000
> --- a/drivers/md/linear.c
> +++ b/drivers/md/linear.c
> @@@ -317,33 -307,29 +307,33 @@@ static int linear_make_request (struct 
>   	const int rw = bio_data_dir(bio);
>   	mddev_t *mddev = q->queuedata;
>   	dev_info_t *tmp_dev;
> - 	sector_t block;
>  +	int cpu;
>   
>   	if (unlikely(bio_barrier(bio))) {
>   		bio_endio(bio, -EOPNOTSUPP);
>   		return 0;
>   	}
>   
>  -	disk_stat_inc(mddev->gendisk, ios[rw]);
>  -	disk_stat_add(mddev->gendisk, sectors[rw], bio_sectors(bio));
>  +	cpu = part_stat_lock();
>  +	part_stat_inc(cpu, &mddev->gendisk->part0, ios[rw]);
>  +	part_stat_add(cpu, &mddev->gendisk->part0, sectors[rw],
>  +		      bio_sectors(bio));
>  +	part_stat_unlock();
>   
>   	tmp_dev = which_dev(mddev, bio->bi_sector);
> - 	block = bio->bi_sector >> 1;
>       
> - 	if (unlikely(block >= (tmp_dev->size + tmp_dev->offset)
> - 		     || block < tmp_dev->offset)) {
> + 	if (unlikely(bio->bi_sector >= (tmp_dev->num_sectors +
> + 					tmp_dev->start_sector)
> + 		     || (bio->bi_sector <
> + 			 tmp_dev->start_sector))) {
>   		char b[BDEVNAME_SIZE];
>   
> - 		printk("linear_make_request: Block %llu out of bounds on "
> - 			"dev %s size %llu offset %llu\n",
> - 			(unsigned long long)block,
> + 		printk("linear_make_request: Sector %llu out of bounds on "
> + 			"dev %s: %llu sectors, offset %llu\n",
> + 			(unsigned long long)bio->bi_sector,
>   			bdevname(tmp_dev->rdev->bdev, b),
> - 			(unsigned long long)tmp_dev->size,
> - 		        (unsigned long long)tmp_dev->offset);
> + 			(unsigned long long)tmp_dev->num_sectors,
> + 			(unsigned long long)tmp_dev->start_sector);
>   		bio_io_error(bio);
>   		return 0;
>   	}
> @@@ -353,8 -339,9 +343,9 @@@
>   		 * split it.
>   		 */
>   		struct bio_pair *bp;
>  -		bp = bio_split(bio, bio_split_pool,
>  +		bp = bio_split(bio,
> - 			       ((tmp_dev->offset + tmp_dev->size)<<1) - bio->bi_sector);
> + 			       tmp_dev->start_sector + tmp_dev->num_sectors
> + 			       - bio->bi_sector);
>   		if (linear_make_request(q, &bp->bio1))
>   			generic_make_request(&bp->bio1);
>   		if (linear_make_request(q, &bp->bio2))
> --
> To unsubscribe from this list: send the line "unsubscribe linux-next" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-next" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel]     [Linux USB Development]     [Yosemite News]     [Linux SCSI]

  Powered by Linux