* [PATCH] dm: era: use do_div for 64-bit division
@ 2014-03-11 8:31 Arnd Bergmann
2014-03-11 12:59 ` Mike Snitzer
0 siblings, 1 reply; 2+ messages in thread
From: Arnd Bergmann @ 2014-03-11 8:31 UTC (permalink / raw)
To: Mike Snitzer; +Cc: dm-devel, Alasdair Kergon, Joe Thornber, linux-kernel
Commit 983043be0c1de "dm era: support non power-of-2 blocksize"
introduced the use of sector_div to divide a variable of type
dm_block_t by an integer. This fails on 32-bit machines when
CONFIG_LBDAF is not set, because that assumes that the first
argument is a 32-bit number.
To allow building this driver in all configurations, we either
have to cast the dm_block_t to sector_t or use do_div(), which
always takes a 64-bit argument. This patch uses the second
approach in order to cope with theoretical configurations where
dm_block_t contains a number that does not fit into sector_t.
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Cc: Mike Snitzer <snitzer@redhat.com>
Cc: Joe Thornber <ejt@redhat.com>
Cc: Alasdair Kergon <agk@redhat.com>
Cc: dm-devel@redhat.com
---
This currently only occurs in linux-next. Please apply.
diff --git a/drivers/md/dm-era-target.c b/drivers/md/dm-era-target.c
index d7bd7b3..3383423 100644
--- a/drivers/md/dm-era-target.c
+++ b/drivers/md/dm-era-target.c
@@ -1123,7 +1123,7 @@ static dm_block_t get_block(struct era *era, struct bio *bio)
dm_block_t block_nr = bio->bi_iter.bi_sector;
if (!block_size_is_power_of_two(era))
- (void) sector_div(block_nr, era->sectors_per_block);
+ (void) do_div(block_nr, era->sectors_per_block);
else
block_nr >>= era->sectors_per_block_shift;
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: dm: era: use do_div for 64-bit division
2014-03-11 8:31 [PATCH] dm: era: use do_div for 64-bit division Arnd Bergmann
@ 2014-03-11 12:59 ` Mike Snitzer
0 siblings, 0 replies; 2+ messages in thread
From: Mike Snitzer @ 2014-03-11 12:59 UTC (permalink / raw)
To: Arnd Bergmann; +Cc: dm-devel, Alasdair Kergon, Joe Thornber, linux-kernel
On Tue, Mar 11 2014 at 4:31am -0400,
Arnd Bergmann <arnd@arndb.de> wrote:
> Commit 983043be0c1de "dm era: support non power-of-2 blocksize"
> introduced the use of sector_div to divide a variable of type
> dm_block_t by an integer. This fails on 32-bit machines when
> CONFIG_LBDAF is not set, because that assumes that the first
> argument is a 32-bit number.
>
> To allow building this driver in all configurations, we either
> have to cast the dm_block_t to sector_t or use do_div(), which
> always takes a 64-bit argument. This patch uses the second
> approach in order to cope with theoretical configurations where
> dm_block_t contains a number that does not fit into sector_t.
Thanks for taking the time to look into this.
But the first approach was used on Friday (and is adequate considering
we're starting with the bio's bi_sector). The new commit id is
1c5a63b138638d08f4dc65ed48d3d5d3bad1b08b.
The moral of the story is: don't make a mistake on Thursday because that
last linux-next of the week will plague you for the next 5 days. I was
hoping for relief with Monday's linux-next build but alas... ;)
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2014-03-11 13:00 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-03-11 8:31 [PATCH] dm: era: use do_div for 64-bit division Arnd Bergmann
2014-03-11 12:59 ` Mike Snitzer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox