Hfs Plus Article Index for
Hfs
Website Links For
Plus
 

Information About

Hfs Plus




  Full Name Hierarchical File System Plus
  Developer Apple
  Introduction Os Mac OS 81
  Introduction Date January 19, 1998
  Partition Id <tt>Apple_HFS</tt> ( Apple Partition Map )<br><tt>0xAF</tt> ( MBR )<br><tt>Apple_HFSX</tt> ( Apple Partition Map ) when HFSX <br><tt>48465300-0000-11AA-<br>AA11-00306543ECAC</tt> ( GPT )
  Directory Struct B-tree
  File Struct B-tree
  Bad Blocks Struct B-tree
  Max Files No Unlimited
  Max File Size 8 EiB
  Max Filename Size 255 characters (255 UTF-16 encoding units, normalized to Apple-modified variant of Unicode Normalization Format D)
  Max Volume Size 16 EiB
  Filename Character Set Unicode , any character, including NUL OS APIs may limit some characters for legacy reasons
  Dates Recorded access, attributes modified, backed up, contents modified, created
  Date Range January 1 1904 - February 6 2040
  Date Resolution 1s
  Forks Streams Yes
  Attributes Color (3 bits, all other flags 1 bit), locked, custom icon, bundle, invisible, alias, system, stationery, inited, no INIT resources, shared, desktop
  File System Permissions Unix permissions, ACLs ( Mac OS X V104 onward)
  Compression No
  Encryption No, although per- Home Directory AES using HFS+ formatted dmg volumes is possible using FileVault in Mac OS X V103 onward


HFS Plus or '''HFS+''' is a File System developed by Apple Inc. to replace their Hierarchical File System (HFS) as the primary file system used on Macintosh computers. It is also one of the formats used by the IPod digital music player. HFS Plus is also referred to as '''HFS Extended''' and '''Mac OS Extended'''. During development, Apple referred to this filesystem with the codename '''Sequoia'''.1

HFS Plus is an improved version of HFS, supporting much larger files (block addresses are 32-bit length instead of 16-bit) and using Unicode (instead of Mac OS Roman ) for naming the items (files, folders) – names which are also normalized to NFD .2 HFS Plus permits filenames up to 255 UTF-16 characters in length, and n-forked files similar to NTFS , though almost no software takes advantage of forks other than the Data Fork and Resource Fork . HFS Plus also uses a full 32-bit allocation mapping table, rather than HFS's 16 bits. This was a serious limitation of HFS, meaning that no disk could support more than 65,536 allocation blocks under HFS. When disks were small, this was of little consequence, but as they started to approach the 1 GB mark, it meant that the smallest amount of space that any file could occupy (a single allocation block) became excessively large, wasting significant amounts of disk space. For example, on a 1 GB disk, the allocation block size under HFS is 16 KB, so even a 1 byte file would take up 16 KB of disk space.



HISTORY


HFS Plus was introduced with the January 19 1998 release of Mac OS 8.1 .3 However its first appearance, as a beta filesystem, was in the never-released Copland OS betas.

With the release of the 10.2.2 update on November 11 2002 , Apple added optional Journaling features to HFS Plus for improved data reliability. These features were easily accessible in Mac OS X Server, but only accessible through the command line in the standard desktop client.4 With Mac OS X V10.3 , all HFS Plus volumes on all Macs are set to be journaled by default. Within the system, an HFS Plus volume with a journal is identified as HFSJ.

10.3 also introduced another version of HFS Plus called HFSX. HFSX volumes are almost identical to HFS Plus volumes, except that they are never surrounded by the HFS Wrapper that is typical of HFS Plus volumes and they support Case Sensitivity for file and folder names. HFSX volumes can be recognised by two entries in the Volume Header, a value of HX in the signature field and 5 in the version field.

With 10.4 , Apple added support for Inline Attribute Data records, something that had been a part of the Mac OS X implementation of HFS Plus since at least 10.0 , but always marked as "reserved for future use".5 Until the release of Mac OS X Server 10.4 , HFS Plus only supported the standard UNIX File System Permissions , however 10.4 introduced support for Access Control List -based file security, which is designed to be fully compatible with the file permission system used by Microsoft Windows XP and Windows Server 2003 .


DESIGN


HFS Plus volumes are divided into sectors (called logical blocks in HFS), that are usually 512 bytes in size. These sectors are then grouped together into allocation blocks which can contain one or more sectors; the number of allocation blocks depends on the total size of the volume. HFS Plus uses a larger value to address allocation blocks than HFS, 32 bits rather than 16 bits; this means it can access 4,294,967,296 (=2^{32}) allocation blocks rather than the 65,536 (=2^{16}) allocation blocks available to HFS.

Typically an HFS Plus volume is embedded inside an HFS Wrapper, although this is becoming less prevalent. The wrapper was designed for two purposes; it allowed Macintosh computers without HFS Plus support in their ROM to boot HFS Plus volumes and it also was designed to help users transition to HFS Plus by including a minimal, bootable HFS volume with a read-only file called ''Where_have_all_my_files_gone?'', explaining to users with versions of the Mac OS without HFS Plus, that the volume requires a system with HFS Plus support. The original HFS volume contains a signature and an offset to the embedded HFS Plus volume within its volume header. All allocation blocks in the HFS volume which contain the embedded volume are mapped out of the HFS allocation file as ''bad blocks''.

There are nine structures that make up a typical HFS Plus volume:

# Sectors 0 and 1 of the volume are HFS Boot Blocks . These are identical to the boot blocks in an HFS volume. They are part of the HFS wrapper.
# Sector 2 contains the Volume Header equivalent to the Master Directory Block in an HFS volume. The Volume Header stores a wide variety of data about the volume itself, for example the size of allocation blocks, a timestamp that indicates when the volume was created or the location of other volume structures such as the Catalog File or Extent Overflow File. The Volume Header is always located in the same place.
# The Allocation File which keeps track of which allocation blocks are free and which are in use. It is similar to the Volume Bitmap in HFS, each allocation block is represented by one bit. A zero means the block is free and a one means the block is in use. The main difference with the HFS Volume Bitmap, is that the Allocation File is stored as a regular file, it does not occupy a special reserved space near the beginning of the volume. The Allocation File can also change size and does not have to be stored contiguously within a volume.

# The second to last sector contains the Alternate Volume Header equivalent to the Alternate Master Directory Block of HFS.
# The last sector in the volume is reserved for use by Apple. It is used during the computer manufacturing process.


OTHER OPERATING SYSTEMS

Like with NTFS on Linux , there has been some success in porting HFS+ to Linux, at least in read-only mode, but must be Built into the kernel, or Modularized for a particular kernel. [http://www.ardistech.com/hfsplus/
Most end users use the kernels provided for in their distributions, which vary in their HFS+ support, and usage of HFS+ on the IPod has notably caused some demand for this functionality to be built in.


SEE ALSO



REFERENCES







EXTERNAL LINKS