• Gvozden Neskovic's avatar
    SIMD implementation of vdev_raidz generate and reconstruct routines · ab9f4b0b
    Gvozden Neskovic authored
    
    
    This is a new implementation of RAIDZ1/2/3 routines using x86_64
    scalar, SSE, and AVX2 instruction sets. Included are 3 parity
    generation routines (P, PQ, and PQR) and 7 reconstruction routines,
    for all RAIDZ level. On module load, a quick benchmark of supported
    routines will select the fastest for each operation and they will
    be used at runtime. Original implementation is still present and
    can be selected via module parameter.
    
    Patch contains:
    - specialized gen/rec routines for all RAIDZ levels,
    - new scalar raidz implementation (unrolled),
    - two x86_64 SIMD implementations (SSE and AVX2 instructions sets),
    - fastest routines selected on module load (benchmark).
    - cmd/raidz_test - verify and benchmark all implementations
    - added raidz_test to the ZFS Test Suite
    
    New zfs module parameters:
    - zfs_vdev_raidz_impl (str): selects the implementation to use. On
      module load, the parameter will only accept first 3 options, and
      the other implementations can be set once module is finished
      loading. Possible values for this option are:
        "fastest" - use the fastest math available
        "original" - use the original raidz code
        "scalar" - new scalar impl
        "sse" - new SSE impl if available
        "avx2" - new AVX2 impl if available
    
    See contents of `/sys/module/zfs/parameters/zfs_vdev_raidz_impl` to
    get the list of supported values. If an implementation is not supported
    on the system, it will not be shown. Currently selected option is
    enclosed in `[]`.
    Signed-off-by: default avatarGvozden Neskovic <neskovic@gmail.com>
    Signed-off-by: default avatarBrian Behlendorf <behlendorf1@llnl.gov>
    Closes #4328
    ab9f4b0b
Makefile.am 164 Bytes