1 // SPDX-License-Identifier: GPL-2.0
3 * Functions related to generic helpers functions
5 #include <linux/kernel.h>
6 #include <linux/module.h>
8 #include <linux/blkdev.h>
9 #include <linux/scatterlist.h>
13 static sector_t
bio_discard_limit(struct block_device
*bdev
, sector_t sector
)
15 unsigned int discard_granularity
= bdev_discard_granularity(bdev
);
16 sector_t granularity_aligned_sector
;
18 if (bdev_is_partition(bdev
))
19 sector
+= bdev
->bd_start_sect
;
21 granularity_aligned_sector
=
22 round_up(sector
, discard_granularity
>> SECTOR_SHIFT
);
25 * Make sure subsequent bios start aligned to the discard granularity if
26 * it needs to be split.
28 if (granularity_aligned_sector
!= sector
)
29 return granularity_aligned_sector
- sector
;
32 * Align the bio size to the discard granularity to make splitting the bio
33 * at discard granularity boundaries easier in the driver if needed.
35 return round_down(UINT_MAX
, discard_granularity
) >> SECTOR_SHIFT
;
38 struct bio
*blk_alloc_discard_bio(struct block_device
*bdev
,
39 sector_t
*sector
, sector_t
*nr_sects
, gfp_t gfp_mask
)
41 sector_t bio_sects
= min(*nr_sects
, bio_discard_limit(bdev
, *sector
));
47 bio
= bio_alloc(bdev
, 0, REQ_OP_DISCARD
, gfp_mask
);
50 bio
->bi_iter
.bi_sector
= *sector
;
51 bio
->bi_iter
.bi_size
= bio_sects
<< SECTOR_SHIFT
;
53 *nr_sects
-= bio_sects
;
55 * We can loop for a long time in here if someone does full device
56 * discards (like mkfs). Be nice and allow us to schedule out to avoid
57 * softlocking if preempt is disabled.
63 int __blkdev_issue_discard(struct block_device
*bdev
, sector_t sector
,
64 sector_t nr_sects
, gfp_t gfp_mask
, struct bio
**biop
)
68 while ((bio
= blk_alloc_discard_bio(bdev
, §or
, &nr_sects
,
70 *biop
= bio_chain_and_submit(*biop
, bio
);
73 EXPORT_SYMBOL(__blkdev_issue_discard
);
76 * blkdev_issue_discard - queue a discard
77 * @bdev: blockdev to issue discard for
78 * @sector: start sector
79 * @nr_sects: number of sectors to discard
80 * @gfp_mask: memory allocation flags (for bio_alloc)
83 * Issue a discard request for the sectors in question.
85 int blkdev_issue_discard(struct block_device
*bdev
, sector_t sector
,
86 sector_t nr_sects
, gfp_t gfp_mask
)
88 struct bio
*bio
= NULL
;
92 blk_start_plug(&plug
);
93 ret
= __blkdev_issue_discard(bdev
, sector
, nr_sects
, gfp_mask
, &bio
);
95 ret
= submit_bio_wait(bio
);
96 if (ret
== -EOPNOTSUPP
)
100 blk_finish_plug(&plug
);
104 EXPORT_SYMBOL(blkdev_issue_discard
);
106 static sector_t
bio_write_zeroes_limit(struct block_device
*bdev
)
108 sector_t bs_mask
= (bdev_logical_block_size(bdev
) >> 9) - 1;
110 return min(bdev_write_zeroes_sectors(bdev
),
111 (UINT_MAX
>> SECTOR_SHIFT
) & ~bs_mask
);
115 * There is no reliable way for the SCSI subsystem to determine whether a
116 * device supports a WRITE SAME operation without actually performing a write
117 * to media. As a result, write_zeroes is enabled by default and will be
118 * disabled if a zeroing operation subsequently fails. This means that this
119 * queue limit is likely to change at runtime.
121 static void __blkdev_issue_write_zeroes(struct block_device
*bdev
,
122 sector_t sector
, sector_t nr_sects
, gfp_t gfp_mask
,
123 struct bio
**biop
, unsigned flags
, sector_t limit
)
127 unsigned int len
= min(nr_sects
, limit
);
130 if ((flags
& BLKDEV_ZERO_KILLABLE
) &&
131 fatal_signal_pending(current
))
134 bio
= bio_alloc(bdev
, 0, REQ_OP_WRITE_ZEROES
, gfp_mask
);
135 bio
->bi_iter
.bi_sector
= sector
;
136 if (flags
& BLKDEV_ZERO_NOUNMAP
)
137 bio
->bi_opf
|= REQ_NOUNMAP
;
139 bio
->bi_iter
.bi_size
= len
<< SECTOR_SHIFT
;
140 *biop
= bio_chain_and_submit(*biop
, bio
);
148 static int blkdev_issue_write_zeroes(struct block_device
*bdev
, sector_t sector
,
149 sector_t nr_sects
, gfp_t gfp
, unsigned flags
)
151 sector_t limit
= bio_write_zeroes_limit(bdev
);
152 struct bio
*bio
= NULL
;
153 struct blk_plug plug
;
156 blk_start_plug(&plug
);
157 __blkdev_issue_write_zeroes(bdev
, sector
, nr_sects
, gfp
, &bio
,
160 if ((flags
& BLKDEV_ZERO_KILLABLE
) &&
161 fatal_signal_pending(current
)) {
162 bio_await_chain(bio
);
163 blk_finish_plug(&plug
);
166 ret
= submit_bio_wait(bio
);
169 blk_finish_plug(&plug
);
172 * For some devices there is no non-destructive way to verify whether
173 * WRITE ZEROES is actually supported. These will clear the capability
174 * on an I/O error, in which case we'll turn any error into
175 * "not supported" here.
177 if (ret
&& !bdev_write_zeroes_sectors(bdev
))
183 * Convert a number of 512B sectors to a number of pages.
184 * The result is limited to a number of pages that can fit into a BIO.
185 * Also make sure that the result is always at least 1 (page) for the cases
186 * where nr_sects is lower than the number of sectors in a page.
188 static unsigned int __blkdev_sectors_to_bio_pages(sector_t nr_sects
)
190 sector_t pages
= DIV_ROUND_UP_SECTOR_T(nr_sects
, PAGE_SIZE
/ 512);
192 return min(pages
, (sector_t
)BIO_MAX_VECS
);
195 static void __blkdev_issue_zero_pages(struct block_device
*bdev
,
196 sector_t sector
, sector_t nr_sects
, gfp_t gfp_mask
,
197 struct bio
**biop
, unsigned int flags
)
200 unsigned int nr_vecs
= __blkdev_sectors_to_bio_pages(nr_sects
);
203 bio
= bio_alloc(bdev
, nr_vecs
, REQ_OP_WRITE
, gfp_mask
);
204 bio
->bi_iter
.bi_sector
= sector
;
206 if ((flags
& BLKDEV_ZERO_KILLABLE
) &&
207 fatal_signal_pending(current
))
211 unsigned int len
, added
;
213 len
= min_t(sector_t
,
214 PAGE_SIZE
, nr_sects
<< SECTOR_SHIFT
);
215 added
= bio_add_page(bio
, ZERO_PAGE(0), len
, 0);
218 nr_sects
-= added
>> SECTOR_SHIFT
;
219 sector
+= added
>> SECTOR_SHIFT
;
222 *biop
= bio_chain_and_submit(*biop
, bio
);
227 static int blkdev_issue_zero_pages(struct block_device
*bdev
, sector_t sector
,
228 sector_t nr_sects
, gfp_t gfp
, unsigned flags
)
230 struct bio
*bio
= NULL
;
231 struct blk_plug plug
;
234 if (flags
& BLKDEV_ZERO_NOFALLBACK
)
237 blk_start_plug(&plug
);
238 __blkdev_issue_zero_pages(bdev
, sector
, nr_sects
, gfp
, &bio
, flags
);
240 if ((flags
& BLKDEV_ZERO_KILLABLE
) &&
241 fatal_signal_pending(current
)) {
242 bio_await_chain(bio
);
243 blk_finish_plug(&plug
);
246 ret
= submit_bio_wait(bio
);
249 blk_finish_plug(&plug
);
255 * __blkdev_issue_zeroout - generate number of zero filed write bios
256 * @bdev: blockdev to issue
257 * @sector: start sector
258 * @nr_sects: number of sectors to write
259 * @gfp_mask: memory allocation flags (for bio_alloc)
260 * @biop: pointer to anchor bio
261 * @flags: controls detailed behavior
264 * Zero-fill a block range, either using hardware offload or by explicitly
265 * writing zeroes to the device.
267 * If a device is using logical block provisioning, the underlying space will
268 * not be released if %flags contains BLKDEV_ZERO_NOUNMAP.
270 * If %flags contains BLKDEV_ZERO_NOFALLBACK, the function will return
271 * -EOPNOTSUPP if no explicit hardware offload for zeroing is provided.
273 int __blkdev_issue_zeroout(struct block_device
*bdev
, sector_t sector
,
274 sector_t nr_sects
, gfp_t gfp_mask
, struct bio
**biop
,
277 sector_t limit
= bio_write_zeroes_limit(bdev
);
279 if (bdev_read_only(bdev
))
283 __blkdev_issue_write_zeroes(bdev
, sector
, nr_sects
,
284 gfp_mask
, biop
, flags
, limit
);
286 if (flags
& BLKDEV_ZERO_NOFALLBACK
)
288 __blkdev_issue_zero_pages(bdev
, sector
, nr_sects
, gfp_mask
,
293 EXPORT_SYMBOL(__blkdev_issue_zeroout
);
296 * blkdev_issue_zeroout - zero-fill a block range
297 * @bdev: blockdev to write
298 * @sector: start sector
299 * @nr_sects: number of sectors to write
300 * @gfp_mask: memory allocation flags (for bio_alloc)
301 * @flags: controls detailed behavior
304 * Zero-fill a block range, either using hardware offload or by explicitly
305 * writing zeroes to the device. See __blkdev_issue_zeroout() for the
306 * valid values for %flags.
308 int blkdev_issue_zeroout(struct block_device
*bdev
, sector_t sector
,
309 sector_t nr_sects
, gfp_t gfp_mask
, unsigned flags
)
313 if ((sector
| nr_sects
) & ((bdev_logical_block_size(bdev
) >> 9) - 1))
315 if (bdev_read_only(bdev
))
318 if (bdev_write_zeroes_sectors(bdev
)) {
319 ret
= blkdev_issue_write_zeroes(bdev
, sector
, nr_sects
,
321 if (ret
!= -EOPNOTSUPP
)
325 return blkdev_issue_zero_pages(bdev
, sector
, nr_sects
, gfp_mask
, flags
);
327 EXPORT_SYMBOL(blkdev_issue_zeroout
);
329 int blkdev_issue_secure_erase(struct block_device
*bdev
, sector_t sector
,
330 sector_t nr_sects
, gfp_t gfp
)
332 sector_t bs_mask
= (bdev_logical_block_size(bdev
) >> 9) - 1;
333 unsigned int max_sectors
= bdev_max_secure_erase_sectors(bdev
);
334 struct bio
*bio
= NULL
;
335 struct blk_plug plug
;
338 /* make sure that "len << SECTOR_SHIFT" doesn't overflow */
339 if (max_sectors
> UINT_MAX
>> SECTOR_SHIFT
)
340 max_sectors
= UINT_MAX
>> SECTOR_SHIFT
;
341 max_sectors
&= ~bs_mask
;
343 if (max_sectors
== 0)
345 if ((sector
| nr_sects
) & bs_mask
)
347 if (bdev_read_only(bdev
))
350 blk_start_plug(&plug
);
352 unsigned int len
= min_t(sector_t
, nr_sects
, max_sectors
);
354 bio
= blk_next_bio(bio
, bdev
, 0, REQ_OP_SECURE_ERASE
, gfp
);
355 bio
->bi_iter
.bi_sector
= sector
;
356 bio
->bi_iter
.bi_size
= len
<< SECTOR_SHIFT
;
363 ret
= submit_bio_wait(bio
);
366 blk_finish_plug(&plug
);
370 EXPORT_SYMBOL(blkdev_issue_secure_erase
);