mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-29 23:53:55 +08:00
0a82a6239b
async_raid6_2data_recov() recovers two data disk failures async_raid6_datap_recov() recovers a data disk and the P disk These routines are a port of the synchronous versions found in drivers/md/raid6recov.c. The primary difference is breaking out the xor operations into separate calls to async_xor. Two helper routines are introduced to perform scalar multiplication where needed. async_sum_product() multiplies two sources by scalar coefficients and then sums (xor) the result. async_mult() simply multiplies a single source by a scalar. This implemention also includes, in contrast to the original synchronous-only code, special case handling for the 4-disk and 5-disk array cases. In these situations the default N-disk algorithm will present 0-source or 1-source operations to dma devices. To cover for dma devices where the minimum source count is 2 we implement 4-disk and 5-disk handling in the recovery code. [ Impact: asynchronous raid6 recovery routines for 2data and datap cases ] Cc: Yuri Tikhonov <yur@emcraft.com> Cc: Ilya Yanok <yanok@emcraft.com> Cc: H. Peter Anvin <hpa@zytor.com> Cc: David Woodhouse <David.Woodhouse@intel.com> Reviewed-by: Andre Noll <maan@systemlinux.org> Acked-by: Maciej Sosnowski <maciej.sosnowski@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
7 lines
260 B
Makefile
7 lines
260 B
Makefile
obj-$(CONFIG_ASYNC_CORE) += async_tx.o
|
|
obj-$(CONFIG_ASYNC_MEMCPY) += async_memcpy.o
|
|
obj-$(CONFIG_ASYNC_MEMSET) += async_memset.o
|
|
obj-$(CONFIG_ASYNC_XOR) += async_xor.o
|
|
obj-$(CONFIG_ASYNC_PQ) += async_pq.o
|
|
obj-$(CONFIG_ASYNC_RAID6_RECOV) += async_raid6_recov.o
|