Re: [PATCH V5 00/13] mmc: Add Command Queue support

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

 



Hi

On 2017/8/17 15:45, Bough Chen wrote:

-----Original Message-----
From: linux-mmc-owner@xxxxxxxxxxxxxxx [mailto:linux-mmc-
owner@xxxxxxxxxxxxxxx] On Behalf Of Adrian Hunter
Sent: Thursday, August 10, 2017 8:08 PM
To: Ulf Hansson <ulf.hansson@xxxxxxxxxx>
Cc: linux-mmc <linux-mmc@xxxxxxxxxxxxxxx>; Bough Chen
<haibo.chen@xxxxxxx>; Alex Lemberg <alex.lemberg@xxxxxxxxxxx>;
Mateusz Nowak <mateusz.nowak@xxxxxxxxx>; Yuliy Izrailov
<Yuliy.Izrailov@xxxxxxxxxxx>; Jaehoon Chung <jh80.chung@xxxxxxxxxxx>;
Dong Aisheng <dongas86@xxxxxxxxx>; Das Asutosh
<asutoshd@xxxxxxxxxxxxxx>; Zhangfei Gao <zhangfei.gao@xxxxxxxxx>;
Sahitya Tummala <stummala@xxxxxxxxxxxxxx>; Harjani Ritesh
<riteshh@xxxxxxxxxxxxxx>; Venu Byravarasu <vbyravarasu@xxxxxxxxxx>;
Linus Walleij <linus.walleij@xxxxxxxxxx>; Shawn Lin <shawn.lin@xxxxxxxxxxxxxx>
Subject: [PATCH V5 00/13] mmc: Add Command Queue support

Hi

Here is V5 of the hardware command queue patches without the software
command queue patches.

HW CMDQ offers 25% - 50% better random multi-threaded I/O.  I see a slight 2%
drop in sequential read speed but no change to sequential write.


Hi Adrian,

I test the performance on the i.MX8.  Here in my side, I use 'dd' to test the
sequential read/write speed, see a slight 3% drop for both read and write.

     ---------------------------------------------
    |               | read (KB/s)| write (KB/s) |
    ---------------------------------------------
     |CMDQ in HS400ES|    257     |     94.5     |
     ---------------------------------------------
     |    HS400ES    |    265     |     96.6     |
     ---------------------------------------------

For random multi-threaded I/O, I use 'fio'  to test, the test command:
fio -filename=/mnt/test -direct=1 -iodepth 1 -thread -rw=randread - ioengine=psync  -bs=4k -size=2G -numjobs=10 -runtime=60  -group_reporting - name=mytest

I test 5 times, and get the average value.
For CMDQ in HS400ES
     ----------------------------------------------------
     | block size   |    4KB    |    8KB    |    16KB   |
     ----------------------------------------------------
     | random read  | 26340KB/s | 51844KB/s | 85738KB/s |
     ----------------------------------------------------
     | random write | 12691KB/s | 15879KB/s | 17535KB/s |
     ----------------------------------------------------

HS400ES without CMDQ
     ----------------------------------------------------
     | block size   |    4KB    |    8KB    |    16KB   |
     ----------------------------------------------------
     | random read  | 18585KB/s | 35041KB/s | 63880KB/s |
     ----------------------------------------------------
     | random write | 16465KB/s | 19210KB/s | 22672KB/s |
     ----------------------------------------------------

For random write from the test, I find every test value differ greatly no matter enable CMDQ or not.

From the test, I see CMDQ random read speed increase 34%~48%, but for random write, the speed
drop 17.4% ~ 33%.

When you send software cmdq V5 patch, you give some explanation for the random write. But the
average random write speed also drops a lot, I think it is now a good news, which need attention!


Maybe Shawn Lin can double test this random write performance.

Yes, I also find the performance fluctuates a lot for different
eMMC chips when enabling CMDQ. I will need more data to check that.
Will update it later.


Best Regards
Haibo Chen

