From: Doug Ledford <dledford@redhat.com>
To: James Bottomley <James.Bottomley@steeleye.com>
Cc: linux-scsi@vger.kernel.org
Subject: Re: PATCH: scsi device queue depth adjustability patch
Date: Wed, 2 Oct 2002 18:18:37 -0400 [thread overview]
Message-ID: <20021002221837.GB30503@redhat.com> (raw)
In-Reply-To: <200210022141.g92LfCh01941@localhost.localdomain>
On Wed, Oct 02, 2002 at 05:41:12PM -0400, James Bottomley wrote:
> dledford@redhat.com said:
> > This patch makes it possible to adjust the queue depth of a scsi
> > device after it has been in use some time and you have a better idea
> > of what the optimal queue depth should be. For the most part this
> > should work, but my 2.5.40 test machine is blowing chunks on the
> > serverworks IDE support right now so it isn't tested :-(
>
> I note that there's a lot more than dynamic queue depth adjustment in this
> patch (PPA inquiry, slave attach etc.).
The slave attach is required for the queue depth adjustment stuff to work.
The goal is to remove the select_queue_depths() function entirely and make
slave_attach() -> adjust_queue_depth() the replacement. The PPR message
ability flag was just a simple bit that goes along with slave attach.
There's more to be done there, but that's in there as a sample.
> How do HBA's that don't support this now work?
The mid layer calls into the HBA driver's select_queue_depths() function
and the driver sets the queue depth on each device from there.
> You've taken any dependency on
> scsi_host.cmd_per_lun out of the code (thus rendering it useless) so every HBA
> driver now is forced to use an initial queue depth adjustment just to start
> tagged command queueing.
This is true both before and after my patch. If the HBA doesn't implement
the select_queue_depths function then it will never get tagged queueing.
Besides, cmd_per_lun is *not* for tagged queueing, it's the queue depth
the scsi mid layer is suppossed to keep for *non* tagged devices.
> Can't we at least start with cmd_per_lun as the
> default depth?
The current mid layer never has enabled a default depth, all scsi drivers
must enable tagged queueing for each device before it happens. I'm just
changing how that's done from a specific select_queue_depths() call in
point that does one and only one thing to a generic slave_attach() call in
point that sets various post-INQUIRY data drive specific items, queue
depth and acceptable speed negotiation message protocols being the two
examples in my patch.
> I'm not entirely happy with the idea that we control the queue depth by
> adjusting the number of the device's allocated commands.
It's the only safe way to do it. You can't count on being able to
allocate commands because you may not have available mem, and you don't
want extra laying around because that wastes mem, and it allows my next
changes to go in which includes switching to linked lists for commands and
that way we can have a free list for each lun and when there is a command
on the free list, then you know you are under your queue depth count
because if all commands are used, then none are on the free list.
> I know the patch
> goes to great lengths to move these kmallocs out of the critical path, but
> there are certain environments (multi-initiator) where the queue depth can be
> nastily and randomly variable.
Go look at the QUEUE_FULL handler in the aic7xxx_old driver. This is how
most/all reasonably well written drivers handle queue depth adjustments.
Trust me, they don't go around adjusting the depth all the time. Most of
the time there will be one initial adjustment, then maybe one more
adjustment as we lock it down to the max upper limit when one exists, the
rest of the time we just handle the occasional random queue depth
QUEUE_FULL messages as exactly that and only temporarily freeze the queue
to let the drive get some work done.
> If the allocations were more lazy (wait a
> while before freeing a struct Scsi_Cmnd to see if the queue depth goes up
> again for instance) this would address some of these concerns (perhaps just
> moving to a slab allocator for command blocks would do it?)
Nope, this is a non concern because we don't call adjust_queue_depth on
every queue full (or at least we shouldn't, there isn't any documentation
yet to tell people that, but that was the purpose of making the
aic7xxx_old driver implement the new method since it serves as an example
and it does exactly as I'm talking about).
> > Side note: I left the control of queue depth setting solely in the
> > hands of the low level drivers since they are the *only* ones that
> > can get an accurate queue depth reading at the time of any given
> > QUEUE_FULL message (see what the aic7xxx_old driver has to do in the
> > QUEUE_FULL handler to find out how many commands the drive has seen
> > at this exact point in time vs. how many we may have queued up to the
> > card, the difference in numbers can be significant). For that
> > reason, the adjust_queue_depth call was made to defer the action
> > until later so that it was interrupt context safe.
>
> I appreciate that the HBA driver is the most exact counter of the queue depth,
> but would it make a significant difference if the adjustments were done
> globally in the mid-layer?
The mid layer simply does not have access to the info needed to do what
you are talking about. Let me give you an example from the aic7xxx
driver. On this card we have a sequencer that handles the scsi protocol
for us. When we get a command from the mid layer it goes either to the
card's QINFIFO (queue of commands that the sequencer hasn't started yet)
or to the device's waiting queue (queue of commands that we can't send to
the sequencer yet because of some reason). Once it is on the card and the
sequencer starts the process of selecting the target device, the command
is moved to the waiting_q on the card (queue of commands already started
but for which the target device has not yet responded). Once the device
is selected and we get to send the command, then we usually go directly
into status phase and get our QUEUE_FULL. At this point the sequencer
pauses all operations on the scsi bus and interrupts the kernel to handle
the QUEUE_FULL. Prior to this command being selected, there may have been
any number of commands place in the cards QOUTFIFO (our queue of already
completed SCSI commands which the kernel interrupt driver hasn't processed
yet). So when the kernel driver gets the QUEUE_FULL interrupt, it must
first plug this device up. It then must remove any commands it finds in
the QINFIFO and in the waiting_q on the card and requeue them back into
the device's waiting queue. Each command it moves like this decrements
the device's active command count since when we place a command on the
QINFIFO that's when we increment the active count. Then we have to pull
any possible completed commands out of the QOUTFIFO and place them on the
done queue (commands we have queued to go back to the mid layer), also
decrementing the active count each time. Finally, we decrement the active
count for the device one more time to accomodate our QUEUE_FULL command.
Only after we have done *all* of this crap do we have an accurate queue
depth count for the command that returned a QUEUE_FULL. As you can see,
lots of this is very hardware specific. Controller cards that don't have
a sequencer like control engine won't be starting commands off in a lazy
fasion like this and so don't need all this stuff. That's why the only
place where we can get an accurate count of the queue depth is in the low
level driver. So, that code *must* stay there since getting an accurate
count is how we avoid the random flip flops of queue depth that you were
worried about earlier.
Now, what can be moved to the mid layer, and is on my list to do, is a
generic interface for coming up with the proper action after a QUEUE_FULL.
Currently, each driver not only determines the real depth, but then also
does it's own magic to tell if it's a random event or a hard limit. It
would be easy to add something like scsi_notify_queue_full(sdev, count);
where scsi_notify_queue_full() would keep track of the last queue full
depth, etc. Let the low level driver come up with the accurate count,
then they can use this function to determine what to do about it. On any
change to queue depth, the function can return the amount of commands to
add/subtract, then the low level driver can adjust it's own internal
structure counts and also call scsi_adjust_queue_depth() to have the mid
layer do likewise. BTW, I'll change the adjust_queue_depth code to make
it immediately adjust the depth down when possible and do lazy increases
so that hitting a hard limit will free up resources immediately, but that
will go with making the commands linked list based so that it can simply
do a while(sdev->queue_depth > sdev->new_queue_depth &&
list_not_empty(sdev->free_list)) { kfree(get_list_head(sdev->free_list));
sdev->queue_depth--; }
> The great advantage is that we would gain dynamic
> queue depth adjustments without having to add specific code to every driver,
You're never going to get around this and have a reasonably reliable
method :-(
> at the cost of not always being entirely accurate about the depth. Is there a
> good argument that this really, really must be done at the LLD level given the
> cost in terms of LLD modifications? You could still add hooks for those HBAs
> that really want to do it themselves.
Well, all the device drivers that implement queue depth adjustments at all
already do it themselves, so my proposed method is better than what we
currently have since it at least allows them to move the decide
disposition stuff into a library call or they can do it themselves.
--
Doug Ledford <dledford@redhat.com> 919-754-3700 x44233
Red Hat, Inc.
1801 Varsity Dr.
Raleigh, NC 27606
next prev parent reply other threads:[~2002-10-02 22:18 UTC|newest]
Thread overview: 284+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <dledford@redhat.com>
2002-10-02 0:28 ` PATCH: scsi device queue depth adjustability patch Doug Ledford
2002-10-02 1:16 ` Alan Cox
2002-10-02 1:41 ` Doug Ledford
2002-10-02 13:44 ` Alan Cox
2002-10-02 21:41 ` James Bottomley
2002-10-02 22:18 ` Doug Ledford [this message]
2002-10-02 23:19 ` James Bottomley
2002-10-03 12:46 ` James Bottomley
2002-10-03 16:35 ` Doug Ledford
2002-10-04 1:40 ` Jeremy Higdon
2002-10-03 14:25 ` James Bottomley
2002-10-03 16:41 ` Doug Ledford
2002-10-03 17:00 ` James Bottomley
2002-10-16 21:35 ` scsi_scan.c question Doug Ledford
2002-10-16 21:41 ` James Bottomley
2002-10-17 0:18 ` Doug Ledford
2002-10-16 21:57 ` Patrick Mansfield
2002-10-18 15:57 ` Patrick Mansfield
2002-11-18 0:27 ` aic7xxx_biosparam Doug Ledford
2002-11-18 0:36 ` aic7xxx_biosparam J.E.J. Bottomley
2002-11-18 2:46 ` aic7xxx_biosparam Doug Ledford
2002-11-18 3:20 ` aic7xxx_biosparam J.E.J. Bottomley
2002-11-18 3:26 ` aic7xxx_biosparam Doug Ledford
2002-11-18 0:43 ` aic7xxx_biosparam Andries Brouwer
2002-11-18 2:47 ` aic7xxx_biosparam Doug Ledford
2002-11-18 0:57 ` aic7xxx_biosparam Alan Cox
2002-11-18 2:34 ` aic7xxx_biosparam Doug Ledford
2002-12-21 1:22 ` scsi_scan changes Doug Ledford
2002-12-21 1:27 ` James Bottomley
2008-10-31 1:02 ` RFC - device names and mdadm with some reference to udev greg
2008-10-31 9:18 ` Neil Brown
2008-11-02 13:52 ` Luca Berra
2002-11-21 15:16 [PATCH] turn scsi_allocate_device into readable code Christoph Hellwig
2002-11-21 15:36 ` Doug Ledford
2002-11-21 15:39 ` J.E.J. Bottomley
2002-11-21 15:49 ` Doug Ledford
2002-11-21 16:12 ` J.E.J. Bottomley
2002-11-21 17:08 ` [PATCH] current scsi-misc-2.5 include files Patrick Mansfield
-- strict thread matches above, loose matches on Subject: below --
2002-11-16 19:40 [PATCH] removel useless mod use count manipulation Christoph Hellwig
2002-11-17 2:59 ` Doug Ledford
2002-11-17 17:31 ` J.E.J. Bottomley
2002-11-17 18:14 ` Doug Ledford
2002-11-17 12:40 ` Douglas Gilbert
2002-11-17 12:48 ` Christoph Hellwig
2002-11-17 13:38 ` Douglas Gilbert
2002-11-15 20:34 [RFC][PATCH] move dma_mask into struct device J.E.J. Bottomley
2002-11-16 0:19 ` Mike Anderson
2002-11-16 14:48 ` J.E.J. Bottomley
2002-11-16 20:33 ` Patrick Mansfield
2002-11-17 15:07 ` J.E.J. Bottomley
2002-11-06 22:18 [PATCH] add request prep functions to SCSI J.E.J. Bottomley
2002-11-06 23:16 ` Doug Ledford
2002-11-06 23:43 ` J.E.J. Bottomley
2002-11-07 21:45 ` Mike Anderson
2002-11-06 4:24 [PATCH] fix 2.5 scsi queue depth setting Patrick Mansfield
2002-11-06 4:35 ` Patrick Mansfield
2002-11-06 17:15 ` J.E.J. Bottomley
2002-11-06 17:47 ` J.E.J. Bottomley
2002-11-06 18:24 ` Patrick Mansfield
2002-11-06 18:32 ` J.E.J. Bottomley
2002-11-06 18:39 ` Patrick Mansfield
2002-11-06 18:50 ` J.E.J. Bottomley
2002-11-06 19:50 ` Patrick Mansfield
2002-11-06 20:45 ` Doug Ledford
2002-11-06 21:19 ` J.E.J. Bottomley
2002-11-06 20:50 ` Doug Ledford
[not found] <patmans@us.ibm.com>
2002-10-15 16:55 ` [RFC PATCH] consolidate SCSI-2 command lun setting Patrick Mansfield
2002-10-15 20:29 ` James Bottomley
2002-10-15 22:00 ` Patrick Mansfield
2002-10-30 16:58 ` [PATCH] 2.5 current bk fix setting scsi queue depths Patrick Mansfield
2002-10-30 17:17 ` James Bottomley
2002-10-30 18:05 ` Patrick Mansfield
2002-10-31 0:44 ` James Bottomley
2002-10-21 19:34 [PATCH] get rid of ->finish method for highlevel drivers Christoph Hellwig
2002-10-21 23:58 ` James Bottomley
2002-10-22 15:48 ` James Bottomley
2002-10-22 18:43 ` Patrick Mansfield
2002-10-22 23:17 ` Mike Anderson
2002-10-22 23:30 ` Doug Ledford
2002-10-23 14:16 ` James Bottomley
2002-10-23 15:13 ` Christoph Hellwig
2002-10-24 1:36 ` Patrick Mansfield
2002-10-24 23:20 ` Willem Riede
2002-10-24 23:36 ` Christoph Hellwig
2002-10-25 0:02 ` Willem Riede
2002-10-22 7:30 ` Mike Anderson
2002-10-22 11:14 ` Christoph Hellwig
2002-10-15 18:55 [patch 2.5] ips queue depths Jeffery, David
2002-10-15 19:30 ` Dave Hansen
2002-10-15 19:47 ` Doug Ledford
2002-10-15 20:04 ` Patrick Mansfield
2002-10-15 20:52 ` Doug Ledford
2002-10-15 23:30 ` Patrick Mansfield
2002-10-15 23:56 ` Luben Tuikov
2002-10-16 2:32 ` Doug Ledford
2002-10-16 19:04 ` Patrick Mansfield
2002-10-16 20:15 ` Doug Ledford
2002-10-17 0:39 ` Luben Tuikov
2002-10-17 17:01 ` Mike Anderson
2002-10-17 21:13 ` Luben Tuikov
2002-10-15 20:10 ` Mike Anderson
2002-10-15 20:24 ` Doug Ledford
2002-10-15 20:38 ` James Bottomley
2002-10-15 22:10 ` Mike Anderson
2002-10-16 1:04 ` James Bottomley
2002-10-15 20:24 ` Mike Anderson
2002-10-15 22:46 ` Doug Ledford
2002-10-15 20:26 ` Luben Tuikov
2002-10-15 21:27 ` Patrick Mansfield
2002-10-16 0:43 ` Luben Tuikov
2002-10-21 7:28 ` Mike Anderson
2002-10-21 16:16 ` Doug Ledford
2002-10-21 16:29 ` James Bottomley
2002-10-10 15:01 [PATCH] scsi host cleanup 3/3 (driver changes) Stephen Cameron
2002-10-10 16:46 ` Mike Anderson
2002-10-10 16:59 ` James Bottomley
2002-10-10 20:05 ` Mike Anderson
2002-09-30 21:06 [PATCH] first cut at fixing unable to requeue with no outstanding commands James Bottomley
2002-09-30 23:28 ` Mike Anderson
2002-10-01 0:38 ` James Bottomley
2002-10-01 15:01 ` Patrick Mansfield
2002-10-01 15:14 ` James Bottomley
2002-10-01 16:23 ` Mike Anderson
2002-10-01 16:30 ` James Bottomley
2002-10-01 20:18 ` Inhibit auto-attach of scsi disks ? Scott Merritt
2002-10-02 0:46 ` Alan Cox
2002-10-02 1:49 ` Scott Merritt
2002-10-02 1:58 ` Doug Ledford
2002-10-02 2:45 ` Scott Merritt
2002-10-02 13:40 ` Alan Cox
2002-09-24 11:35 SCSI woes (followup) Russell King
2002-09-24 13:46 ` James Bottomley
2002-09-24 13:58 ` Russell King
2002-09-24 14:29 ` James Bottomley
2002-09-24 18:16 ` Luben Tuikov
2002-09-24 18:18 ` Patrick Mansfield
2002-09-24 19:01 ` Russell King
2002-09-24 19:08 ` Mike Anderson
2002-09-24 19:21 ` Russell King
2002-09-24 19:32 ` Patrick Mansfield
2002-09-24 20:00 ` Russell King
2002-09-24 22:23 ` Patrick Mansfield
2002-09-24 23:04 ` Russell King
2002-09-24 22:39 ` Russell King
2002-09-24 23:14 ` James Bottomley
2002-09-24 23:26 ` Mike Anderson
2002-09-24 23:31 ` James Bottomley
2002-09-24 23:56 ` Mike Anderson
2002-09-24 23:33 ` Russell King
2002-09-25 0:47 ` Mike Anderson
2002-09-25 8:45 ` Russell King
2002-09-25 2:18 ` Doug Ledford
2002-09-25 14:41 ` Russell King
2002-09-24 23:33 ` Mike Anderson
2002-09-24 23:45 ` Russell King
2002-09-25 0:08 ` Patrick Mansfield
2002-09-25 8:41 ` Russell King
2002-09-25 17:22 ` Patrick Mansfield
2002-09-25 12:46 ` Russell King
2002-09-24 17:57 ` Luben Tuikov
2002-09-24 18:39 ` Mike Anderson
2002-09-24 18:49 ` Luben Tuikov
2002-09-09 14:57 [RFC] Multi-path IO in 2.5/2.6 ? James Bottomley
2002-09-09 16:56 ` Patrick Mansfield
2002-09-09 17:34 ` James Bottomley
2002-09-09 18:40 ` Mike Anderson
2002-09-10 13:02 ` Lars Marowsky-Bree
2002-09-10 16:03 ` Patrick Mansfield
2002-09-10 16:03 ` Patrick Mansfield
2002-09-10 16:27 ` Mike Anderson
2002-09-10 0:08 ` Patrick Mansfield
2002-09-10 7:55 ` Jeremy Higdon
2002-09-10 13:04 ` Lars Marowsky-Bree
2002-09-10 16:20 ` Patrick Mansfield
2002-09-10 16:20 ` Patrick Mansfield
2002-09-10 13:16 ` Lars Marowsky-Bree
2002-09-10 19:26 ` Patrick Mansfield
2002-09-11 14:20 ` James Bottomley
2002-09-11 19:17 ` Lars Marowsky-Bree
2002-09-11 19:17 ` Lars Marowsky-Bree
2002-09-11 19:37 ` James Bottomley
2002-09-11 19:52 ` Lars Marowsky-Bree
2002-09-11 19:52 ` Lars Marowsky-Bree
2002-09-12 1:15 ` Bernd Eckenfels
2002-09-11 21:38 ` Oliver Xymoron
2002-09-11 20:30 ` Doug Ledford
2002-09-11 21:17 ` Mike Anderson
2002-09-10 17:21 ` Patrick Mochel
2002-09-10 17:21 ` Patrick Mochel
2002-09-10 18:42 ` Patrick Mansfield
2002-09-10 19:00 ` Patrick Mochel
2002-09-10 19:00 ` Patrick Mochel
2002-09-10 19:37 ` Patrick Mansfield
2002-09-11 0:21 ` Neil Brown
2002-09-03 14:35 aic7xxx sets CDR offline, how to reset? James Bottomley
2002-09-03 18:23 ` Doug Ledford
2002-09-03 19:09 ` James Bottomley
2002-09-03 20:59 ` Alan Cox
2002-09-03 20:59 ` Alan Cox
2002-09-03 21:32 ` James Bottomley
2002-09-03 21:54 ` Alan Cox
2002-09-03 22:50 ` Doug Ledford
2002-09-03 23:28 ` Alan Cox
2002-09-04 7:40 ` Jeremy Higdon
2002-09-04 16:24 ` James Bottomley
2002-09-04 17:13 ` Mike Anderson
2002-09-05 9:50 ` Jeremy Higdon
2002-09-04 16:13 ` James Bottomley
2002-09-04 16:50 ` Justin T. Gibbs
2002-09-05 9:39 ` Jeremy Higdon
2002-09-05 13:35 ` Justin T. Gibbs
2002-09-05 23:56 ` Jeremy Higdon
2002-09-06 0:13 ` Justin T. Gibbs
2002-09-06 0:32 ` Jeremy Higdon
2002-09-03 21:13 ` Doug Ledford
2002-09-03 21:48 ` James Bottomley
2002-09-03 22:42 ` Doug Ledford
2002-09-03 22:52 ` Doug Ledford
2002-09-03 23:29 ` Alan Cox
2002-09-04 21:16 ` Luben Tuikov
2002-09-04 10:37 ` Andries Brouwer
2002-09-04 10:48 ` Doug Ledford
2002-09-04 11:23 ` Alan Cox
2002-09-04 16:25 ` Rogier Wolff
2002-09-04 19:34 ` Thunder from the hill
2002-09-04 19:34 ` Thunder from the hill
2002-09-03 21:24 ` Patrick Mansfield
2002-09-03 22:02 ` James Bottomley
2002-09-03 23:26 ` Alan Cox
2002-08-26 16:29 [RFC]: 64 bit LUN/Tags, dummy device in host_queue, host_lock <-> LLDD reentrancy Aron Zeh
2002-08-26 16:48 ` James Bottomley
2002-08-26 17:27 ` Mike Anderson
2002-08-26 19:00 ` James Bottomley
2002-08-26 20:57 ` Mike Anderson
2002-08-26 21:10 ` James Bottomley
2002-08-26 22:38 ` Mike Anderson
2002-08-26 22:56 ` Patrick Mansfield
2002-08-26 23:10 ` Doug Ledford
2002-08-28 14:38 ` James Bottomley
2002-08-26 21:15 ` Mike Anderson
2002-08-12 23:38 [PATCH] 2.5.31 scsi_error.c cleanup Mike Anderson
2002-08-22 14:05 ` James Bottomley
2002-08-22 16:34 ` Mike Anderson
2002-08-22 17:11 ` James Bottomley
2002-08-22 20:10 ` Mike Anderson
2002-08-05 23:53 When must the io_request_lock be held? Jamie Wellnitz
2002-08-06 17:58 ` Mukul Kotwani
2002-08-07 14:48 ` Doug Ledford
2002-08-07 15:26 ` James Bottomley
2002-08-07 16:18 ` Doug Ledford
2002-08-07 16:48 ` James Bottomley
2002-08-07 18:06 ` Mike Anderson
2002-08-07 23:17 ` James Bottomley
2002-08-08 19:28 ` Luben Tuikov
2002-08-07 16:55 ` Patrick Mansfield
2002-06-11 2:46 Proposed changes to generic blk tag for use in SCSI (1/3) James Bottomley
2002-06-11 5:50 ` Jens Axboe
2002-06-11 14:29 ` James Bottomley
2002-06-11 14:45 ` Jens Axboe
2002-06-11 16:39 ` James Bottomley
2002-06-13 21:01 ` Doug Ledford
2002-06-13 21:26 ` James Bottomley
2002-06-13 21:26 ` James Bottomley
2002-06-13 21:50 ` Doug Ledford
2002-06-13 22:09 ` James Bottomley
2002-04-08 15:18 [RFC] Persistent naming of scsi devices sullivan
2002-04-08 15:04 ` Christoph Hellwig
2002-04-08 15:59 ` Matthew Jacob
2002-04-08 16:34 ` James Bottomley
2002-04-08 18:27 ` Patrick Mansfield
2002-04-08 19:17 ` James Bottomley
2002-04-09 0:22 ` Douglas Gilbert
2002-04-09 14:35 ` sullivan
2002-04-09 14:55 ` sullivan
2002-04-08 17:51 ` Oliver Neukum
2002-04-08 18:01 ` Christoph Hellwig
2002-04-08 18:18 ` Matthew Jacob
2002-04-08 18:28 ` James Bottomley
2002-04-08 18:34 ` Matthew Jacob
2002-04-08 19:07 ` James Bottomley
2002-04-08 20:41 ` Matthew Jacob
2002-04-08 18:45 ` Tigran Aivazian
2002-04-08 20:18 ` Eddie Williams
2002-04-09 0:48 ` Kurt Garloff
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20021002221837.GB30503@redhat.com \
--to=dledford@redhat.com \
--cc=James.Bottomley@steeleye.com \
--cc=linux-scsi@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.