mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	nvme: move NVME_QUIRK_DEALLOCATE_ZEROES out of nvme_config_discard
Move the handling of the NVME_QUIRK_DEALLOCATE_ZEROES quirk out of nvme_config_discard so that it is combined with the normal write_zeroes limit handling. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Max Gurtovoy <mgurtovoy@nvidia.com> Signed-off-by: Keith Busch <kbusch@kernel.org>
This commit is contained in:
		
							parent
							
								
									152694c829
								
							
						
					
					
						commit
						63dfa10043
					
				| @ -1816,9 +1816,6 @@ static void nvme_config_discard(struct nvme_ctrl *ctrl, struct gendisk *disk, | |||||||
| 	else | 	else | ||||||
| 		blk_queue_max_discard_segments(queue, NVME_DSM_MAX_RANGES); | 		blk_queue_max_discard_segments(queue, NVME_DSM_MAX_RANGES); | ||||||
| 	queue->limits.discard_granularity = queue_logical_block_size(queue); | 	queue->limits.discard_granularity = queue_logical_block_size(queue); | ||||||
| 
 |  | ||||||
| 	if (ctrl->quirks & NVME_QUIRK_DEALLOCATE_ZEROES) |  | ||||||
| 		blk_queue_max_write_zeroes_sectors(queue, UINT_MAX); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static bool nvme_ns_ids_equal(struct nvme_ns_ids *a, struct nvme_ns_ids *b) | static bool nvme_ns_ids_equal(struct nvme_ns_ids *a, struct nvme_ns_ids *b) | ||||||
| @ -2029,8 +2026,12 @@ static void nvme_update_disk_info(struct nvme_ctrl *ctrl, struct gendisk *disk, | |||||||
| 	set_capacity_and_notify(disk, capacity); | 	set_capacity_and_notify(disk, capacity); | ||||||
| 
 | 
 | ||||||
| 	nvme_config_discard(ctrl, disk, head); | 	nvme_config_discard(ctrl, disk, head); | ||||||
| 	blk_queue_max_write_zeroes_sectors(disk->queue, | 
 | ||||||
| 					   ctrl->max_zeroes_sectors); | 	if (ctrl->quirks & NVME_QUIRK_DEALLOCATE_ZEROES) | ||||||
|  | 		blk_queue_max_write_zeroes_sectors(disk->queue, UINT_MAX); | ||||||
|  | 	else | ||||||
|  | 		blk_queue_max_write_zeroes_sectors(disk->queue, | ||||||
|  | 				ctrl->max_zeroes_sectors); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static bool nvme_ns_is_readonly(struct nvme_ns *ns, struct nvme_ns_info *info) | static bool nvme_ns_is_readonly(struct nvme_ns *ns, struct nvme_ns_info *info) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Christoph Hellwig
						Christoph Hellwig