tl;dr: If you see weird errors when using or formatting a drive internally on a Mac (especially after upgrading to a newer and/or faster SATA hard drive), it could mean the SATA cable needs to be replaced.
Who would've thought such a tiny cable could cause so many problems?
I have an older Mac mini (mid-2011 i5 model), and I use it as a general media server and network backup. It handles Time Machine backups for two other Macs, it has about 20 TB of external storage connected, and I also use it as a 'home base' to store all my Dropbox, iCloud, and Photos content locally, and store an extra Time Machine backup of all that. I'm a little nutty about backups... but I haven't lost a file in two decades and I don't want to start now ;-).
Anyways, my digital cruft has grown to the point it wouldn't fit on a 1 TB main drive anymore, so I decided to upgrade the Mac mini's internal drive to a 2 TB SSD, hopefully giving me another 2-4 years of life out of that computer before I have to find a new backup solution with more than 2 TB of storage.
I've replaced the drive a couple times before, and never had any issues. I'd plug the new SATA drive into my USB-to-SATA adapter, clone the disk using Disk Utility (now using Carbon Copy Cloner as of macOS 10.12, since Disk Utility won't restore APFS volumes cleanly anymore), and then use the iFixIt guide for replacing the hard drive in a 2011 Mac mini.
This time, I bought a 2TB SATA III (6 Gb/s) drive from Crucial, to replace an older SATA II Mushkin drive. The drive formatted via the USB-to-SATA adapter, and I cloned the disk successfully using CCC. I replaced the internal drive, and booted the Mini... and it wouldn't boot off the new drive!
So I used system restore (⌘-R while booting the Mac), and opened Disk Utility. It saw the new drive, and could mount and unmount it.
But when I tried to switch the startup disk, and it popped a message saying the disk could not be 'blessed'. I tried opening the terminal and manually blessing the disk with the bless
command, but that failed.
Since I had two backups of the old drive, I decided to try re-formatting the new drive while it was inside the Mac mini. Many times (erasing and partitioning as both 'APFS' and 'Mac OS Extended (Journaled)'), it would start the process, then run into an error. I actually hit a few different errors, depending on the type of format I was attempting, including:
# While restoring in Disk Utility... at the very end.
The volume on device dev disk0(source volume) is not of type Apple_HFS or Apple_UFS
# When trying to partition the drive while it was in the Mac.
An internal error occurred while preflighting your volume for APFS conversion
# When trying to erase the disk in Terminal with `diskutil eraseDisk`.
Error: 12: POSIX reports: Cannot allocate memory
There were a few other errors, too... but eventually in all my Google searches, I found this incredibly helpful answer from iFixIt's forums. User Dan/@danj said:
I'm thinking the drive cable has degraded so the faster data flows with the SSD is having problems. I've had a few that needed replacing.
I realized that I've now replaced the hard drive in this Mac mini 3 times... and the tiny flex cable and connector on the cable is very fragile. It would probably last forever if you never touched it, but having to pull it and put it back in 3 times could definitely make it less-than-reliable.
So I went on Amazon and found a Mac mini hard drive cable upgrade kit with part number 821-1500-A for a little over $10. I ordered it, it arrived the next day, I swapped the cable, and now I'm having no trouble at all with the new SATA III Crucial drive.
Moral of the story? If you are upgrading your hard drive in a Mac (Mini, MacBook Pro, etc.), and the new drive has mysterious problems that don't happen when it's plugged in elsewhere, consider replacing the SATA cable!
(Unfortunately, newer Macs don't have replaceable hard drives anymore... so this might be a moot point in the future. I hope not.)
Comments
One other cause of this is poorer shielding in older cables - the hack that's been used historically is to wrap the flex cable in carefully cut aluminum foil. I've done this on a few older models that shipped with SATA II drives (specifically, the 17" MacBookPro 2009 models) with good success.
A little late on my comment, but does this have anything to do with the SATA adapter supporting 512bytes vs 4k byte sector size (Advanced Format)?