Lines Matching +full:top +full:- +full:level

1 // SPDX-License-Identifier: GPL-2.0
11 #include <linux/backing-dev-defs.h>
16 #include <linux/dma-mapping.h>
19 #include "blk-wbt.h"
23 q->rq_timeout = timeout; in blk_queue_rq_timeout()
28 * blk_set_default_limits - reset limits to default values
36 lim->max_segments = BLK_MAX_SEGMENTS; in blk_set_default_limits()
37 lim->max_discard_segments = 1; in blk_set_default_limits()
38 lim->max_integrity_segments = 0; in blk_set_default_limits()
39 lim->seg_boundary_mask = BLK_SEG_BOUNDARY_MASK; in blk_set_default_limits()
40 lim->virt_boundary_mask = 0; in blk_set_default_limits()
41 lim->max_segment_size = BLK_MAX_SEGMENT_SIZE; in blk_set_default_limits()
42 lim->max_sectors = lim->max_hw_sectors = BLK_SAFE_MAX_SECTORS; in blk_set_default_limits()
43 lim->max_dev_sectors = 0; in blk_set_default_limits()
44 lim->chunk_sectors = 0; in blk_set_default_limits()
45 lim->max_write_zeroes_sectors = 0; in blk_set_default_limits()
46 lim->max_zone_append_sectors = 0; in blk_set_default_limits()
47 lim->max_discard_sectors = 0; in blk_set_default_limits()
48 lim->max_hw_discard_sectors = 0; in blk_set_default_limits()
49 lim->max_secure_erase_sectors = 0; in blk_set_default_limits()
50 lim->discard_granularity = 0; in blk_set_default_limits()
51 lim->discard_alignment = 0; in blk_set_default_limits()
52 lim->discard_misaligned = 0; in blk_set_default_limits()
53 lim->logical_block_size = lim->physical_block_size = lim->io_min = 512; in blk_set_default_limits()
54 lim->bounce = BLK_BOUNCE_NONE; in blk_set_default_limits()
55 lim->alignment_offset = 0; in blk_set_default_limits()
56 lim->io_opt = 0; in blk_set_default_limits()
57 lim->misaligned = 0; in blk_set_default_limits()
58 lim->zoned = BLK_ZONED_NONE; in blk_set_default_limits()
59 lim->zone_write_granularity = 0; in blk_set_default_limits()
60 lim->dma_alignment = 511; in blk_set_default_limits()
64 * blk_set_stacking_limits - set default limits for stacking devices
76 lim->max_segments = USHRT_MAX; in blk_set_stacking_limits()
77 lim->max_discard_segments = USHRT_MAX; in blk_set_stacking_limits()
78 lim->max_hw_sectors = UINT_MAX; in blk_set_stacking_limits()
79 lim->max_segment_size = UINT_MAX; in blk_set_stacking_limits()
80 lim->max_sectors = UINT_MAX; in blk_set_stacking_limits()
81 lim->max_dev_sectors = UINT_MAX; in blk_set_stacking_limits()
82 lim->max_write_zeroes_sectors = UINT_MAX; in blk_set_stacking_limits()
83 lim->max_zone_append_sectors = UINT_MAX; in blk_set_stacking_limits()
88 * blk_queue_bounce_limit - set bounce buffer limit for queue
99 q->limits.bounce = bounce; in blk_queue_bounce_limit()
104 * blk_queue_max_hw_sectors - set max sectors for a request for this queue
109 * Enables a low level driver to set a hard upper limit,
119 * per-device basis in /sys/block/<device>/queue/max_sectors_kb.
124 struct queue_limits *limits = &q->limits; in blk_queue_max_hw_sectors()
128 max_hw_sectors = 1 << (PAGE_SHIFT - 9); in blk_queue_max_hw_sectors()
134 limits->logical_block_size >> SECTOR_SHIFT); in blk_queue_max_hw_sectors()
135 limits->max_hw_sectors = max_hw_sectors; in blk_queue_max_hw_sectors()
137 max_sectors = min_not_zero(max_hw_sectors, limits->max_dev_sectors); in blk_queue_max_hw_sectors()
140 limits->logical_block_size >> SECTOR_SHIFT); in blk_queue_max_hw_sectors()
141 limits->max_sectors = max_sectors; in blk_queue_max_hw_sectors()
143 if (!q->disk) in blk_queue_max_hw_sectors()
145 q->disk->bdi->io_pages = max_sectors >> (PAGE_SHIFT - 9); in blk_queue_max_hw_sectors()
150 * blk_queue_chunk_sectors - set size of the chunk for this queue
163 q->limits.chunk_sectors = chunk_sectors; in blk_queue_chunk_sectors()
168 * blk_queue_max_discard_sectors - set max sectors for a single discard
175 q->limits.max_hw_discard_sectors = max_discard_sectors; in blk_queue_max_discard_sectors()
176 q->limits.max_discard_sectors = max_discard_sectors; in blk_queue_max_discard_sectors()
181 * blk_queue_max_secure_erase_sectors - set max sectors for a secure erase
188 q->limits.max_secure_erase_sectors = max_sectors; in blk_queue_max_secure_erase_sectors()
193 * blk_queue_max_write_zeroes_sectors - set max sectors for a single
201 q->limits.max_write_zeroes_sectors = max_write_zeroes_sectors; in blk_queue_max_write_zeroes_sectors()
206 * blk_queue_max_zone_append_sectors - set max sectors for a single zone append
218 max_sectors = min(q->limits.max_hw_sectors, max_zone_append_sectors); in blk_queue_max_zone_append_sectors()
219 max_sectors = min(q->limits.chunk_sectors, max_sectors); in blk_queue_max_zone_append_sectors()
228 q->limits.max_zone_append_sectors = max_sectors; in blk_queue_max_zone_append_sectors()
233 * blk_queue_max_segments - set max hw segments for a request for this queue
238 * Enables a low level driver to set an upper limit on the number of
249 q->limits.max_segments = max_segments; in blk_queue_max_segments()
254 * blk_queue_max_discard_segments - set max segments for discard requests
259 * Enables a low level driver to set an upper limit on the number of
265 q->limits.max_discard_segments = max_segments; in blk_queue_max_discard_segments()
270 * blk_queue_max_segment_size - set max segment size for blk_rq_map_sg
275 * Enables a low level driver to set an upper limit on the size of a
287 WARN_ON_ONCE(q->limits.virt_boundary_mask); in blk_queue_max_segment_size()
289 q->limits.max_segment_size = max_size; in blk_queue_max_segment_size()
294 * blk_queue_logical_block_size - set logical block size for the queue
305 struct queue_limits *limits = &q->limits; in blk_queue_logical_block_size()
307 limits->logical_block_size = size; in blk_queue_logical_block_size()
309 if (limits->physical_block_size < size) in blk_queue_logical_block_size()
310 limits->physical_block_size = size; in blk_queue_logical_block_size()
312 if (limits->io_min < limits->physical_block_size) in blk_queue_logical_block_size()
313 limits->io_min = limits->physical_block_size; in blk_queue_logical_block_size()
315 limits->max_hw_sectors = in blk_queue_logical_block_size()
316 round_down(limits->max_hw_sectors, size >> SECTOR_SHIFT); in blk_queue_logical_block_size()
317 limits->max_sectors = in blk_queue_logical_block_size()
318 round_down(limits->max_sectors, size >> SECTOR_SHIFT); in blk_queue_logical_block_size()
323 * blk_queue_physical_block_size - set physical block size for the queue
329 * hardware can operate on without reverting to read-modify-write
334 q->limits.physical_block_size = size; in blk_queue_physical_block_size()
336 if (q->limits.physical_block_size < q->limits.logical_block_size) in blk_queue_physical_block_size()
337 q->limits.physical_block_size = q->limits.logical_block_size; in blk_queue_physical_block_size()
339 if (q->limits.io_min < q->limits.physical_block_size) in blk_queue_physical_block_size()
340 q->limits.io_min = q->limits.physical_block_size; in blk_queue_physical_block_size()
345 * blk_queue_zone_write_granularity - set zone write granularity for the queue
359 q->limits.zone_write_granularity = size; in blk_queue_zone_write_granularity()
361 if (q->limits.zone_write_granularity < q->limits.logical_block_size) in blk_queue_zone_write_granularity()
362 q->limits.zone_write_granularity = q->limits.logical_block_size; in blk_queue_zone_write_granularity()
367 * blk_queue_alignment_offset - set physical block alignment offset
373 * the legacy DOS partition table 63-sector offset. Low-level drivers
379 q->limits.alignment_offset = in blk_queue_alignment_offset()
380 offset & (q->limits.physical_block_size - 1); in blk_queue_alignment_offset()
381 q->limits.misaligned = 0; in blk_queue_alignment_offset()
387 struct request_queue *q = disk->queue; in disk_update_readahead()
390 * For read-ahead of large files to be effective, we need to read ahead in disk_update_readahead()
393 disk->bdi->ra_pages = in disk_update_readahead()
395 disk->bdi->io_pages = queue_max_sectors(q) >> (PAGE_SHIFT - 9); in disk_update_readahead()
400 * blk_limits_io_min - set minimum request size for a device
412 limits->io_min = min; in blk_limits_io_min()
414 if (limits->io_min < limits->logical_block_size) in blk_limits_io_min()
415 limits->io_min = limits->logical_block_size; in blk_limits_io_min()
417 if (limits->io_min < limits->physical_block_size) in blk_limits_io_min()
418 limits->io_min = limits->physical_block_size; in blk_limits_io_min()
423 * blk_queue_io_min - set minimum request size for the queue
438 blk_limits_io_min(&q->limits, min); in blk_queue_io_min()
443 * blk_limits_io_opt - set optimal request size for a device
457 limits->io_opt = opt; in blk_limits_io_opt()
462 * blk_queue_io_opt - set optimal request size for the queue
476 blk_limits_io_opt(&q->limits, opt); in blk_queue_io_opt()
477 if (!q->disk) in blk_queue_io_opt()
479 q->disk->bdi->ra_pages = in blk_queue_io_opt()
487 unsigned int granularity = max(lim->physical_block_size, lim->io_min); in queue_limit_alignment_offset()
491 return (granularity + lim->alignment_offset - alignment) % granularity; in queue_limit_alignment_offset()
499 if (!lim->max_discard_sectors) in queue_limit_discard_alignment()
503 alignment = lim->discard_alignment >> SECTOR_SHIFT; in queue_limit_discard_alignment()
504 granularity = lim->discard_granularity >> SECTOR_SHIFT; in queue_limit_discard_alignment()
512 offset = (granularity + alignment - offset) % granularity; in queue_limit_discard_alignment()
527 * blk_stack_limits - adjust queue_limits for stacked devices
528 * @t: the stacking driver limits (top device)
536 * struct (top) and then iteratively call the stacking function for
540 * Returns 0 if the top and bottom queue_limits are compatible. The
541 * top device's block sizes and alignment offsets may be adjusted to
543 * and alignments exist, -1 is returned and the resulting top
550 unsigned int top, bottom, alignment, ret = 0; in blk_stack_limits() local
552 t->max_sectors = min_not_zero(t->max_sectors, b->max_sectors); in blk_stack_limits()
553 t->max_hw_sectors = min_not_zero(t->max_hw_sectors, b->max_hw_sectors); in blk_stack_limits()
554 t->max_dev_sectors = min_not_zero(t->max_dev_sectors, b->max_dev_sectors); in blk_stack_limits()
555 t->max_write_zeroes_sectors = min(t->max_write_zeroes_sectors, in blk_stack_limits()
556 b->max_write_zeroes_sectors); in blk_stack_limits()
557 t->max_zone_append_sectors = min(t->max_zone_append_sectors, in blk_stack_limits()
558 b->max_zone_append_sectors); in blk_stack_limits()
559 t->bounce = max(t->bounce, b->bounce); in blk_stack_limits()
561 t->seg_boundary_mask = min_not_zero(t->seg_boundary_mask, in blk_stack_limits()
562 b->seg_boundary_mask); in blk_stack_limits()
563 t->virt_boundary_mask = min_not_zero(t->virt_boundary_mask, in blk_stack_limits()
564 b->virt_boundary_mask); in blk_stack_limits()
566 t->max_segments = min_not_zero(t->max_segments, b->max_segments); in blk_stack_limits()
567 t->max_discard_segments = min_not_zero(t->max_discard_segments, in blk_stack_limits()
568 b->max_discard_segments); in blk_stack_limits()
569 t->max_integrity_segments = min_not_zero(t->max_integrity_segments, in blk_stack_limits()
570 b->max_integrity_segments); in blk_stack_limits()
572 t->max_segment_size = min_not_zero(t->max_segment_size, in blk_stack_limits()
573 b->max_segment_size); in blk_stack_limits()
575 t->misaligned |= b->misaligned; in blk_stack_limits()
580 * compatible with the current top alignment. in blk_stack_limits()
582 if (t->alignment_offset != alignment) { in blk_stack_limits()
584 top = max(t->physical_block_size, t->io_min) in blk_stack_limits()
585 + t->alignment_offset; in blk_stack_limits()
586 bottom = max(b->physical_block_size, b->io_min) + alignment; in blk_stack_limits()
588 /* Verify that top and bottom intervals line up */ in blk_stack_limits()
589 if (max(top, bottom) % min(top, bottom)) { in blk_stack_limits()
590 t->misaligned = 1; in blk_stack_limits()
591 ret = -1; in blk_stack_limits()
595 t->logical_block_size = max(t->logical_block_size, in blk_stack_limits()
596 b->logical_block_size); in blk_stack_limits()
598 t->physical_block_size = max(t->physical_block_size, in blk_stack_limits()
599 b->physical_block_size); in blk_stack_limits()
601 t->io_min = max(t->io_min, b->io_min); in blk_stack_limits()
602 t->io_opt = lcm_not_zero(t->io_opt, b->io_opt); in blk_stack_limits()
603 t->dma_alignment = max(t->dma_alignment, b->dma_alignment); in blk_stack_limits()
605 /* Set non-power-of-2 compatible chunk_sectors boundary */ in blk_stack_limits()
606 if (b->chunk_sectors) in blk_stack_limits()
607 t->chunk_sectors = gcd(t->chunk_sectors, b->chunk_sectors); in blk_stack_limits()
610 if (t->physical_block_size & (t->logical_block_size - 1)) { in blk_stack_limits()
611 t->physical_block_size = t->logical_block_size; in blk_stack_limits()
612 t->misaligned = 1; in blk_stack_limits()
613 ret = -1; in blk_stack_limits()
617 if (t->io_min & (t->physical_block_size - 1)) { in blk_stack_limits()
618 t->io_min = t->physical_block_size; in blk_stack_limits()
619 t->misaligned = 1; in blk_stack_limits()
620 ret = -1; in blk_stack_limits()
624 if (t->io_opt & (t->physical_block_size - 1)) { in blk_stack_limits()
625 t->io_opt = 0; in blk_stack_limits()
626 t->misaligned = 1; in blk_stack_limits()
627 ret = -1; in blk_stack_limits()
631 if ((t->chunk_sectors << 9) & (t->physical_block_size - 1)) { in blk_stack_limits()
632 t->chunk_sectors = 0; in blk_stack_limits()
633 t->misaligned = 1; in blk_stack_limits()
634 ret = -1; in blk_stack_limits()
637 t->raid_partial_stripes_expensive = in blk_stack_limits()
638 max(t->raid_partial_stripes_expensive, in blk_stack_limits()
639 b->raid_partial_stripes_expensive); in blk_stack_limits()
642 t->alignment_offset = lcm_not_zero(t->alignment_offset, alignment) in blk_stack_limits()
643 % max(t->physical_block_size, t->io_min); in blk_stack_limits()
646 if (t->alignment_offset & (t->logical_block_size - 1)) { in blk_stack_limits()
647 t->misaligned = 1; in blk_stack_limits()
648 ret = -1; in blk_stack_limits()
651 t->max_sectors = blk_round_down_sectors(t->max_sectors, t->logical_block_size); in blk_stack_limits()
652 t->max_hw_sectors = blk_round_down_sectors(t->max_hw_sectors, t->logical_block_size); in blk_stack_limits()
653 t->max_dev_sectors = blk_round_down_sectors(t->max_dev_sectors, t->logical_block_size); in blk_stack_limits()
656 if (b->discard_granularity) { in blk_stack_limits()
659 if (t->discard_granularity != 0 && in blk_stack_limits()
660 t->discard_alignment != alignment) { in blk_stack_limits()
661 top = t->discard_granularity + t->discard_alignment; in blk_stack_limits()
662 bottom = b->discard_granularity + alignment; in blk_stack_limits()
664 /* Verify that top and bottom intervals line up */ in blk_stack_limits()
665 if ((max(top, bottom) % min(top, bottom)) != 0) in blk_stack_limits()
666 t->discard_misaligned = 1; in blk_stack_limits()
669 t->max_discard_sectors = min_not_zero(t->max_discard_sectors, in blk_stack_limits()
670 b->max_discard_sectors); in blk_stack_limits()
671 t->max_hw_discard_sectors = min_not_zero(t->max_hw_discard_sectors, in blk_stack_limits()
672 b->max_hw_discard_sectors); in blk_stack_limits()
673 t->discard_granularity = max(t->discard_granularity, in blk_stack_limits()
674 b->discard_granularity); in blk_stack_limits()
675 t->discard_alignment = lcm_not_zero(t->discard_alignment, alignment) % in blk_stack_limits()
676 t->discard_granularity; in blk_stack_limits()
678 t->max_secure_erase_sectors = min_not_zero(t->max_secure_erase_sectors, in blk_stack_limits()
679 b->max_secure_erase_sectors); in blk_stack_limits()
680 t->zone_write_granularity = max(t->zone_write_granularity, in blk_stack_limits()
681 b->zone_write_granularity); in blk_stack_limits()
682 t->zoned = max(t->zoned, b->zoned); in blk_stack_limits()
688 * disk_stack_limits - adjust queue limits for stacked drivers
689 * @disk: MD/DM gendisk (top)
694 * Merges the limits for a top level gendisk and a bottom level
700 struct request_queue *t = disk->queue; in disk_stack_limits()
702 if (blk_stack_limits(&t->limits, &bdev_get_queue(bdev)->limits, in disk_stack_limits()
705 disk->disk_name, bdev); in disk_stack_limits()
712 * blk_queue_update_dma_pad - update pad mask
723 if (mask > q->dma_pad_mask) in blk_queue_update_dma_pad()
724 q->dma_pad_mask = mask; in blk_queue_update_dma_pad()
729 * blk_queue_segment_boundary - set boundary rules for segment merging
735 if (mask < PAGE_SIZE - 1) { in blk_queue_segment_boundary()
736 mask = PAGE_SIZE - 1; in blk_queue_segment_boundary()
741 q->limits.seg_boundary_mask = mask; in blk_queue_segment_boundary()
746 * blk_queue_virt_boundary - set boundary rules for bio merging
752 q->limits.virt_boundary_mask = mask; in blk_queue_virt_boundary()
761 q->limits.max_segment_size = UINT_MAX; in blk_queue_virt_boundary()
766 * blk_queue_dma_alignment - set dma length and memory alignment
777 q->limits.dma_alignment = mask; in blk_queue_dma_alignment()
782 * blk_queue_update_dma_alignment - update dma length and memory alignment
799 if (mask > q->limits.dma_alignment) in blk_queue_update_dma_alignment()
800 q->limits.dma_alignment = mask; in blk_queue_update_dma_alignment()
805 * blk_set_queue_depth - tell the block layer about the device queue depth
812 q->queue_depth = depth; in blk_set_queue_depth()
818 * blk_queue_write_cache - configure queue's write cache
836 wbt_set_write_cache(q, test_bit(QUEUE_FLAG_WC, &q->queue_flags)); in blk_queue_write_cache()
841 * blk_queue_required_elevator_features - Set a queue required elevator features
852 q->required_elevator_features = features; in blk_queue_required_elevator_features()
857 * blk_queue_can_use_dma_map_merging - configure queue for merging segments.
885 xa_for_each(&disk->part_tbl, idx, part) { in disk_has_partitions()
897 * disk_set_zoned - configure the zoned model for a disk
911 struct request_queue *q = disk->queue; in disk_set_zoned()
941 q->limits.zoned = model; in disk_set_zoned()
959 if (q->limits.misaligned) in bdev_alignment_offset()
960 return -1; in bdev_alignment_offset()
962 return queue_limit_alignment_offset(&q->limits, in bdev_alignment_offset()
963 bdev->bd_start_sect); in bdev_alignment_offset()
964 return q->limits.alignment_offset; in bdev_alignment_offset()
973 return queue_limit_discard_alignment(&q->limits, in bdev_discard_alignment()
974 bdev->bd_start_sect); in bdev_discard_alignment()
975 return q->limits.discard_alignment; in bdev_discard_alignment()