mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-25 01:16:34 +03:00
a73c94934f
Currently, the ICP contains accelerated assembly code to be used specifically on CPUs with AES-NI enabled. This code makes heavy use of the movaps instruction which assumes that it will be provided aes keys that are 16 byte aligned. This assumption seems to hold on Illumos, but on Linux some kernel options such as 'slub_debug=P' will violate it. This patch changes all instances of this instruction to movups which is the same except that it can handle unaligned memory. This patch also adds a few flags which were accidentally never given to the assembly compiler, resulting in objtool warnings. Reviewed by: Gvozden Neskovic <neskovic@gmail.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Nathaniel R. Lewis <linux.robotdude@gmail.com> Signed-off-by: Tom Caputi <tcaputi@datto.com> Closes #7065 Closes #7108
92 lines
2.2 KiB
Makefile
92 lines
2.2 KiB
Makefile
src = @abs_top_srcdir@/module/icp
|
|
obj = @abs_builddir@
|
|
|
|
MODULE := icp
|
|
|
|
TARGET_ASM_DIR = @TARGET_ASM_DIR@
|
|
|
|
ifeq ($(TARGET_ASM_DIR), asm-x86_64)
|
|
ASM_SOURCES := asm-x86_64/aes/aeskey.o
|
|
ASM_SOURCES += asm-x86_64/aes/aes_amd64.o
|
|
ASM_SOURCES += asm-x86_64/aes/aes_intel.o
|
|
ASM_SOURCES += asm-x86_64/modes/gcm_intel.o
|
|
ASM_SOURCES += asm-x86_64/sha1/sha1-x86_64.o
|
|
ASM_SOURCES += asm-x86_64/sha2/sha256_impl.o
|
|
ASM_SOURCES += asm-x86_64/sha2/sha512_impl.o
|
|
endif
|
|
|
|
ifeq ($(TARGET_ASM_DIR), asm-i386)
|
|
ASM_SOURCES :=
|
|
endif
|
|
|
|
ifeq ($(TARGET_ASM_DIR), asm-generic)
|
|
ASM_SOURCES :=
|
|
endif
|
|
|
|
obj-$(CONFIG_ZFS) := $(MODULE).o
|
|
|
|
asflags-y := -I$(src)/include
|
|
asflags-y += $(ZFS_MODULE_CFLAGS) $(ZFS_MODULE_CPPFLAGS)
|
|
ccflags-y := -I$(src)/include
|
|
ccflags-y += $(ZFS_MODULE_CFLAGS) $(ZFS_MODULE_CPPFLAGS)
|
|
|
|
$(MODULE)-objs += illumos-crypto.o
|
|
$(MODULE)-objs += api/kcf_cipher.o
|
|
$(MODULE)-objs += api/kcf_digest.o
|
|
$(MODULE)-objs += api/kcf_mac.o
|
|
$(MODULE)-objs += api/kcf_miscapi.o
|
|
$(MODULE)-objs += api/kcf_ctxops.o
|
|
$(MODULE)-objs += core/kcf_callprov.o
|
|
$(MODULE)-objs += core/kcf_prov_tabs.o
|
|
$(MODULE)-objs += core/kcf_sched.o
|
|
$(MODULE)-objs += core/kcf_mech_tabs.o
|
|
$(MODULE)-objs += core/kcf_prov_lib.o
|
|
$(MODULE)-objs += spi/kcf_spi.o
|
|
$(MODULE)-objs += io/aes.o
|
|
$(MODULE)-objs += io/edonr_mod.o
|
|
$(MODULE)-objs += io/sha1_mod.o
|
|
$(MODULE)-objs += io/sha2_mod.o
|
|
$(MODULE)-objs += io/skein_mod.o
|
|
$(MODULE)-objs += os/modhash.o
|
|
$(MODULE)-objs += os/modconf.o
|
|
$(MODULE)-objs += algs/modes/cbc.o
|
|
$(MODULE)-objs += algs/modes/ccm.o
|
|
$(MODULE)-objs += algs/modes/ctr.o
|
|
$(MODULE)-objs += algs/modes/ecb.o
|
|
$(MODULE)-objs += algs/modes/gcm.o
|
|
$(MODULE)-objs += algs/modes/modes.o
|
|
$(MODULE)-objs += algs/aes/aes_impl.o
|
|
$(MODULE)-objs += algs/aes/aes_modes.o
|
|
$(MODULE)-objs += algs/edonr/edonr.o
|
|
$(MODULE)-objs += algs/sha1/sha1.o
|
|
$(MODULE)-objs += algs/sha2/sha2.o
|
|
$(MODULE)-objs += algs/sha1/sha1.o
|
|
$(MODULE)-objs += algs/skein/skein.o
|
|
$(MODULE)-objs += algs/skein/skein_block.o
|
|
$(MODULE)-objs += algs/skein/skein_iv.o
|
|
$(MODULE)-objs += $(ASM_SOURCES)
|
|
|
|
ICP_DIRS = \
|
|
api \
|
|
core \
|
|
spi \
|
|
io \
|
|
os \
|
|
algs \
|
|
algs/aes \
|
|
algs/edonr \
|
|
algs/modes \
|
|
algs/sha1 \
|
|
algs/sha2 \
|
|
algs/skein \
|
|
asm-x86_64 \
|
|
asm-x86_64/aes \
|
|
asm-x86_64/modes \
|
|
asm-x86_64/sha1 \
|
|
asm-x86_64/sha2 \
|
|
asm-i386 \
|
|
asm-generic
|
|
|
|
all:
|
|
mkdir -p $(ICP_DIRS)
|