32GB iPhone 7 Has 8 Times Slower Storage Performance Than 128GB Model (thenextweb.com)
An anonymous reader quotes a report from The Next Web: Apple isn't telling you everything about its phones. Few weeks back, GSMArena reported that the 32GB iPhone 7 and 7 Plus had significantly slower storage performance than the 128GB and 256GB models of the device. In a new video, Unbox Therapy's Lew Hilsenteger conducted a series of speed tests that confirm the discrepancy in storage speeds between the different configurations of Apple's phone -- and it turns out the 32GB iPhone is about eight times slower than the larger capacity storage version of the device. For his first test, Hilsenteger used the free PerformanceTest Mobile app to compare the read and write speeds of the iPhone. While there was little difference between the read speeds of the 32GB and 128GB models, there's a huge disparity when it comes to write speed. The 32GB iPhone writes at 42MB per second, which is nearly eight times slower than the 128GB version's 341MB per second. Hilsenteger then performed a real-world speed test, which included transferring movies from a MacBook to the iPhone using a USB cable. While the 256GB model took two minutes and 34 seconds to complete the 4.2GB file transfer, the 32GB iPhone 7 needed a total of three minutes and 40 seconds for the same transmission.
All modern NAND flash memory does "quasi-RAID". Writes are split across all chips in parallel, so the larger the capacity, the more chips, the faster the write speed. Check out any USB thumb drive with various capacities - larger models of the same line will be faster.
That said, 128GB should only be 4 times faster than 32GB, so if these figures are correct then the 32GB units are also using lower spec memory.
foo mane padme hum
Bingo. One NAND die is not all that fast; it's when you put multiple dies together - either via multiple packages or, in the case of the iPhone, layering - that you get the absurdly high transfer rates solid state NAND storage is known for.
AnandTech's SSD Anthology even 7 years later is still the single best primer on the subject of flash storage: http://www.anandtech.com/show/2738/6. It goes over how this concept works in greater detail.
The one thing you won't find in there though, but is similarly important for understanding smartphone storage, is SLC caching. Most phones these days are using Triple Level (TLC) storage, which means storing 3 bits in a single cell. This greatly brings down the cost per byte of NAND, however it makes it slower to program and erase. As a result the iPhone (and most other phones) have an area of NAND that is pseudo-single level (SLC), which only stores 1 bit per cell. The purpose of the pseudo-SLC area is to serve as a cache; quickly absorb and coalesce writes, and then write them out to the slower TLC NAND transparently to the user.
The size of the pseudo-TLC area is generally proportional to the size of the total NAND. That means the larger iPhones have a larger pseudo-SLC area. And if you understand caching, then you understand what happens when you exceed that cache size. Most likely some of the tests in TFA were big enough to overflow the pseudo-SLC on the 32GB phone, but not on the larger model. Which is why there's such a large performance difference on some tests, but not in other things like transferring files.
Unless Apple is doing some sort of quasi RAID like read/write access against all available memory chips
"Quasi RAID" is actually how all SSDs work. The controller spreads the writes across multiple flash chips. This is why NVMe is so much faster, the OS can give the SSD controller thousands of outstanding IO requests instead of the max of 32 with SATA. The iPhone uses a single eMMC flash chip which integrates the controller and the NAND on one die. The eMMC chip will do the same thing, only across flash cells instead of entire chips.
In the end, all this comes down to is the fancy 128/256GB eMMC flash comes with a nicer onboard controller than the 32GB one, hence higher bandwidth. That said, with such a huge difference there is no doubt Apple ordered the cheapest 32GB flash they could find. You probably can find the same eMMC chips in a $50 cheap Chinese Android phone. For a $500+ phone they should be paying the extra $2 for higher bandwidth 32GB eMMC chips.
That depends 100% on the sort of controllers & memory layouts that are involved.
Do you have specific information that Apple does this? I don't.
Given that:
- nearly all modern smartphone/tablets/etc. do no go the extra headache to implement some weird custom solution for their mass storage.
- instead they all go for simple, standard, cheap of the shelf technology.
- [ BTW: eMMC (embed MMC - i.e.: an SD Card, without the plastic package, but directly available over an MMC bus) seems to be the most frequent solution ]
- Most of the flash anywhere, including thousands of SD Cards on the market right now, follow the exact same tendency: bigger model have more chips and can spread their write/erases among more chips ("quasi-RAID") giving better performance. That's why the "Class 10 UHS III" SDXC cards are only available on the bigger models, smaller models are slower. Same difference between microSDXC and regular SDXC cards (bigger cards can pack more chips and you have a greater choice of faster cards. At the micro level, it's only 128GB and above capacity that usually come with "Class 10 UHS III").
- Even more gory details if you care to read the benchmarked read/write speeds of each card. (again, more chips - found in larger package or bigger capacity - manage higher write/erase speeds).
Given all the above, there's high expectation that iPhones are following the trend.. :
But hey instead of speculating and calling each other names, let's check actual real heardware
iFixit, Chipworks, SK Hynix Datasheet
What a surprise~ iPhone are exactly everyone else~ and source cheap of the shelf parts instead of re-inventing the wheel~~ Who would have though this~~~
iFixit's 32Gb iPhone use H23QEG8VG2ACS - a stack of 4 chips, with 256Gibits total (or 32GiB if used alone like in this phone).
Chipworks's 128GB iPhone use - a stack of 8 chips, with 1024Gibits total (or 128GiB when used in alone configuration)
So without even taking into account anything else, 32GB iPhone can only spread their writes among half of the chips available to a 128GB iPhone.
So they already start with a 50% malus at the hardware level.
That said, 128GB should only be 4 times faster than 32GB, so if these figures are correct then the 32GB units are also using lower spec memory.
Nope. At all. Like you said it entirely depends on the flash configuration. 128 isn't necessarily 4x more chips than 32.
Some constructor would go for 8x more chips of half the capacity.
In Apple case, they went for 2x more chips at 2x more capacity (more expensive but faster, enabling them to have bigger marging on the smaller/slower 32GB).
Which again goes back to the point of what I have posted... and this article.
Which goes back to the answer which you were given:
- YES, nearly every last constructor of flash is doing "quasi-RAID", i.e.: stacking/bonding more chips in the same package and spreading the write/erase among that.
That single fact can account for a huge part of the difference between models.
Then the thing is designed by Apple.
They run iOS on it. i.e.: the same "Darwin" core ( Mach microkernel + BSD monolithic kernel + BSD user space) as Mac OS X, only with a different interface.
They probably *still* use the same asinine file system as always HFS+
And that one is completely inadequate for flash.
It's a classical "inplace" writing file system.
This dramatically increase the "write amplification" typical with random-writes flash media. (each time you need to change some data, you would need to erase and re-write a whole block).
This probably *also* accounts for the dramatic performance
"Sufficiently advanced satire is indistinguishable from reality." - [Tips: 1DrYakQDKCQ6y52z6QbnkxHXAocMZJE61o ]