Dan Williams
8a4aeec8d2
libata/ahci: accommodate tag ordered controllers
...
The AHCI spec allows implementations to issue commands in tag order
rather than FIFO order:
5.3.2.12 P:SelectCmd
HBA sets pSlotLoc = (pSlotLoc + 1) mod (CAP.NCS + 1)
or HBA selects the command to issue that has had the
PxCI bit set to '1' longer than any other command
pending to be issued.
The result is that commands posted sequentially (time-wise) may play out
of sequence when issued by hardware.
This behavior has likely been hidden by drives that arrange for commands
to complete in issue order. However, it appears recent drives (two from
different vendors that we have found so far) inflict out-of-order
completions as a matter of course. So, we need to take care to maintain
ordered submission, otherwise we risk triggering a drive to fall out of
sequential-io automation and back to random-io processing, which incurs
large latency and degrades throughput.
This issue was found in simple benchmarks where QD=2 seq-write
performance was 30-50% *greater* than QD=32 seq-write performance.
Tagging for -stable and making the change globally since it has a low
risk-to-reward ratio. Also, word is that recent versions of an unnamed
OS also does it this way now. So, drives in the field are already
experienced with this tag ordering scheme.
Cc: <stable@vger.kernel.org >
Cc: Dave Jiang <dave.jiang@intel.com >
Cc: Ed Ciechanowski <ed.ciechanowski@intel.com >
Reviewed-by: Matthew Wilcox <matthew.r.wilcox@intel.com >
Signed-off-by: Dan Williams <dan.j.williams@intel.com >
Signed-off-by: Tejun Heo <tj@kernel.org >
2014-04-18 15:56:03 -04:00
..
2014-01-02 10:46:41 +01:00
2014-01-30 17:20:32 -08:00
2012-10-17 12:31:15 +01:00
2014-01-30 16:25:49 -08:00
2014-02-17 12:37:09 -08:00
2014-02-19 12:07:55 -07:00
2013-12-31 20:32:26 +02:00
2013-07-09 10:33:30 -07:00
2014-03-19 14:41:58 +09:00
2014-02-06 10:22:56 +01:00
2013-03-01 13:39:00 -08:00
2014-01-24 17:17:30 -08:00
2014-02-15 10:58:17 +00:00
2013-07-10 11:10:27 -07:00
2013-02-28 18:02:55 -08:00
2014-04-01 15:38:47 -07:00
2014-01-25 11:17:34 -08:00
2014-02-13 20:48:02 -08:00
2014-01-26 11:00:41 -08:00
2014-01-20 11:55:23 -08:00
2013-02-13 06:16:08 -08:00
2014-03-09 12:45:08 +05:30
2014-01-16 14:25:37 +01:00
2014-04-01 16:55:57 -07:00
2013-12-23 18:34:58 -08:00
2013-09-10 13:03:41 -07:00
2014-03-26 16:58:11 +00:00
2014-02-22 18:14:13 +01:00
2014-03-30 00:50:57 +00:00
2014-01-24 22:39:54 +01:00
2014-01-30 10:18:43 -08:00
2014-04-01 17:06:09 -07:00
2012-10-13 10:46:48 +01:00
2012-10-13 10:46:48 +01:00
2010-10-15 21:18:59 +02:00
2014-04-01 15:14:04 -07:00
2012-10-13 10:46:48 +01:00
2013-07-03 16:31:35 -07:00
2012-10-13 10:46:48 +01:00
2014-02-22 17:13:01 -05:00
2013-07-30 11:53:12 -04:00
2013-05-29 12:57:34 -07:00
2012-02-09 09:04:23 -08:00
2011-06-06 22:55:11 -07:00
2012-10-08 13:50:19 +10:30
2012-10-08 13:50:20 +10:30
2013-09-24 10:35:17 +01:00
2013-12-02 11:24:18 +00:00
2013-07-03 16:07:42 -07:00
2013-03-12 13:59:14 -07:00
2013-01-03 15:57:16 -08:00
2013-10-27 08:40:39 -04:00
2012-12-02 00:05:12 +00:00
2014-02-12 17:21:22 +00:00
2012-10-09 16:22:46 +09:00
2012-03-16 10:38:24 -04:00
2014-02-28 19:44:55 -08:00
2009-04-01 08:59:23 -07:00
2013-12-24 09:35:17 -08:00
2010-12-06 15:58:43 -05:00
2013-11-08 08:59:44 -07:00
2013-10-16 01:16:04 +02:00
2013-04-10 23:41:16 +02:00
2012-09-10 11:13:16 -07:00
2011-03-11 14:25:50 +00:00
2014-02-11 08:40:45 -07:00
2012-03-04 17:54:34 -05:00
2011-08-03 11:30:42 -04:00
2014-03-30 17:02:06 -07:00
2008-06-06 11:29:10 -07:00
2014-03-13 09:38:42 -06:00
2014-04-01 19:19:15 -07:00
2014-02-24 14:46:32 -08:00
2013-11-08 09:04:30 -07:00
2009-01-04 13:33:20 -08:00
2014-01-30 16:56:54 -08:00
2014-01-13 17:32:27 +01:00
2012-12-06 14:33:02 +01:00
2013-09-04 09:23:46 -04:00
2013-02-21 17:22:16 -08:00
2014-01-23 16:36:56 -08:00
2013-08-30 23:44:11 -07:00
2014-01-15 11:33:40 +08:00
2011-01-13 08:03:17 -08:00
2012-10-13 10:46:48 +01:00
2014-01-03 23:41:42 +01:00
2014-02-11 10:38:30 -05:00
2010-03-24 16:31:22 -07:00
2013-12-04 17:19:44 +01:00
2014-02-09 15:11:47 +01:00
2013-07-30 11:24:20 -07:00
2014-01-21 20:18:26 -08:00
2013-02-13 06:00:53 -08:00
2014-01-21 16:19:48 -08:00
2014-03-20 16:42:14 +01:00
2014-02-13 12:34:05 +01:00
2014-01-23 18:11:00 -08:00
2014-01-23 18:11:00 -08:00
2013-11-15 09:32:21 +09:00
2014-01-10 16:27:36 -08:00
2008-04-30 08:29:54 -07:00
2012-01-03 22:54:57 -05:00
2010-08-10 13:47:42 -07:00
2013-05-20 12:27:59 -07:00
2008-06-04 14:56:12 +01:00
2013-12-29 15:25:48 +01:00
2013-12-02 20:43:15 +01:00
2013-12-02 20:43:14 +01:00
2013-10-23 10:10:20 -07:00
2013-12-04 09:33:34 -04:00
2011-09-23 12:05:29 +05:30
2013-09-13 15:09:52 +02:00
2014-02-18 12:45:38 -08:00
2014-02-18 12:38:37 -08:00
2014-03-20 03:50:12 +01:00
2014-03-13 15:56:44 +01:00
2013-01-09 08:26:53 -08:00
2012-03-24 10:08:39 -07:00
2012-03-29 19:52:48 +08:00
2012-10-13 10:46:48 +01:00
2009-09-10 10:00:05 -07:00
2013-12-12 10:39:01 -08:00
2012-10-13 10:46:48 +01:00
2013-05-12 14:16:21 +02:00
2013-10-03 16:14:12 -07:00
2013-08-18 17:39:55 -07:00
2010-08-04 11:00:45 +02:00
2010-03-30 22:02:32 +09:00
2013-11-15 16:47:22 -08:00
2011-10-31 19:32:26 -04:00
2013-09-20 10:36:34 -04:00
2014-04-01 16:28:19 -07:00
2012-10-22 16:50:13 -07:00
2011-06-10 14:55:36 +02:00
2012-11-19 14:32:13 +01:00
2014-02-13 10:08:52 +05:30
2014-01-21 16:19:41 -08:00
2013-10-31 14:49:24 +00:00
2014-01-29 20:27:23 -08:00
2007-02-09 17:39:36 -05:00
2014-01-09 12:43:37 +01:00
2013-10-23 10:10:12 -07:00
2010-07-28 09:59:01 -04:00
2014-02-17 16:46:48 +01:00
2013-06-28 16:04:36 +02:00
2014-02-17 16:50:37 +01:00
2013-07-06 14:09:38 -07:00
2013-01-17 12:19:09 -08:00
2011-11-29 12:46:19 -05:00
2013-03-03 23:59:59 -08:00
2013-12-11 18:06:47 +01:00
2012-10-13 10:46:48 +01:00
2011-07-25 20:57:16 -07:00
2014-03-05 18:15:37 +00:00
2009-06-15 21:30:26 -07:00
2014-02-24 14:46:38 -08:00
2013-11-09 00:16:24 -05:00
2008-01-28 23:21:18 +01:00
2013-07-15 11:25:00 +09:30
2013-05-07 18:38:27 -07:00
2012-10-13 10:46:48 +01:00
2014-01-15 15:39:33 -08:00
2012-10-13 10:46:48 +01:00
2013-03-27 13:48:25 +01:00
2014-01-16 10:23:02 +10:30
2013-04-29 18:28:40 -07:00
2014-03-19 14:41:58 +09:00
2012-10-13 10:46:48 +01:00
2013-12-18 10:56:13 +10:00
2013-09-26 15:06:58 -07:00
2012-10-13 10:46:48 +01:00
2014-01-25 03:14:36 -05:00
2011-01-09 15:42:55 -08:00
2014-03-10 11:44:42 -04:00
2009-06-18 19:50:21 +08:00
2014-03-07 10:19:57 -05:00
2013-02-23 17:50:12 -08:00
2013-12-08 18:22:32 -08:00
2012-10-13 10:46:48 +01:00
2014-01-21 23:17:20 -08:00
2014-02-28 15:12:09 -08:00
2013-06-19 20:30:32 -07:00
2007-05-08 11:15:31 -07:00
2009-12-17 10:58:17 -05:00
2013-09-12 10:12:47 -07:00
2014-03-10 11:44:42 -04:00
2013-09-27 18:40:25 +01:00
2012-10-13 10:46:48 +01:00
2014-02-18 12:20:45 -08:00
2014-02-25 11:18:06 +01:00
2013-06-29 12:57:13 +04:00
2014-03-20 13:21:05 -04:00
2014-03-03 11:32:08 +01:00
2009-06-18 13:04:05 -07:00
2014-01-23 16:36:52 -08:00
2013-11-19 16:39:06 -05:00
2012-11-08 16:58:30 +01:00
2006-09-30 01:47:55 +02:00
2014-03-10 17:26:19 -07:00
2014-02-19 17:22:44 +01:00
2013-12-17 14:27:17 -05:00
2013-10-11 17:21:14 +11:00
2013-04-30 10:09:06 +02:00
2014-02-22 13:07:06 +00:00
2013-09-13 15:11:21 +02:00
2012-10-13 10:46:48 +01:00
2013-02-23 17:50:16 -08:00
2006-04-26 12:56:16 +01:00
2014-03-20 12:35:45 +01:00
2014-03-04 07:55:47 -08:00
2014-01-23 16:36:50 -08:00
2013-10-13 16:16:28 -07:00
2012-03-16 10:38:24 -04:00
2014-03-08 22:15:52 -08:00
2012-10-13 10:46:48 +01:00
2014-01-26 22:48:35 +01:00
2013-12-07 01:03:14 +01:00
2014-02-17 16:27:47 +01:00
2013-06-05 12:00:27 -07:00
2012-10-13 10:46:48 +01:00
2008-08-02 18:36:10 +01:00
2013-03-27 13:48:25 +01:00
2012-10-13 10:46:48 +01:00
2008-07-09 12:09:28 -04:00
2013-12-11 14:47:40 -05:00
2014-01-23 18:08:10 -08:00
2014-02-13 20:24:13 -08:00
2005-04-16 15:20:36 -07:00
2011-01-31 21:17:41 -08:00
2012-11-10 00:40:24 -08:00
2013-03-27 13:48:25 +01:00
2014-02-19 17:22:44 +01:00
2012-10-09 16:22:40 +09:00
2012-10-09 16:22:39 +09:00
2012-03-04 17:54:34 -05:00
2014-02-13 18:12:04 -08:00
2006-10-05 15:10:12 +01:00
2012-03-20 12:47:48 +01:00
2014-02-26 14:42:09 -07:00
2012-12-09 00:20:28 -05:00
2013-03-15 12:23:09 -07:00
2014-02-25 15:25:45 -08:00
2014-01-27 21:02:39 -08:00
2013-02-27 19:10:21 -08:00
2014-02-21 21:49:07 +01:00
2014-03-14 13:43:33 +01:00
2007-09-16 21:13:58 -07:00
2013-07-01 08:12:41 -04:00
2013-08-09 10:49:00 +02:00
2012-05-31 17:49:32 -07:00
2012-10-13 10:46:48 +01:00
2013-10-03 18:47:54 +02:00
2007-07-31 15:39:40 -07:00
2012-10-13 10:46:48 +01:00
2014-04-01 11:22:57 -07:00
2013-11-13 12:09:07 +09:00
2014-03-20 16:28:09 -07:00
2012-10-13 10:46:48 +01:00
2014-03-08 22:08:29 -08:00
2014-03-06 16:30:46 +01:00
2013-09-25 17:17:01 +01:00
2011-01-24 14:45:11 +10:30
2013-04-30 17:04:06 -07:00
2012-07-21 10:34:00 -07:00
2010-03-15 15:29:39 +01:00
2013-08-28 21:35:14 -07:00
2013-12-11 15:28:36 -08:00
2013-05-16 07:55:07 -07:00
2013-04-30 17:04:02 -07:00
2013-07-25 12:35:39 +02:00
2011-09-16 19:20:20 -04:00
2013-07-03 16:07:43 -07:00
2013-04-01 11:04:50 -07:00
2014-04-18 15:56:03 -04:00
2012-10-06 02:48:09 +09:00
2013-01-06 01:11:25 -08:00
2014-02-13 20:21:59 -08:00
2009-06-16 19:47:57 -07:00
2013-11-13 12:09:24 +09:00
2012-10-13 10:46:48 +01:00
2014-03-31 14:13:25 -07:00
2013-12-20 12:25:45 -08:00
2011-12-12 22:06:55 -08:00
2012-10-13 10:46:48 +01:00
2013-03-22 22:17:36 -06:00
2013-02-02 00:01:15 +01:00
2012-03-16 10:38:24 -04:00
2013-12-11 15:52:34 +01:00
2011-01-10 19:04:08 +01:00
2014-02-28 15:36:37 -08:00
2013-12-26 13:29:35 -05:00
2014-01-23 16:36:51 -08:00
2013-11-13 12:09:06 +09:00
2013-12-20 12:20:26 -08:00
2012-06-25 11:53:47 +02:00
2009-06-16 08:40:20 +02:00
2012-01-23 08:38:47 -08:00
2014-01-21 16:19:49 -08:00
2014-02-18 10:56:28 -08:00
2013-09-11 15:58:01 -07:00
2014-03-31 14:35:30 -07:00
2014-01-23 16:36:50 -08:00
2014-03-10 17:26:19 -07:00
2014-04-01 16:28:19 -07:00
2014-01-16 10:23:03 +10:30
2012-09-28 14:31:03 +09:30
2013-08-20 15:37:42 +09:30
2013-11-09 00:16:19 -05:00
2009-04-01 07:38:54 -04:00
2012-10-08 13:50:21 +10:30
2014-01-27 21:02:39 -08:00
2013-06-26 12:10:56 +02:00
2014-03-11 12:14:56 +01:00
2013-07-03 16:08:05 -07:00
2014-01-14 15:15:25 -08:00
2014-03-28 17:16:51 -04:00
2014-03-28 17:10:36 -04:00
2014-01-01 23:43:36 -05:00
2013-10-25 19:26:58 -04:00
2014-03-01 13:51:53 -06:00
2014-01-25 03:14:05 -05:00
2012-12-11 17:22:27 -08:00
2013-04-29 15:54:36 -07:00
2013-08-27 13:52:52 -04:00
2013-01-17 19:11:14 -08:00
2014-03-07 10:24:49 -05:00
2014-02-05 10:04:37 -06:00
2014-03-07 16:02:46 +01:00
2014-01-13 14:29:49 -08:00
2014-01-03 11:22:21 -08:00
2013-06-12 12:37:30 +01:00
2014-03-26 16:57:57 +00:00
2013-11-13 12:09:04 +09:00
2013-03-29 17:54:33 -07:00
2013-10-30 12:02:58 +08:00
2012-01-10 16:30:42 -08:00
2013-07-03 16:07:31 -07:00
2014-01-23 16:36:55 -08:00
2012-10-13 10:46:48 +01:00
2013-03-01 23:51:07 -05:00
2013-12-07 01:03:14 +01:00
2014-04-01 18:49:04 -07:00
2014-03-19 15:11:19 -06:00
2013-02-05 11:54:06 +01:00
2014-01-23 20:17:18 +00:00
2013-06-16 16:12:26 -07:00
2014-01-23 16:36:50 -08:00
2008-01-23 19:33:58 -06:00
2014-01-13 14:29:49 -08:00
2013-10-24 23:43:29 -04:00
2013-07-03 16:08:03 -07:00
2013-09-26 16:18:32 -07:00
2011-08-25 15:34:19 +02:00
2014-03-02 00:18:15 +01:00
2014-03-20 13:25:54 +01:00
2012-10-13 10:46:48 +01:00
2012-10-13 10:46:48 +01:00
2012-10-13 10:46:48 +01:00
2013-08-19 21:22:34 -07:00
2014-01-23 14:48:35 +01:00
2011-03-31 11:26:23 -03:00
2013-05-01 17:29:47 -04:00
2013-05-01 17:29:39 -04:00
2013-04-09 14:13:35 -04:00
2011-09-29 00:32:03 -04:00
2012-11-03 15:27:07 -04:00
2008-09-02 19:21:38 -07:00
2010-02-08 18:19:41 -06:00
2014-01-23 16:36:58 -08:00
2014-01-21 23:17:20 -08:00
2010-02-10 17:47:17 -08:00
2012-05-17 15:18:37 +02:00
2014-02-17 15:01:52 -08:00
2014-03-31 11:05:24 -07:00
2014-03-20 17:12:25 -07:00
2014-03-20 17:12:25 -07:00
2013-12-18 19:04:50 -08:00
2014-04-01 16:13:21 -07:00
2012-03-24 10:08:39 -07:00
2014-01-16 12:00:56 -08:00
2013-04-12 10:26:23 +02:00
2012-10-13 10:46:48 +01:00
2011-10-03 15:19:19 -04:00
2011-04-19 15:38:02 -04:00
2012-10-13 10:46:48 +01:00
2013-03-15 00:34:50 -04:00
2013-07-03 16:08:05 -07:00
2014-03-20 22:09:09 -07:00
2006-07-13 13:21:35 -07:00
2011-05-12 08:28:47 -07:00
2012-07-04 11:51:59 +03:00
2007-05-02 11:56:33 +01:00
2013-04-29 18:28:22 -07:00
2014-01-13 13:41:50 +01:00
2013-12-17 21:19:08 -08:00
2010-03-13 01:21:21 +01:00
2014-01-28 13:20:09 -08:00
2009-09-15 02:44:17 -07:00
2012-10-13 10:46:48 +01:00
2014-04-01 11:00:07 -07:00
2013-06-17 16:38:57 -07:00
2012-10-13 10:46:48 +01:00
2012-10-13 10:46:48 +01:00
2014-03-10 08:30:02 +01:00
2010-10-22 10:20:06 -07:00
2013-07-09 10:33:28 -07:00
2011-09-13 11:11:57 +02:00
2013-11-15 09:32:20 +09:00
2014-01-12 10:13:59 +01:00
2014-02-28 16:27:18 -08:00
2014-03-17 16:20:49 -07:00
2012-10-13 10:46:48 +01:00
2010-10-31 10:40:39 -04:00
2013-09-10 18:56:32 -04:00
2012-06-28 17:14:34 +01:00
2014-03-27 15:29:38 -04:00
2014-03-10 17:26:19 -07:00
2014-02-24 14:47:15 -08:00
2013-02-26 22:25:17 +01:00
2013-08-02 12:33:54 -07:00
2012-12-07 12:48:00 -05:00
2014-01-22 21:57:05 -08:00
2014-01-13 13:47:36 +01:00
2014-01-13 13:47:36 +01:00
2013-12-16 11:36:13 +01:00
2014-01-27 21:02:40 -08:00
2014-02-15 11:55:28 -08:00
2014-02-17 15:01:37 -08:00
2008-05-26 16:15:32 +02:00
2011-06-14 22:48:51 -04:00
2006-12-07 02:14:08 +01:00
2012-10-13 10:46:48 +01:00
2010-08-09 16:48:44 -04:00
2012-02-24 10:05:59 +01:00
2012-10-13 10:46:48 +01:00
2012-04-20 23:27:08 +02:00
2013-10-09 12:40:45 +02:00
2013-04-30 17:04:03 -07:00
2012-12-17 17:15:17 -08:00
2009-04-10 15:48:52 +02:00
2013-04-30 15:50:12 +05:30
2012-02-10 11:42:25 -08:00
2005-04-16 15:20:36 -07:00
2014-03-04 09:12:24 +01:00
2014-03-25 20:54:57 -07:00
2013-06-12 16:29:44 -07:00
2010-08-11 08:59:22 -07:00
2012-09-13 16:47:34 +02:00
2010-03-30 22:02:32 +09:00
2013-12-07 01:03:14 +01:00
2007-02-09 16:23:15 +00:00
2011-10-31 19:32:32 -04:00
2013-09-25 13:53:10 +02:00
2010-05-27 09:12:51 -07:00
2014-01-15 23:05:31 +01:00
2013-05-14 20:54:06 +02:00
2013-04-04 13:18:31 -07:00
2012-08-21 16:28:31 +02:00
2011-05-23 13:59:53 +02:00
2012-10-09 16:22:32 +09:00
2013-10-10 12:31:43 -07:00
2014-02-23 09:04:27 -08:00
2010-11-29 08:55:25 +11:00
2014-01-06 14:37:25 +01:00
2013-03-15 00:36:09 -04:00
2012-03-20 21:29:40 -04:00
2012-07-22 23:57:55 +04:00
2014-03-03 21:11:05 -05:00
2013-02-04 15:40:28 -08:00
2014-02-18 12:50:26 -08:00
2014-02-28 16:31:00 -08:00
2014-01-13 13:47:37 +01:00
2013-04-15 21:23:03 +01:00
2012-10-13 10:46:48 +01:00
2014-03-04 15:38:16 -08:00
2014-04-01 17:06:09 -07:00
2013-09-24 10:35:19 +01:00
2005-04-16 15:20:36 -07:00
2011-06-15 20:04:00 -07:00
2012-11-20 04:19:49 -08:00
2012-10-13 10:46:48 +01:00
2012-10-13 10:46:48 +01:00
2013-10-29 11:28:17 +10:30
2013-03-08 12:24:48 -05:00
2013-07-09 10:33:21 -07:00
2014-02-07 11:27:30 -08:00
2006-04-26 12:56:16 +01:00
2012-10-13 10:46:48 +01:00
2013-12-02 20:43:15 +01:00
2014-02-27 12:20:31 +01:00
2012-10-13 10:46:48 +01:00
2014-04-01 11:00:07 -07:00
2014-02-22 02:02:28 +01:00
2011-03-22 17:44:17 -07:00
2006-06-22 15:05:58 -07:00