When we reviewed Intel's SSD DC S3700 I started looking at consistency of IO latency, an area that Intel's latest controller specifically targeted for significant improvement. In our review of OCZ's Vector I took the same methodology and applied it to the current crop of high-end consumer drives. As I believe improving IO consistency is a good optimization practice for all SSDs, the hope is that we'll see improvements in this area on both client and enterprise focused drives.

In the comments thread for the Vector review, jwilliams4200 posted some very interesting data. The S3700 has 264GiB of NAND on-board but only exposes 186GiB of it (200GB advertised capacity) as user accessible storage, the rest is used as spare area to improve performance, consistency and endurance. Most client drives on the other hand only feature about 7% of their total NAND capacity set aside as spare area (256GiB of NAND, 238GiB of user storage). The obvious hypothesis is that a big part (if not all?) of the S3700's advantage in performance consistency is due to the large amount of spare area.

We've understood the relationship between spare area and write amplification for quite some time now. I borrowed the chart below from a paper published by IBM's Zurich Research Laboratory showing the relationship between write amplification and spare area for various workloads:


Write Amplification vs. Spare Area, courtesy of IBM Zurich Research Laboratory

With more spare area, write amplification is lower. The controller has more room and thus flexibility with running its defragmentation and garbage collection algorithms. The dreaded read-modify-write scenario is triggered less frequently as there's less space pressure thanks to additional spare area. If you're testing in a full-drive scenario, there's simply less data to keep track of when you've got more NAND set aside as spare area. This keeps internal data structure footprints smaller by default, which also improves performance.

It's because of this relationship between write amplification and spare area that we've always recommended setting aside 10 - 20% of your SSD and not filling it up entirely. Most modern controllers will do just fine if you partition the drive and leave the last 10 - 20% untouched. With TRIM support even the partitioning step isn't really necessary, but it does help from a data management standpoint. The real question is what's the relationship between spare area and IO latency/performance consistency.

To find out, I repeated jwilliams4200's tests. I took a bunch of 240/256GB drives and filled them to various percentages of their capacity, and performed our IO consistency test with an identical span of LBAs. The goal was to simulate worst case IO consistency while taking into account greater percentages of spare area.

The Tests

For this investigation I picked a couple of the most interesting, modern SSD controllers: Samsung's MDX controller from the SSD 840 Pro, Link A Media Devices' LM87800 controller from Corsair's Neutron and Barefoot 3 from OCZ's Vector. For all of these drives I used 256GB capacities. With the exception of the Neutron, all of the drives had ~7% of their NAND capacity set aside as spare area. The Neutron is a 240GB drive after its ~12% spare area.

The high level testing methodology remains unchanged from our S3700 review. Unlike in previous reviews however, I did vary the percentage of the drive that I filled/tested depending on the amount of spare area I was trying to simulate. The buttons are labeled with the advertised user capacity had the SSD vendor decided to use that specific amount of spare area.  If you want to replicate this on your own all you need to do is create a partition smaller than the total capacity of the drive and leave the remaining space unused to simulate a larger amount of spare area. The partitioning step isn't absolutely necessary in every case but it's an easy way to make sure you never exceed your allocated spare area. It's a good idea to do this from the start (e.g. secure erase, partition, then install Windows), but if you are working backwards you can always create the spare area partition, format it to TRIM it, then delete the partition. Finally, this method of creating spare area works on the drives I've tested here but not all controllers may behave the same way.

In our Intel SSD DC S3700 review I introduced a new method of characterizing performance: looking at the latency of individual operations over time. The S3700 promised a level of performance consistency that was unmatched in the industry, and as a result needed some additional testing to show that. The reason we don't have consistent IO latency with SSDs is because inevitably all controllers have to do some amount of defragmentation or garbage collection in order to continue operating at high speeds. When and how an SSD decides to run its defrag and cleanup routines directly impacts the user experience. Frequent (borderline aggressive) cleanup generally results in more stable performance, while delaying that can result in higher peak performance at the expense of much lower worst case performance. The graphs below tell us a lot about the architecture of these SSDs and how they handle internal defragmentation.

To generate the data below I took a freshly secure erased SSD and filled it with sequential data. This ensures that all user accessible LBAs have data associated with them. Next I kicked off a 4KB random write workload across all LBAs at a queue depth of 32 using incompressible data. I ran the test for just over half an hour, no where near what we run our steady state tests for but enough to give me a good look at drive behavior once all spare area filled up.

I recorded instantaneous IOPS every second for the duration of the test. I then plotted IOPS vs. time and generated the scatter plots below. Each set of graphs features the same scale. The first two sets use a log scale for easy comparison, while the last set of graphs uses a linear scale that tops out at 40K IOPS for better visualization of differences between drives.

