The DPB information is obtained via DOS Fns 32H and 1fH.  It describes a
drive and the medium in the drive.

Virtually all this information can be obtained by reading the boot sector
and invoking a series of other DOS function calls and performing
calculations (see FAT), but the DPB has all the data in one place.

DPBRec
Offset Size Contents
                                                                 
+0      1  bDrvNo       drive number (0=A, 1=B, etc.)
+1      1  bUnitNo      sub-unit number
+2      2  wSectSize    bytes per sector
+4      1  bClustMask   sectors per cluster-1 (max sector in cluster)
+5      1  bClustShift  cluster-to-sector shift (cluster is 2  sectors)
+6      2  wFirstFAT    sector number of first start of first FAT
+8      1  bFatCnt      number of FATs
+9      2  wRootEntries number of entries allowed in root directory
+0bH     2  wFirstData   sector number of cluster #2 (first data cluster)
+0dH     2  wHiClust     total clusters+1 (number of highest cluster)
+0fH     1  bFatSects    sectors needed by a FAT
+10H     2  wRootSec     sector # of start of root directory
+12H     4  pfrDevHdr    address of DevHdrRec for this device driver
+16H     1  bMedia       media descriptor byte
+17H     1  bFirstAccess ffH=medium in drive has not been accessed
+18H     4  pfrNextDPB   Address of next DPBRec (0ffffH if last)
+1CH     2  wNextFree    last allocated cluster
+1EH     2  wFreeCnt     number of free clusters
32               size of a DPBRec

Many of these fields are exactly as in BootSectorRec and BPBRec (which
see).  Notable fields are:

bUnitNo  identifies the drive sub-unit, for device drivers which
support multiple drive types.

wFirstFAT  is the sector number of the first copy of the FAT for this
drive.  It is also the number of "reserved" sectors on the
disk, since the first FAT always follows the last reserved
sector.

wFirstData  saves some calculations when converting a cluster number (from
the FAT or a DirEntryRec) into a cluster number.  Data for a
FAT entry of (0)002H starts at this sector number.  In
general, the data for cluster number n starts at sector number
wFirstData + ((n-2)*(bClustMask+1)).

bFirstAccess  00H means this DPB has been accessed.
ffH means this DPB has NOT been accessed and must be rebuilt.

pfrNextDPB  is the FAR address of the next DPBRec in the chain; this
address is FFFF:FFFF in the last DPBRec.  The address of the
first DBPRec can be found via 52H (get ListOfLists).

wNextFree  is used by DOS in allocating clusters.  DOS will attempt to
allocate at this cluster (and then bump wNextFree up) in the
hopes of making contiguous allocations.  This field was not
documented before 5.0.

wFreeCnt  MAY contain the current number of unallocated clusters.  But
DOS is NOT required to maintain a correct calculation here.
Use fn 36H to learn how much space is available (that fn
triggers ram-resident Undelete Delete Sentry to purge old
files).  If this field is ffffH, it has not been calculated
yet.  This field was not documented before 5.0.

Notes: The undocumented DOS fn 53H converts a BPB (as supplied by a
device driver) into a DPB.

See Also: DOS fn 53H (translate BPB to DPB)
- -

DPB: Drive Parameter Block