Thread (104 messages) 104 messages, 9 authors, 2024-06-17

Re: [PATCH 02/26] sd: move zone limits setup out of sd_read_block_characteristics

From: Damien Le Moal <dlemoal@kernel.org>
Date: 2024-06-11 07:21:01
Also in: ceph-devel, dm-devel, linux-bcache, linux-block, linux-m68k, linux-mmc, linux-nvme, linux-raid, linux-s390, linux-scsi, linux-um, nvdimm, virtualization, xen-devel

On 6/11/24 2:52 PM, Christoph Hellwig wrote:
On Tue, Jun 11, 2024 at 02:51:24PM +0900, Damien Le Moal wrote:
quoted
quoted
-	if (lim->zoned)
+	if (sdkp->device->type == TYPE_ZBC)
Nit: use sd_is_zoned() here ?
Yes.
quoted
quoted
-	if (!sd_is_zoned(sdkp))
+	if (!sd_is_zoned(sdkp)) {
+		lim->zoned = false;
Maybe we should clear the other zone related limits here ? If the drive is
reformatted/converted from SMR to CMR (FORMAT WITH PRESET), the other zone
limits may be set already, no ?
blk_validate_zoned_limits already takes care of that.
I do not think it does:

static int blk_validate_zoned_limits(struct queue_limits *lim)
{
        if (!lim->zoned) {
                if (WARN_ON_ONCE(lim->max_open_zones) ||
                    WARN_ON_ONCE(lim->max_active_zones) ||
                    WARN_ON_ONCE(lim->zone_write_granularity) ||
                    WARN_ON_ONCE(lim->max_zone_append_sectors))
                        return -EINVAL;
                return 0;
        }
	...

So setting lim->zoned to false without clearing the other limits potentially
will trigger warnings...

-- 
Damien Le Moal
Western Digital Research
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help