]> git.proxmox.com Git - mirror_zfs.git/commit
Avoid memory copy when verifying raidz/draid parity
authorAlexander Motin <mav@FreeBSD.org>
Tue, 5 Jul 2022 23:27:29 +0000 (19:27 -0400)
committerGitHub <noreply@github.com>
Tue, 5 Jul 2022 23:27:29 +0000 (16:27 -0700)
commit74230a5bc1be6e5e84a5f41b26f6f65a155078f0
tree4203db4b1a46a8ab4a900a6bdd893fd3d02c21de
parent1ac7d194e5ca31d5284e410a87ad9f9669a7f5b5
Avoid memory copy when verifying raidz/draid parity

Before this change for every valid parity column raidz_parity_verify()
allocated new buffer and copied there existing data, then recalculated
the parity and compared the result with the copy.  This patch removes
the memory copy, simply swapping original buffer pointers with newly
allocated empty ones for parity recalculation and comparison. Original
buffers with potentially incorrect parity data are then just freed,
while new recalculated ones are used for repair.

On a pool of 12 4-wide raidz vdevs, storing 1.5TB of 16MB blocks, this
change reduces memory traffic during scrub by 17% and total unhalted
CPU time by 25%.

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Alexander Motin <mav@FreeBSD.org>
Sponsored-By: iXsystems, Inc.
Closes #13613
module/zfs/vdev_raidz.c