Re[2]: [PATCH 1/2] target: Don't arbitrary limit I/O size to fabric_max_sectors

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Nicholas:

My vote is for 1MB. This is because it offers plenty of headroom for an OS/X-based client (which I think have defaults around 32KB), and is the default for many Linux and Windows distributions. 8MB is great, but it doesn't track back to anything in my industry - the next limit above 1MB would be about 55MB, the next above that would be 4 times that. But the initiator should be able to break the I/O down to smaller I/Os for the target.

Lance

------ Original Message ------
From: "Nicholas A. Bellinger" <nab@xxxxxxxxxxxxxxx>
To: "Nicholas A. Bellinger" <nab@xxxxxxxxxxxxx>
Cc: "target-devel" <target-devel@xxxxxxxxxxxxxxx>; "linux-scsi" <linux-scsi@xxxxxxxxxxxxxxx>; "Christoph Hellwig" <hch@xxxxxx>; "Roland Dreier" <roland@xxxxxxxxxxxxxxx>; "Martin K. Petersen" <martin.petersen@xxxxxxxxxx>
Sent: 1/7/2015 8:11:47 AM
Subject: Re: [PATCH 1/2] target: Don't arbitrary limit I/O size to fabric_max_sectors

Hey Christoph,

Adding CC' for MKP.

On Wed, 2015-01-07 at 00:24 +0000, Nicholas A. Bellinger wrote:
 From: Nicholas Bellinger <nab@xxxxxxxxxxxxxxx>

This patch avoids the arbitrary limiting of I/O size to fabric_max_sectors,
 which currently has a hardcoded max of 8192 (4 MB for 512 byte sector
 devices).

This is problematic because Linux initiators have only recently started to honor block limits MAXIMUM TRANSFER LENGTH, and other non-Linux based initiators (eg: Fibre Channel) can also generate I/Os larger than 4 MB.

 Currently when this happens, the following message will appear on the
 target resulting in I/Os being returned with non recoverable status:

SCSI OP 28h with too big sectors 16384 exceeds fabric_max_sectors: 8192

Instead, use the existing hw_max_sectors value to determine the maximum
 sized I/O the backend is capable of supporting. Also, change IBLOCK
 backend driver to set hw_max_sectors based on queue_max_hw_sectors(),
 instead of UINT_MAX.

 Reported-by: Lance Gropper <lance.gropper@xxxxxxxxxxxxx>
 Reported-by: Stefan Priebe <s.priebe@xxxxxxxxxxxx>
 Cc: Christoph Hellwig <hch@xxxxxx>
 Cc: Roland Dreier <roland@xxxxxxxxxxxxxxx>
 Signed-off-by: Nicholas Bellinger <nab@xxxxxxxxxxxxxxx>
 ---
  drivers/target/target_core_device.c | 8 ++++----
  drivers/target/target_core_iblock.c | 2 +-
  drivers/target/target_core_sbc.c | 7 -------
  drivers/target/target_core_spc.c | 5 +----
  4 files changed, 6 insertions(+), 16 deletions(-)


<SNIP>

diff --git a/drivers/target/target_core_iblock.c b/drivers/target/target_core_iblock.c
 index 3efff94..5795cd8 100644
 --- a/drivers/target/target_core_iblock.c
 +++ b/drivers/target/target_core_iblock.c
@@ -124,7 +124,7 @@ static int iblock_configure_device(struct se_device *dev)
   q = bdev_get_queue(bd);

   dev->dev_attrib.hw_block_size = bdev_logical_block_size(bd);
 - dev->dev_attrib.hw_max_sectors = UINT_MAX;
 + dev->dev_attrib.hw_max_sectors = queue_max_hw_sectors(q);
   dev->dev_attrib.hw_queue_depth = q->nr_requests;

   /*

After thinking about this a bit more, I'm starting to have second
thoughts about using queue_max_hw_sectors() to set hw_max_sectors for
IBLOCK.

IIRC, most modern hardware is reporting a large enough value for
queue_max_hw_sectors() to support 8 MB I/Os, but I'm thinking that this
could end up being problematic for older hardware that is reporting much
smaller values.

Is there any reason why the underlying queue_max_hw_sectors() is going
to trigger an -EIO failure in generic_make_request_checks() when a
IBLOCK dispatched bio exceeds the reported size..?

What are your thoughts for a sane default here..?

--nab

--
To unsubscribe from this list: send the line "unsubscribe target-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html

--
To unsubscribe from this list: send the line "unsubscribe target-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux SCSI]     [Kernel Newbies]     [Linux SCSI Target Infrastructure]     [Share Photos]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Device Mapper]

  Powered by Linux