The first set of graphs shows the performance data over the entire 2000 second test period. In these charts you'll notice an early period of very high performance followed by a sharp dropoff. What you're seeing in that case is the drive alllocating new blocks from its spare area, then eventually using up all free blocks and having to perform a read-modify-write for all subsequent writes (write amplification goes up, performance goes down).

The second set of graphs zooms in to the beginning of steady state operation for the drive (t=1400s). The third set also looks at the beginning of steady state operation but on a linear performance scale. Click the buttons below each graph to switch source data.

Impact of Spare Area
  Intel SSD DC S3700 200GB Corsair Neutron 240GB OCZ Vector 256GB Samsung SSD 840 Pro 256GB
Default
12% Spare Area - - -
25% Spare Area -
50% Spare Area - - -

I ran the most data on Samsung's SSD 840 Pro as it's likely going to be the most popular of the drives here. If you click through the various simulated capacities/spare area points you'll see the drive's performance consistency improves tremendously once you hit 25% spare area. The drive's IO consistency goes from a spread out mess to something that resembles a thickly painted line across the graph. At 50% spare area, the 840 Pro begins to lose that initial performance cliff and instead develops a much flatter curve. Compared to the S3700 there's still some obvious variation in IO latency (and thus performance) but it's far more controlled than in the default configuration.

OCZ's Vector behaves similarly. The individual IOs on the Vector with 25% spare area are more tightly grouped than on the 840 Pro in general, but you can see OCZ's periodic defrag routine kick in with regular blips that deviate below the curve.

The LAMD based Neutron is actually remarkably consistent even in its default configuration. I originally didn't include the Neutron but Kristian theorized that LAMD's enterprise experience could make for an interesting datapoint here. He was right. The Neutron remains one of the most consistent SSDs out of the box without dedicating any additional spare area to the controller. Even compared to Samsung's SSD 840 Pro at 225GB, the Neutron manages to deliver more consistent performance. The Neutron's curve tightens up at 25% spare area but there's still a good amount of variance. The LAMD defrag routines don't look as predictable/periodic as we've seen on other drives, including the S3700. I wonder if the controller is doing something a bit more dynamic here.

The next set of charts look at the steady state (for most drives) portion of the curve. Here we'll get some better visibility into how everyone will perform over the long run.

Impact of Spare Area
  Intel SSD DC S3700 200GB Corsair Neutron 240GB OCZ Vector 256GB Samsung SSD 840 Pro 256GB
Default
12% Spare Area - - -
25% Spare Area -
50% Spare Area - - -

The scale isn't different here, but we do get a better look at steady state consistency. The Neutron continues to impress, looking almost identical to the S3700 if you give up 25% of the drive's NAND to spare area. Samsung also does very well at 25% spare area, there's just a huge improvement there.

The final set of graphs abandons the log scale entirely and just looks at a linear scale that tops out at 50K IOPS. We're also only looking at steady state (or close to it) performance here:

Impact of Spare Area
  Intel SSD DC S3700 200GB Corsair Neutron 240GB OCZ Vector 256GB Samsung SSD 840 Pro 256GB
Default
12% Spare Area - - -
25% Spare Area -
50% Spare Area - - -

Zooming in and looking at a linear scale does show us that additional spare area alone isn't enough to deliver the degree of consistency that Intel's S3700 offers. The solution really has to be a combination of controller and spare area. It's also entirely possible that a controller that prioritizes IO consistency would be able to offset the need for significant spare area. That's definitely the case with Corsair's Neutron, and I'd assume that future derivaties of Intel's S3700 with standard MLC and less spare area will behave similarly. For most consumers this likely won't matter as minimum performance improves substantially once you hit 25% spare area for these drives, but enterprise customers with several if not dozens of SSDs in a RAID array will still benefit from the S3700's architecture.

Final Words

Delivering consistent performance is an important part of improving user experience. As Intel's SSD DC S3700 and Corsair's Neutron have shown, consistent performance is possible through a controller that prioritizes efficient and aggressive defragmentation. I do believe it is important for controller vendors to prioritize IO consistency in their controller and firmware designs.

For drives on the market today that don't already prioritize consistent IO, it is possible to deliver significant improvements in IO consistency through an increase in spare area. OCZ's Vector and Samsung's SSD 840 Pro both deliver much better IO consistency if you simply set aside 25% of the total NAND capacity as spare area. Consumer SSD prices are finally low enough where we're no longer forced to buy the minimum capacity for our needs. Whatever drive you end up buying, plan on using only about 75% of its capacity if you want a good balance between performance consistency and capacity.

Comments Locked

134 Comments