Changes since V4:
       mmc: core: Add mmc_retune_hold_now()
	Add explanation to commit message.
       mmc: host: Add CQE interface
	Add comments to callback declarations.
       mmc: core: Turn off CQE before sending commands
	Add explanation to commit message.
       mmc: core: Add support for handling CQE requests
	Add comments as requested by Ulf.
       mmc: core: Remove unused MMC_CAP2_PACKED_CMD
	New patch.
       mmc: mmc: Enable Command Queuing
	Adjust for removal of MMC_CAP2_PACKED_CMD.
	Add a comment about Packed Commands.
       mmc: mmc: Enable CQE's
	Remove un-necessary check for MMC_CAP2_CQE
       mmc: block: Use local variables in mmc_blk_data_prep()
	New patch.
       mmc: block: Prepare CQE data
	Adjust due to "mmc: block: Use local variables in
mmc_blk_data_prep()"
	Remove priority setting.
	Add explanation to commit message.
       mmc: cqhci: support for command queue enabled host
	Fix transfer descriptor setting in cqhci_set_tran_desc() for 32-bit DMA

Changes since V3:
	Adjusted ...blk_end_request...() for new block status codes
	Fixed CQHCI transaction descriptor for "no DCMD" case

Changes since V2:
	Dropped patches that have been applied.
	Re-based
	Added "mmc: sdhci-pci: Add CQHCI support for Intel GLK"

Changes since V1:

	"Share mmc request array between partitions" is dependent
	on changes in "Introduce queue semantics", so added that
	and block fixes:

	Added "Fix is_waiting_last_req set incorrectly"
	Added "Fix cmd error reset failure path"
	Added "Use local var for mqrq_cur"
	Added "Introduce queue semantics"

Changes since RFC:

	Re-based on next.
	Added comment about command queue priority.
	Added some acks and reviews.


Adrian Hunter (12):
       mmc: core: Add mmc_retune_hold_now()
       mmc: core: Add members to mmc_request and mmc_data for CQE's
       mmc: host: Add CQE interface
       mmc: core: Turn off CQE before sending commands
       mmc: core: Add support for handling CQE requests
       mmc: core: Remove unused MMC_CAP2_PACKED_CMD
       mmc: mmc: Enable Command Queuing
       mmc: mmc: Enable CQE's
       mmc: block: Use local variables in mmc_blk_data_prep()
       mmc: block: Prepare CQE data
       mmc: block: Add CQE support
       mmc: sdhci-pci: Add CQHCI support for Intel GLK

Venkat Gopalakrishnan (1):
       mmc: cqhci: support for command queue enabled host

  drivers/mmc/core/block.c          |  238 +++++++-
  drivers/mmc/core/block.h          |    7 +
  drivers/mmc/core/bus.c            |    7 +
  drivers/mmc/core/core.c           |  178 +++++-
  drivers/mmc/core/host.c           |    6 +
  drivers/mmc/core/host.h           |    1 +
  drivers/mmc/core/mmc.c            |   42 +-
  drivers/mmc/core/queue.c          |  273 ++++++++-
  drivers/mmc/core/queue.h          |   42 +-
  drivers/mmc/host/Kconfig          |   14 +
  drivers/mmc/host/Makefile         |    1 +
  drivers/mmc/host/cqhci.c          | 1154
+++++++++++++++++++++++++++++++++++++
  drivers/mmc/host/cqhci.h          |  240 ++++++++
  drivers/mmc/host/sdhci-pci-core.c |  153 ++++-
  include/linux/mmc/core.h          |   18 +-
  include/linux/mmc/host.h          |   63 +-
  include/trace/events/mmc.h        |   36 +-
  17 files changed, 2412 insertions(+), 61 deletions(-)  create mode 100644
drivers/mmc/host/cqhci.c  create mode 100644 drivers/mmc/host/cqhci.h


Regards
Adrian
--
To unsubscribe from this list: send the line "unsubscribe linux-mmc" 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 linux-mmc" 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 linux-mmc" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux USB Devel]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux