On 11/30/18 3:22 PM, Mike Snitzer wrote:
> diff --git a/block/genhd.c b/block/genhd.c
> index cdf174d7d329..d4c9dd65def6 100644
> --- a/block/genhd.c
> +++ b/block/genhd.c
> @@ -45,53 +45,76 @@ static void disk_add_events(struct gendisk *disk);
> static void disk_del_events(struct gendisk *disk);
> static void disk_release_events(struct gendisk *disk);
>
> -void part_inc_in_flight(struct request_queue *q, struct hd_struct *part, int
> rw)
> +void part_inc_in_flight(struct request_queue *q, int cpu, struct hd_struct
> *part, int rw)
> {
> if (queue_is_mq(q))
> return;
>
> - atomic_inc(&part->in_flight[rw]);
> + local_inc(&per_cpu_ptr(part->dkstats, cpu)->in_flight[rw]);
I mentioned this in a previous email, but why isn't this just using
this_cpu_inc? There's also no need to pass in the cpu, if we're not
running with preempt disabled already we have a problem.
--
Jens Axboe
--
dm-devel mailing list
[email protected]
https://www.redhat.com/mailman/listinfo/dm-devel