View All Comments

  • jwilliams4200 - Tuesday, December 4, 2012 - link

    Excellent set of tests and well-chosen comparison SSDs! It is interesting to see how the Vector and Neutron compare to the 840 Pro.

    One point I think is worth making is that highest minimum performance (or lowest maximum latency) is probably more important for most applications than is having a small variation in performance. In other words, if I had a choice between 40,000 IOPS minimum (say 45,000 average with +/- 5000 variation) and 30,000 IOPS minimum with less than +/- 1000 variation, I would choose the one with five times higher variation but 33% higher minimum IOPS. Yet another way to say it is that I value highest worst-case performance over performance consistency -- no reason to cut off the upside if there is already a good floor supporting the downside.

    Only thing that I missed seeing in this article is the Vector at 50% (or perhaps 49% just to be sure to be under 50%). That is potentially interesting due to the way that SSD changes its behavior at 50% full.

    One minor correction: On your second set of graphs, the 50% button is labeled "192GB" instead of "128GB"
  • Anand Lal Shimpi - Tuesday, December 4, 2012 - link

    Thanks for the inspiration :)

    That is a very good point on the Vector. Tests on both sides of the 50% mark could be very interesting. I'll see if I can run some this week.

    I also agree on your analysis of which is the more desired configuration. I've been pushing a lot of the controller vendors recently to take performance consistency more seriously. It sounds like at least two of them will have firmware based solutions to this problem within the next 12 months. Hopefully we won't have to make the tradeoff you're outlining anymore if this catches on.

    Thanks for the correction as well.

    Take care,
    Anand
  • jwilliams4200 - Tuesday, December 4, 2012 - link

    Yes, if you have time to run 49% and 51% on the Vector, I think that would be quite interesting!

    One other thing that might be interesting (for all SSDs), if you have time. I noticed that you use a 1sec averaging time. In my data, I used a 0.1sec averaging time, since one of the SSDs I was testing has some variation that was only visible with a resolution of a few hundred milliseconds.

    I wonder if the little "blips" that are visible in your graphs for the Vector and Neutron might have some structure that may become apparent if you increased your time resolution.
  • rob.laur - Wednesday, December 12, 2012 - link

    "Only thing that I missed seeing in this article is the Vector at 50% (or perhaps 49% just to be sure to be under 50%). That is potentially interesting due to the way that SSD changes its behavior at 50% full"

    As per Tweaktowns recent review of the 128GB Vector:

    "Vector 128GB performs very well when half of the drive has data on it. This contradicts some of the statements made about the way storage mode works. If storage mode becomes active when half of the drive has data on it we would see a massive performance drop here, but as you can see, there is only a small drop between 25% and 50%"

    Storage mode is only temporary and lasts for a couple of minutes and then the drive returns to its previous performance. It does not last forever if the drive is filled over 50%.
  • jwilliams4200 - Wednesday, December 12, 2012 - link

    If you read the tweaktown review, it is clear that they are clueless about how storage mode works. If you check the comments on that review, you can see some discussion of how storage mode may actually work.
  • rob.laur - Wednesday, December 12, 2012 - link

    Storage mode was explained by OCZ reps in depth on their forums as well and they said the same thing tweaktown's tests showed, that it is indeed a mode that lasts for a couple of minutes. Instead of doing tests on empty drives which is not a real world scenario, I think Anand needs to starting doing his tests with lets say 60% of data on the drives so we can really see which performs the best. Mixed reads/writes also is indicative of real world scenarios instead of all read or all write.
  • jwilliams4200 - Wednesday, December 12, 2012 - link

    OCZ has never properly explained how storage mode works. For example, OCZ's vague explanation cannot explain these test results:

    http://www.tomshardware.com/reviews/vertex-4-firmw...

    As for testing SSDs with static data, I agree that is a useful thing to do.

    But mixed read/writes is more problematic, because there are so many ways that reads and writes can be mixed in real workloads. I agree it is a useful test, but deciding exactly what type of mix (eg., percentage reads, block size of reads, whether the reads and writes are interleaved with 1 IO each, 16 IOs each, etc.) to run is tricky.
  • hpvd - Tuesday, December 4, 2012 - link

    sorry i didn't get it in all details.
    Could you give some concrete advice for the usage of the results from this great article in the following cases:
    1) Windows, TRIM => simply make a 25% smaller partition than the size of the SSD? Or does only free space within a partition help?
    2) Windows, No TRIM => ?
    3) RAID0 (intel), TRIM => ?
    4) Raid5, no TRIM => ?

    Thanks very much!

    Best regards

    HPVD
  • Kristian Vättö - Tuesday, December 4, 2012 - link

    With TRIM: Just make sure you have 25% free.

    Without TRIM: Make the volume 25% smaller than the full size.
  • Anand Lal Shimpi - Tuesday, December 4, 2012 - link

    Just create an empty partition of roughly 25% of the NAND capacity on the drive and you're good to go. If you've got TRIM, go ahead and format that partition then delete it.

    Take care,
    Anand

Log in

Don't have an account? Sign up now