Re: [Lsf-pc] [LSF/MM TOPIC] iSCSI MQ adoption via MCS discussion

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

 



On Thu, 2015-01-08 at 15:22 -0800, James Bottomley wrote:
> On Thu, 2015-01-08 at 14:57 -0800, Nicholas A. Bellinger wrote:
> > On Thu, 2015-01-08 at 14:29 -0800, James Bottomley wrote:
> > > On Thu, 2015-01-08 at 14:16 -0800, Nicholas A. Bellinger wrote:

<SNIP>

> > The point is that a simple session wide counter for command sequence
> > number assignment is significantly less overhead than all of the
> > overhead associated with running a full multipath stack atop multiple
> > sessions.
> 
> I don't see how that's relevant to issue speed, which was the measure we
> were using: The layers above are just a hopper.  As long as they're
> loaded, the MQ lower layer can issue at full speed.  So as long as the
> multipath hopper is efficient enough to keep the queues loaded there's
> no speed degradation.
> 
> The problem with a sequence point inside the MQ issue layer is that it
> can cause a stall that reduces the issue speed. so the counter sequence
> point causes a degraded issue speed over the multipath hopper approach
> above even if the multipath approach has a higher CPU overhead.
> 
> Now, if the system is close to 100% cpu already, *then* the multipath
> overhead will try to take CPU power we don't have and cause a stall, but
> it's only in the flat out CPU case.
> 
> > Not to mention that our iSCSI/iSER initiator is already taking a session
> > wide lock when sending outgoing PDUs, so adding a session wide counter
> > isn't adding any additional synchronization overhead vs. what's already
> > in place.
> 
> I'll leave it up to the iSER people to decide whether they're redoing
> this as part of the MQ work.
> 

Session wide command sequence number synchronization isn't something to
be removed as part of the MQ work.  It's a iSCSI/iSER protocol
requirement.

That is, the expected + maximum sequence numbers are returned as part of
every response PDU, which the initiator uses to determine when the
command sequence number window is open so new non-immediate commands may
be sent to the target.

So, given some manner of session wide synchronization is required
between different contexts for the existing single connection case to
update the command sequence number and check when the window opens, it's
a fallacy to claim MC/S adds some type of new initiator specific
synchronization overhead vs. single connection code.

--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



[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