| TCPLAY(8) | System Manager's Manual | TCPLAY(8) | 
tcplay — tool to
    manage TrueCrypt volumes
| tcplay | -c-ddevice [-g]
      [-z] [-w]
      [-apbkdf_hash]
      [-bcipher]
      [-fkeyfile_hidden]
      [-kkeyfile]
      [-xpbkdf_hash]
      [-ycipher] | 
| tcplay | -i-ddevice [-e]
      [-fkeyfile_hidden]
      [-kkeyfile]
      [-ssystem_device]
      [--fde]
      [--use-backup] | 
| tcplay | -jmapping | 
| tcplay | -mmapping-ddevice
      [-e] [-fkeyfile_hidden] [-kkeyfile] [-ssystem_device] [--fde]
      [--use-backup] | 
| tcplay | --modify-ddevice [-kkeyfile] [--new-keyfilenew_keyfile]
      [--new-pbkdf-prfpbkdf_hash]
      [-ssystem_device]
      [--fde] [--use-backup]
      [-w] | 
| tcplay | --modify-ddevice [-kkeyfile]--restore-from-backup-hdr[-w] | 
| tcplay | -umapping | 
| tcplay | -h|-v | 
The tcplay utility provides full support
    for creating and opening/mapping TrueCrypt-compatible volumes. It supports
    the following commands, each with a set of options detailed further
  below:
-c,
    --create--device.-h,
    --help-i,
    --info--device.-j
    mapping,
    --info-mapped=mapping--modify-m
    mapping,
    --map=mapping--device as a dm(4) mapping
      called mapping. The mapping
      argument should not contain any spaces or special characters.-u
    mapping,
    --unmap=mapping-v,
    --versionOptions common to all commands are:
-d
    device,
    --device=device-f
    keyfile_hidden,
    --keyfile-hidden=keyfile_hidden--keyfile option has to be used. This option
      can appear multiple times; if so, multiple keyfiles will be used. This
      option is not valid in the --modify mode.-k
    keyfile,
    --keyfile=keyfileAdditional options for the --create
    command are:
-a
    pbkdf_hash,
    --pbkdf-prf=pbkdf_hash--pbkdf-prf=help.-b
    cipher,
    --cipher=cipher--cipher=help.-g,
    --hidden--keyfile-hidden. The user will be
      prompted for the size of the hidden volume interactively.-w,
    --weak-keys-x
    pbkdf_hash,
    --pbkdf-prf-hidden=pbkdf_hash--hidden. If no algorithm is specified, the same
      as for the outer volume will be used. To see which algorithms are
      supported, specify
      --pbkdf-prf-hidden=help.-y
    cipher,
    --cipher-hidden=cipher--hidden. If no cipher is specified, the same
      as for the outer volume will be used. To see which algorithms are
      supported, specify
      --cipher-hidden=help.-z,
    --insecure-eraseAdditional options for the --info,
    --map and --modify commands
    are:
-e,
    --protect-hidden--info and --map
    commands.-s
    system_device,
    --system-encryption=system_device--device option will point at the actual encrypted
      partition, while the system_device argument will
      point to the parent device (i.e. underlying physical disk) of the
      encrypted partition.--fde--device option should point to the whole disk
      device, not to any particular partition. The resultant mapping will cover
      the whole disk, and will not appear as separate partitions. To access
      individual partitions after mapping, kpartx(8) can be
      used.--use-backuptcplay
      to use the backup headers, which are located at the end of the device, to
      access the volume.Additional options only for the --modify
    command are:
--new-pbkdf-prf=pbkdf_hash--pbkdf-prf=help.--new-keyfile=keyfile--restore-from-backup-hdr--new-pbkdf-prf nor
      --new-keyfile should be specified. This option
      implies --use-backup. Use this option to restore
      the volume headers from the backup header.TrueCrypt limits passphrases to 64 characters (including the
    terminating null character). To be compatible with it,
    tcplay does the same. All passphrases (excluding
    keyfiles) are trimmed to 64 characters. Similarly, keyfiles are limited to a
    size of 1 MB, but up to 256 keyfiles can be used.
tcplay offers plausible deniability.
    Hidden volumes are created within an outer volume. Which volume is accessed
    solely depends on the passphrase and keyfile(s) used. If the passphrase and
    keyfiles for the outer volume are specified, no information about the
    existance of the hidden volume is exposed. Without knowledge of the
    passphrase and keyfile(s) of the hidden volume its existence remains
    unexposed. The hidden volume can be protected when mapping the outer volume
    by using the --protect-hidden option and specifying
    the passphrase and keyfiles for both the outer and hidden volumes.
Create a new TrueCrypt volume on /dev/vn0 using the cipher cascade of AES and Twofish and the Whirlpool hash algorithm for PBKDF2 password derivation and two keyfiles, one.key and two.key:
tcplay
  --create
  --device=/dev/vn0
  --cipher=AES-256-XTS,TWOFISH-256-XTS
  --pbkdf-prf=whirlpool
  --keyfile=one.key
  --keyfile=two.keyMap the outer volume on the TrueCrypt volume on /dev/vn0 as truecrypt1, but protect the hidden volume, using the keyfile hidden.key, from being overwritten:
tcplay
  --map=truecrypt1
  --device=/dev/vn0
  --protect-hidden
  --keyfile-hidden=hidden.keyMap the hidden volume on the TrueCrypt volume on /dev/vn0 as truecrypt2, using the keyfile hidden.key:
tcplay
  --map=truecrypt2
  --device=/dev/vn0
  --keyfile=hidden.keyMap and mount the volume in the file secvol on Linux:
tcplay
  --map=secv
  --device=/dev/loop1/dev/mapper/secv /mntSimilarly on DragonFly:
tcplay
  --map=secv
  --device=/dev/vn1/dev/mapper/secv /mntUnmapping the volume truecrypt2 on both Linux and DragonFly after unmounting:
Or alternatively:
tcplay
  --unmap=truecrypt2A hidden volume whose existance can be plausibly denied and its outer volume can for example be created with
tcplay
  --create --hidden
  --device=/dev/loop0
  --cipher=AES-256-XTS,TWOFISH-256-XTS
  --pbkdf-prf=whirlpool
  --keyfile=one.key
  --cipher-hidden=AES-256-XTS
  --pbkdf-prf-hidden=whirlpool
  --keyfile-hidden=hidden.keytcplay will prompt the user for the
    passphrase for both the outer and hidden volume as well as the size of the
    hidden volume inside the outer volume. The hidden volume will be created
    inside the area spanned by the outer volume. The hidden volume can
    optionally use a different cipher and prf function as specified by the
    --cipher-hidden and
    --pbkdf-prf-hidden options. Which volume is later
    accessed depends only on which passphrase and keyfile(s) are being used, so
    that the existance of the hidden volume remains unknown without knowledge of
    the passphrase and keyfile it is protected by since it is located within the
    outer volume. To map the outer volume without potentially damaging the
    hidden volume, the passphrase and keyfile(s) of the hidden volume must be
    known and provided alongside the --protect-hidden
    option.
A disk encrypted using full disk encryption can be mapped using
tcplay
  --map=tcplay_sdb
  --device=/dev/sdb
  --fdeTo access individual partitions on the now mapped disk, the following command will generate mappings for each individual partition on the encrypted disk:
The tcplay utility appeared in
    DragonFly 2.11.
Alex Hornung
| July 29, 2013 | Debian |