So you purchased some OEM rebranded HDD or SSDs secondhand.
It was a SUPER great deal, right?
These likely originated from major a storage vendor such as NetApp, EMC (Fuck EMC), or even HP or Dell.
You’re excited the night your order shows up; Right up until you attach one of these megacheap deals
to your host….
Only to discover the drive that you’ve purchased will not initialize….
$ sudo diskinfo -v da7
da7
520# sectorsize1600321314800# mediasize in bytes (1.5T)3077540990# mediasize in sectors4160# stripesize0# stripeoffset191568# Cylinders according to firmware.255# Heads according to firmware.63# Sectors according to firmware. HITACHI HUSMM141CLAR1600 # Disk descr. 0SYBE15A # Disk ident. Yes # TRIM/UNMAP support0# Rotation rate in RPM Not_Zoned # Zone Mode
The most frequent cause of this minor panic-laden moment is that the drive was formatted by the factory with a non standard sector size of 520B or 528B.
refused to initialized drive other than the normal 512B or 4Kb. I read online the reason that these drive are formatted that way is due to some proprietary software that these vendor uses needs the additional sector size for some fancy parity stuff.
OK, let’s go to the basics. 520b and 528b disks have existed for ages, probably since the 70s.
They probably were more common than 512-byte sector disks until the PC revolution.
The extra bytes can store all manner of things, such as checksums, keys (for CKD data), metadata that links the content (not uncommon in databases), and so on. There are also block sizes that are a little bigger than 4K, for the same reasons. Quite a few industrial-strength disk systems use them.
Today, many industrially used disks are instead formatted using T10-DIF, which also stores checksums on disk. That is kinda… sorta… similar to having 520-byte blocks, but… only kinda sorta.
Also, a lot of file systems (such as ZFS) use checksums, but they do something smarter than 520-byte blocks or T10-DIF, they store the checksums AWAY from the data, thus allowing the detection of a whole block write going missing
(data and checksum).
All these technologies add real value, and aren’t just a scam to charge customers more.
If you don’t understand what sectors, logical blocks, and physical blocks are, you should probably read the Wikipedia pages about disks….
But, Really quick: At the interface level, the drivers read/write whole logical blocks.
Some disks internally aggregate logical blocks of 512 bytes into physical blocks of 4096 blocks.
The word sector really shouldn’t be used at the interface level, as it can easily be confused with
Logical block
(the unit of atomic data transfer)
and
Physical blocks
The unit of atomic IO.
I know of no common open source file system that can make use of disks with block sizes other than 512 or 4096 bytes. Candidates include ZFS, UFS, ext2/3/4, XFS..
After trying to attach the drive in every possible system, through every single controller you have, and still are having no luck, you probably think you’re SOL.
Luckily there is a way to reconfigure the drive: Low Level Re-Formatting #
This will coerce your hipster drive to use a sector size of 512B.
Look in /var/log/messages after booting, and you will hopefully see useful information:
Mar 9 08:08:54 vhc-carthage kernel: sd 6:0:7:0: [sdh] Attached SCSI disk
Mar 9 08:08:57 vhc-carthage kernel: ...ready
Mar 9 08:08:57 vhc-carthage kernel: sd 6:0:8:0: [sdi] Unsupported sector size 520.
Mar 9 08:08:57 vhc-carthage kernel: sd 6:0:8:0: [sdi]0 512-byte logical blocks: (0 B/0 B)Mar 9 08:08:57 vhc-carthage kernel: sd 6:0:8:0: [sdi] 520-byte physical blocks
Mar 9 08:08:57 vhc-carthage kernel: sd 6:0:8:0: [sdi] Write Protect is off
Mar 9 08:08:57 vhc-carthage kernel: sd 6:0:8:0: [sdi] Write cache: disabled, read cache: enabled, supports DPO and FUA
Mar 9 08:08:57 vhc-carthage kernel: sd 6:0:8:0: [sdi] Unsupported sector size 520.
Mar 9 08:08:57 vhc-carthage kernel: sd 6:0:8:0: [sdi] Attached SCSI disk
Sweet! Lets get to rippin off them skinny jeans!
# yum install sg3_utils# sg_scan -i/dev/sg8: scsi6 channel=0id=7lun=0NETAPP X287_S15K5288A15 NA00 [rmb=0cmdq=1pqual=0pdev=0x0]/dev/sg9: scsi6 channel=0id=8lun=0NETAPP X287_S15K5288A15 NA00 [rmb=0cmdq=1pqual=0pdev=0x0]Now you should format the offending drive using the "sg_format" command.
[root@azev /]# sg_format --format --size=512 /dev/sg8NETAPP X287_S15K5288A15 NA00 peripheral_type: disk [0x0]Mode Sense (block descriptor) data, prior to changes:
Number of blocks=573653847[0x22314357]Block size=520[0x208]A FORMAT will commence in 10 seconds
ALL data on /dev/sg8 will be DESTROYED
Press control-C to abort
It is pretty simple, and after the format is completed, you should have no problem initializing the drive.
However, some drives require a powercycle before successful usage.
Some people argue that the custom firmware on the drive is set to work with sector size 520B or 528B, but during my benchmark, the drive performance was pretty much on par with the normal retail channel.
Hopefully you find this information useful next time you come across a drive with other than 512B sector size.