Theodore Tso wrote: ..
Mark Lord has claimed that the currently shipping SSD's take "hundreds of milliseconds" for a TRIM, command.
.. Here's some data to support that claim. First, here are a series of TRIM commands for single-extents of varying lengths. The measures include the printk() timestamp, plus I had libata itself use rdtsc() before/after each TRIM. This is with a T7400 CPU booted using maxcpus=1, and locked at 2.16GHz using "performance" CPU policy. The first set of data, is from individual single-extent TRIMs, with a "sleep 1 ; sync" between each successive TRIM: Beginning TRIM operations.. Trimming 1 free extents encompassing 656 sectors (0 MB) Trimming 1 free extents encompassing 30 sectors (0 MB) Trimming 1 free extents encompassing 194 sectors (0 MB) Trimming 1 free extents encompassing 42 sectors (0 MB) Trimming 1 free extents encompassing 1574 sectors (1 MB) Trimming 1 free extents encompassing 612 sectors (0 MB) Trimming 1 free extents encompassing 862 sectors (0 MB) Trimming 1 free extents encompassing 1344 sectors (1 MB) Trimming 1 free extents encompassing 822 sectors (0 MB) Trimming 1 free extents encompassing 672 sectors (0 MB) Trimming 1 free extents encompassing 226 sectors (0 MB) Trimming 1 free extents encompassing 860 sectors (0 MB) Trimming 1 free extents encompassing 638 sectors (0 MB) Trimming 1 free extents encompassing 1020 sectors (0 MB) Trimming 1 free extents encompassing 12286 sectors (6 MB) Trimming 1 free extents encompassing 1964 sectors (1 MB) Done. [ 1083.768460] ata_qc_issue: ATA_CMD_DSM starting [ 1083.768672] trim_completed: ATA_CMD_DSM took 438841 cycles [ 1084.794304] ata_qc_issue: ATA_CMD_DSM starting [ 1084.794469] trim_completed: ATA_CMD_DSM took 338065 cycles [ 1085.823605] ata_qc_issue: ATA_CMD_DSM starting [ 1085.823791] trim_completed: ATA_CMD_DSM took 382317 cycles [ 1086.852989] ata_qc_issue: ATA_CMD_DSM starting [ 1086.853166] trim_completed: ATA_CMD_DSM took 352248 cycles [ 1087.882825] ata_qc_issue: ATA_CMD_DSM starting [ 1087.883127] trim_completed: ATA_CMD_DSM took 624546 cycles [ 1088.915833] ata_qc_issue: ATA_CMD_DSM starting [ 1088.916056] trim_completed: ATA_CMD_DSM took 455299 cycles [ 1089.941946] ata_qc_issue: ATA_CMD_DSM starting [ 1089.942181] trim_completed: ATA_CMD_DSM took 485615 cycles [ 1090.968793] ata_qc_issue: ATA_CMD_DSM starting [ 1090.969062] trim_completed: ATA_CMD_DSM took 562042 cycles [ 1091.994441] ata_qc_issue: ATA_CMD_DSM starting [ 1091.994672] trim_completed: ATA_CMD_DSM took 479219 cycles [ 1093.023576] ata_qc_issue: ATA_CMD_DSM starting [ 1093.023799] trim_completed: ATA_CMD_DSM took 463398 cycles [ 1094.053545] ata_qc_issue: ATA_CMD_DSM starting [ 1094.053731] trim_completed: ATA_CMD_DSM took 385229 cycles [ 1095.083131] ata_qc_issue: ATA_CMD_DSM starting [ 1095.083356] trim_completed: ATA_CMD_DSM took 458328 cycles [ 1096.113146] ata_qc_issue: ATA_CMD_DSM starting [ 1096.113356] trim_completed: ATA_CMD_DSM took 423670 cycles [ 1097.144211] ata_qc_issue: ATA_CMD_DSM starting [ 1097.144464] trim_completed: ATA_CMD_DSM took 524706 cycles [ 1098.174457] ata_qc_issue: ATA_CMD_DSM starting [ 1098.175619] trim_completed: ATA_CMD_DSM took 2491138 cycles [ 1099.209218] ata_qc_issue: ATA_CMD_DSM starting [ 1099.209539] trim_completed: ATA_CMD_DSM took 674752 cycles Those TRIMs look fine, in the single millisecond range. But.. the "sleep 1" hides some drive firmware evils.. Here is exactly the same run again, but without the "sleep 1": Beginning TRIM operations.. Trimming 1 free extents encompassing 656 sectors (0 MB) Trimming 1 free extents encompassing 30 sectors (0 MB) Trimming 1 free extents encompassing 194 sectors (0 MB) Trimming 1 free extents encompassing 42 sectors (0 MB) Trimming 1 free extents encompassing 1574 sectors (1 MB) Trimming 1 free extents encompassing 612 sectors (0 MB) Trimming 1 free extents encompassing 862 sectors (0 MB) Trimming 1 free extents encompassing 1344 sectors (1 MB) Trimming 1 free extents encompassing 822 sectors (0 MB) Trimming 1 free extents encompassing 672 sectors (0 MB) Trimming 1 free extents encompassing 226 sectors (0 MB) Trimming 1 free extents encompassing 860 sectors (0 MB) Trimming 1 free extents encompassing 638 sectors (0 MB) Trimming 1 free extents encompassing 1020 sectors (0 MB) Trimming 1 free extents encompassing 12286 sectors (6 MB) Trimming 1 free extents encompassing 1964 sectors (1 MB) Done. [ 1258.206379] ata_qc_issue: ATA_CMD_DSM starting [ 1258.206587] trim_completed: ATA_CMD_DSM took 426088 cycles [ 1258.254513] ata_qc_issue: ATA_CMD_DSM starting [ 1258.366141] trim_completed: ATA_CMD_DSM took 241231523 cycles [ 1258.411749] ata_qc_issue: ATA_CMD_DSM starting [ 1258.524047] trim_completed: ATA_CMD_DSM took 242676590 cycles [ 1258.600184] ata_qc_issue: ATA_CMD_DSM starting [ 1258.711766] trim_completed: ATA_CMD_DSM took 241136519 cycles [ 1258.813515] ata_qc_issue: ATA_CMD_DSM starting [ 1258.910599] trim_completed: ATA_CMD_DSM took 209803152 cycles [ 1259.027253] ata_qc_issue: ATA_CMD_DSM starting [ 1259.108916] trim_completed: ATA_CMD_DSM took 176473453 cycles [ 1259.239549] ata_qc_issue: ATA_CMD_DSM starting [ 1259.306640] trim_completed: ATA_CMD_DSM took 144968694 cycles [ 1259.452978] ata_qc_issue: ATA_CMD_DSM starting [ 1259.505017] trim_completed: ATA_CMD_DSM took 112440172 cycles [ 1259.552393] ata_qc_issue: ATA_CMD_DSM starting [ 1259.664739] trim_completed: ATA_CMD_DSM took 242778861 cycles [ 1259.775724] ata_qc_issue: ATA_CMD_DSM starting [ 1259.861318] trim_completed: ATA_CMD_DSM took 184955732 cycles [ 1259.989289] ata_qc_issue: ATA_CMD_DSM starting [ 1260.059963] trim_completed: ATA_CMD_DSM took 152713730 cycles [ 1260.211066] ata_qc_issue: ATA_CMD_DSM starting [ 1260.257474] trim_completed: ATA_CMD_DSM took 100279998 cycles [ 1260.306277] ata_qc_issue: ATA_CMD_DSM starting [ 1260.417770] trim_completed: ATA_CMD_DSM took 240932835 cycles [ 1260.464049] ata_qc_issue: ATA_CMD_DSM starting [ 1260.575418] trim_completed: ATA_CMD_DSM took 240673134 cycles [ 1260.650624] ata_qc_issue: ATA_CMD_DSM starting [ 1260.763510] trim_completed: ATA_CMD_DSM took 243952865 cycles [ 1260.810454] ata_qc_issue: ATA_CMD_DSM starting [ 1260.921433] trim_completed: ATA_CMD_DSM took 239832996 cycles As you can see, we're now into the 100 millisecond range for successive TRIM-followed-by-TRIM commands. Those are all for single extents. I will follow-up with a small amount of similar data for TRIMs with multiple extents. -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html