Storage Bench v1.0 (Background Info)
Our Storage Bench incorporates all of the I/O from a trace recorded over two weeks. The process of replaying this sequence to capture performance gives us a bunch of numbers that aren't really intuitive at first glance. Most idle time gets expunged, leaving only the time that each benchmarked drive is actually busy working on host commands. So, by taking the ratio of that busy time and the amount of data exchanged during the trace, we arrive at an average data rate (in MB/s) metric we can use to compare drives.
It's not quite a perfect system. The original trace captures the TRIM command in transit, but since the trace is played on a drive without a file system, TRIM wouldn't work even if it were sent during the trace replay (which, sadly, it isn't). Still, trace testing is a great way to capture periods of actual storage activity, a great companion to synthetic testing like Iometer.
Incompressible Data and Storage Bench v1.0
Also worth noting is the fact that our trace testing pushes incompressible data through the system's buffers to the drive getting benchmarked. So, when the trace replay plays back write activity, it's writing largely incompressible data. If we run our storage bench on a SandForce-based SSD, we can monitor the SMART attributes for a bit more insight.
|Mushkin Chronos Deluxe 120 GB|
|RAW Value Increase|
|#242 Host Reads (in GB)||84 GB|
|#241 Host Writes (in GB)||142 GB|
|#233 Compressed NAND Writes (in GB)||149 GB|
Host reads are greatly outstripped by host writes to be sure. That's all baked into the trace. But with SandForce's inline deduplication/compression, you'd expect that the amount of information written to flash would be less than the host writes (unless the data is mostly incompressible, of course). For every 1 GB the host asked to be written, Mushkin's drive is forced to write 1.05 GB.
If our trace replay was just writing easy-to-compress zeros out of the buffer, we'd see writes to NAND as a fraction of host writes. This puts the tested drives on a more equal footing, regardless of the controller's ability to compress data on the fly.
Average Data Rate
The Storage Bench trace generates more than 140 GB worth of writes during testing. This tends to penalize drives smaller than 180 GB and favor those with more than 256 GB of capacity. So, it's not wise to take a trace from a 240 GB SSD and wrap it around something, say, 40 GB-large. Using a small trace on a larger SSD is no problem, but going the other way results in different trace timing, affecting the results.
If you've followed us so far, you won't be surprised to see Crucial's M550s and the 1024 GB SP920 tripping over one another. Nor should the 128 and 256 GB model's outcome require much explanation. But the 512 GB SP920? That doesn't end up where we might have guessed.
First, we tried running our trace a second time. Then we tried other systems, all of which spat back the same result. Really though, losing 15 MB/s doesn't mean much at the end of the day. But we do come away knowing that the 512 GB SP920 isn't exactly the same as the 1024 GB model. Nor is it identical to the M550s. Something is slightly different on what should be an identical drive. Perhaps a look at mean service times on the next page will shed some light...
- Adata's SP920: Quite Literally, A Familiar Face
- A Primer: The Art Of The Platform, SMART, And You
- Test Setup And Benchmarks
- Results: Sequential Performance
- Results: Random Performance
- Results: Tom's Hardware Storage Bench v1.0
- Results: Tom's Hardware Storage Bench v1.0, Continued
- Results: TRIM Testing With ULINK's DriveMaster 2012
- Results: Power Consumption
- Adata SP920: Adding Value With A Nice Bundle