• Artur Paszkiewicz's avatar
    raid5-ppl: load and recover the log · 4536bf9b
    Artur Paszkiewicz authored
    Load the log from each disk when starting the array and recover if the
    array is dirty.
    
    The initial empty PPL is written by mdadm. When loading the log we
    verify the header checksum and signature. For external metadata arrays
    the signature is verified in userspace, so here we read it from the
    header, verifying only if it matches on all disks, and use it later when
    writing PPL.
    
    In addition to the header checksum, each header entry also contains a
    checksum of its partial parity data. If the header is valid, recovery is
    performed for each entry until an invalid entry is found. If the array
    is not degraded and recovery using PPL fully succeeds, there is no need
    to resync the array because data and parity will be consistent, so in
    this case resync will be disabled.
    
    Due to compatibility with IMSM implementations on other systems, we
    can't assume that the recovery data block size is always 4K. Writes
    generated by MD raid5 don't have this issue, but when recovering PPL
    written in other environments it is possible to have entries with
    512-byte sector granularity. The recovery code takes this into account
    and also the logical sector size of the underlying drives.
    Signed-off-by: default avatarArtur Paszkiewicz <artur.paszkiewicz@intel.com>
    Signed-off-by: default avatarShaohua Li <shli@fb.com>
    4536bf9b
raid5-ppl.c 34 KB