|
|
|
@ -1,139 +1,240 @@
|
|
|
|
|
From d1155b9ab9a2ef643ec82285d1fb767dcfd00d16 Mon Sep 17 00:00:00 2001
|
|
|
|
|
From: Ondrej Dubaj <odubaj@redhat.com>
|
|
|
|
|
Date: Thu, 1 Aug 2019 12:17:06 +0200
|
|
|
|
|
Subject: [PATCH] Optimized CRC32 for POWER 8+ architectures.
|
|
|
|
|
From 64af50f69caa52e676a3d7066c2b07ff43d33862 Mon Sep 17 00:00:00 2001
|
|
|
|
|
From: Ilya Leoshkevich <iii@linux.ibm.com>
|
|
|
|
|
Date: Thu, 2 Feb 2023 19:41:11 +0100
|
|
|
|
|
Subject: [PATCH] 0002-PATCH-Add-Power8-optimized-crc32.patch
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
Makefile.in | 8 +
|
|
|
|
|
configure | 77 ++
|
|
|
|
|
contrib/power8-crc/clang_workaround.h | 82 ++
|
|
|
|
|
contrib/power8-crc/crc32_constants.h | 1206 +++++++++++++++++++++++++
|
|
|
|
|
contrib/power8-crc/vec_crc32.c | 674 ++++++++++++++
|
|
|
|
|
crc32.c | 100 +-
|
|
|
|
|
6 files changed, 2135 insertions(+), 12 deletions(-)
|
|
|
|
|
create mode 100644 contrib/power8-crc/clang_workaround.h
|
|
|
|
|
create mode 100644 contrib/power8-crc/crc32_constants.h
|
|
|
|
|
create mode 100644 contrib/power8-crc/vec_crc32.c
|
|
|
|
|
CMakeLists.txt | 7 +-
|
|
|
|
|
Makefile.in | 43 +-
|
|
|
|
|
configure | 7 +-
|
|
|
|
|
contrib/README.contrib | 3 +-
|
|
|
|
|
contrib/power/clang_workaround.h | 82 ++
|
|
|
|
|
contrib/power/crc32_constants.h | 1206 ++++++++++++++++++++++++++++++
|
|
|
|
|
contrib/power/crc32_z_power8.c | 679 +++++++++++++++++
|
|
|
|
|
contrib/power/crc32_z_resolver.c | 15 +
|
|
|
|
|
contrib/power/power.h | 4 +
|
|
|
|
|
crc32.c | 12 +
|
|
|
|
|
test/crc32_test.c | 205 +++++
|
|
|
|
|
12 files changed, 2252 insertions(+), 14 deletions(-)
|
|
|
|
|
create mode 100644 contrib/power/clang_workaround.h
|
|
|
|
|
create mode 100644 contrib/power/crc32_constants.h
|
|
|
|
|
create mode 100644 contrib/power/crc32_z_power8.c
|
|
|
|
|
create mode 100644 contrib/power/crc32_z_resolver.c
|
|
|
|
|
create mode 100644 test/crc32_test.c
|
|
|
|
|
|
|
|
|
|
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
|
|
|
|
index e762023..abf606c 100644
|
|
|
|
|
--- a/CMakeLists.txt
|
|
|
|
|
+++ b/CMakeLists.txt
|
|
|
|
|
@@ -184,7 +184,8 @@ if(CMAKE_COMPILER_IS_GNUCC)
|
|
|
|
|
|
|
|
|
|
if(POWER8)
|
|
|
|
|
add_definitions(-DZ_POWER8)
|
|
|
|
|
- set(ZLIB_POWER8 )
|
|
|
|
|
+ set(ZLIB_POWER8
|
|
|
|
|
+ contrib/power/crc32_z_power8.c)
|
|
|
|
|
|
|
|
|
|
set_source_files_properties(
|
|
|
|
|
${ZLIB_POWER8}
|
|
|
|
|
@@ -301,6 +302,10 @@ add_executable(example test/example.c)
|
|
|
|
|
target_link_libraries(example zlib)
|
|
|
|
|
add_test(example example)
|
|
|
|
|
|
|
|
|
|
+add_executable(crc32_test test/crc32_test.c)
|
|
|
|
|
+target_link_libraries(crc32_test zlib)
|
|
|
|
|
+add_test(crc32_test crc32_test)
|
|
|
|
|
+
|
|
|
|
|
add_executable(minigzip test/minigzip.c)
|
|
|
|
|
target_link_libraries(minigzip zlib)
|
|
|
|
|
|
|
|
|
|
diff --git a/Makefile.in b/Makefile.in
|
|
|
|
|
index b7bdbf2..55f6489 100644
|
|
|
|
|
index e756e2f..d392616 100644
|
|
|
|
|
--- a/Makefile.in
|
|
|
|
|
+++ b/Makefile.in
|
|
|
|
|
@@ -167,6 +167,9 @@ minigzip64.o: $(SRCDIR)test/minigzip.c $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
adler32.o: $(SRCDIR)adler32.c
|
|
|
|
|
$(CC) $(CFLAGS) $(ZINC) -c -o $@ $(SRCDIR)adler32.c
|
|
|
|
|
@@ -75,11 +75,11 @@ PIC_OBJS = $(PIC_OBJC) $(PIC_OBJA)
|
|
|
|
|
|
|
|
|
|
all: static shared
|
|
|
|
|
|
|
|
|
|
-static: example$(EXE) minigzip$(EXE)
|
|
|
|
|
+static: crc32_test$(EXE) example$(EXE) minigzip$(EXE)
|
|
|
|
|
|
|
|
|
|
-shared: examplesh$(EXE) minigzipsh$(EXE)
|
|
|
|
|
+shared: crc32_testsh$(EXE) examplesh$(EXE) minigzipsh$(EXE)
|
|
|
|
|
|
|
|
|
|
-all64: example64$(EXE) minigzip64$(EXE)
|
|
|
|
|
+all64: crc32_test64$(EXE) example64$(EXE) minigzip64$(EXE)
|
|
|
|
|
|
|
|
|
|
check: test
|
|
|
|
|
|
|
|
|
|
@@ -87,7 +87,7 @@ test: all teststatic testshared
|
|
|
|
|
|
|
|
|
|
teststatic: static
|
|
|
|
|
@TMPST=tmpst_$$; \
|
|
|
|
|
- if echo hello world | ./minigzip | ./minigzip -d && ./example $$TMPST ; then \
|
|
|
|
|
+ if echo hello world | ./minigzip | ./minigzip -d && ./example $$TMPST && ./crc32_test; then \
|
|
|
|
|
echo ' *** zlib test OK ***'; \
|
|
|
|
|
else \
|
|
|
|
|
echo ' *** zlib test FAILED ***'; false; \
|
|
|
|
|
@@ -100,7 +100,7 @@ testshared: shared
|
|
|
|
|
DYLD_LIBRARY_PATH=`pwd`:$(DYLD_LIBRARY_PATH) ; export DYLD_LIBRARY_PATH; \
|
|
|
|
|
SHLIB_PATH=`pwd`:$(SHLIB_PATH) ; export SHLIB_PATH; \
|
|
|
|
|
TMPSH=tmpsh_$$; \
|
|
|
|
|
- if echo hello world | ./minigzipsh | ./minigzipsh -d && ./examplesh $$TMPSH; then \
|
|
|
|
|
+ if echo hello world | ./minigzipsh | ./minigzipsh -d && ./examplesh $$TMPSH && ./crc32_testsh; then \
|
|
|
|
|
echo ' *** zlib shared test OK ***'; \
|
|
|
|
|
else \
|
|
|
|
|
echo ' *** zlib shared test FAILED ***'; false; \
|
|
|
|
|
@@ -109,7 +109,7 @@ testshared: shared
|
|
|
|
|
|
|
|
|
|
test64: all64
|
|
|
|
|
@TMP64=tmp64_$$; \
|
|
|
|
|
- if echo hello world | ./minigzip64 | ./minigzip64 -d && ./example64 $$TMP64; then \
|
|
|
|
|
+ if echo hello world | ./minigzip64 | ./minigzip64 -d && ./example64 $$TMP64 && ./crc32_test64; then \
|
|
|
|
|
echo ' *** zlib 64-bit test OK ***'; \
|
|
|
|
|
else \
|
|
|
|
|
echo ' *** zlib 64-bit test FAILED ***'; false; \
|
|
|
|
|
@@ -151,12 +151,18 @@ dfltcc.lo: $(SRCDIR)contrib/s390/dfltcc.c $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
$(CC) $(SFLAGS) $(ZINC) -DPIC -c -o objs/dfltcc.o $(SRCDIR)contrib/s390/dfltcc.c
|
|
|
|
|
-@mv objs/dfltcc.o $@
|
|
|
|
|
|
|
|
|
|
+crc32_power8.o: $(SRCDIR)contrib/power8-crc/vec_crc32.c
|
|
|
|
|
+ $(CC) $(CFLAGS) $(ZINC) -c -o $@ $(SRCDIR)contrib/power8-crc/vec_crc32.c
|
|
|
|
|
+crc32_test.o: $(SRCDIR)test/crc32_test.c $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
+ $(CC) $(CFLAGS) $(ZINCOUT) -c -o $@ $(SRCDIR)test/crc32_test.c
|
|
|
|
|
+
|
|
|
|
|
example.o: $(SRCDIR)test/example.c $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
$(CC) $(CFLAGS) $(ZINCOUT) -c -o $@ $(SRCDIR)test/example.c
|
|
|
|
|
|
|
|
|
|
minigzip.o: $(SRCDIR)test/minigzip.c $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
$(CC) $(CFLAGS) $(ZINCOUT) -c -o $@ $(SRCDIR)test/minigzip.c
|
|
|
|
|
|
|
|
|
|
+crc32_test64.o: $(SRCDIR)test/crc32_test.c $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
+ $(CC) $(CFLAGS) $(ZINCOUT) -D_FILE_OFFSET_BITS=64 -c -o $@ $(SRCDIR)test/crc32_test.c
|
|
|
|
|
+
|
|
|
|
|
example64.o: $(SRCDIR)test/example.c $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
$(CC) $(CFLAGS) $(ZINCOUT) -D_FILE_OFFSET_BITS=64 -c -o $@ $(SRCDIR)test/example.c
|
|
|
|
|
|
|
|
|
|
@@ -170,6 +176,9 @@ adler32.o: $(SRCDIR)adler32.c
|
|
|
|
|
crc32.o: $(SRCDIR)crc32.c
|
|
|
|
|
$(CC) $(CFLAGS) $(ZINC) -c -o $@ $(SRCDIR)crc32.c
|
|
|
|
|
|
|
|
|
|
@@ -215,6 +218,11 @@ adler32.lo: $(SRCDIR)adler32.c
|
|
|
|
|
$(CC) $(SFLAGS) $(ZINC) -DPIC -c -o objs/adler32.o $(SRCDIR)adler32.c
|
|
|
|
|
-@mv objs/adler32.o $@
|
|
|
|
|
+crc32_z_power8.o: $(SRCDIR)contrib/power/crc32_z_power8.c
|
|
|
|
|
+ $(CC) $(CFLAGS) -mcpu=power8 $(ZINC) -c -o $@ $(SRCDIR)contrib/power/crc32_z_power8.c
|
|
|
|
|
+
|
|
|
|
|
deflate.o: $(SRCDIR)deflate.c
|
|
|
|
|
$(CC) $(CFLAGS) $(ZINC) -c -o $@ $(SRCDIR)deflate.c
|
|
|
|
|
|
|
|
|
|
@@ -220,6 +229,11 @@ crc32.lo: $(SRCDIR)crc32.c
|
|
|
|
|
$(CC) $(SFLAGS) $(ZINC) -DPIC -c -o objs/crc32.o $(SRCDIR)crc32.c
|
|
|
|
|
-@mv objs/crc32.o $@
|
|
|
|
|
|
|
|
|
|
+crc32_power8.lo: $(SRCDIR)contrib/power8-crc/vec_crc32.c
|
|
|
|
|
+crc32_z_power8.lo: $(SRCDIR)contrib/power/crc32_z_power8.c
|
|
|
|
|
+ -@mkdir objs 2>/dev/null || test -d objs
|
|
|
|
|
+ $(CC) $(SFLAGS) $(ZINC) -DPIC -c -o objs/crc32_power8.o $(SRCDIR)contrib/power8-crc/vec_crc32.c
|
|
|
|
|
+ -@mv objs/crc32_power8.o $@
|
|
|
|
|
+ $(CC) $(SFLAGS) -mcpu=power8 $(ZINC) -DPIC -c -o objs/crc32_z_power8.o $(SRCDIR)contrib/power/crc32_z_power8.c
|
|
|
|
|
+ -@mv objs/crc32_z_power8.o $@
|
|
|
|
|
+
|
|
|
|
|
crc32.lo: $(SRCDIR)crc32.c
|
|
|
|
|
deflate.lo: $(SRCDIR)deflate.c
|
|
|
|
|
-@mkdir objs 2>/dev/null || test -d objs
|
|
|
|
|
$(CC) $(SFLAGS) $(ZINC) -DPIC -c -o objs/crc32.o $(SRCDIR)crc32.c
|
|
|
|
|
$(CC) $(SFLAGS) $(ZINC) -DPIC -c -o objs/deflate.o $(SRCDIR)deflate.c
|
|
|
|
|
@@ -293,18 +307,27 @@ placebo $(SHAREDLIBV): $(PIC_OBJS) libz.a
|
|
|
|
|
ln -s $@ $(SHAREDLIBM)
|
|
|
|
|
-@rmdir objs
|
|
|
|
|
|
|
|
|
|
+crc32_test$(EXE): crc32_test.o $(STATICLIB)
|
|
|
|
|
+ $(CC) $(CFLAGS) -o $@ crc32_test.o $(TEST_LDFLAGS)
|
|
|
|
|
+
|
|
|
|
|
example$(EXE): example.o $(STATICLIB)
|
|
|
|
|
$(CC) $(CFLAGS) -o $@ example.o $(TEST_LDFLAGS)
|
|
|
|
|
|
|
|
|
|
minigzip$(EXE): minigzip.o $(STATICLIB)
|
|
|
|
|
$(CC) $(CFLAGS) -o $@ minigzip.o $(TEST_LDFLAGS)
|
|
|
|
|
|
|
|
|
|
+crc32_testsh$(EXE): crc32_test.o $(SHAREDLIBV)
|
|
|
|
|
+ $(CC) $(CFLAGS) -o $@ crc32_test.o -L. $(SHAREDLIBV)
|
|
|
|
|
+
|
|
|
|
|
examplesh$(EXE): example.o $(SHAREDLIBV)
|
|
|
|
|
$(CC) $(CFLAGS) -o $@ example.o -L. $(SHAREDLIBV)
|
|
|
|
|
|
|
|
|
|
minigzipsh$(EXE): minigzip.o $(SHAREDLIBV)
|
|
|
|
|
$(CC) $(CFLAGS) -o $@ minigzip.o -L. $(SHAREDLIBV)
|
|
|
|
|
|
|
|
|
|
+crc32_test64$(EXE): crc32_test64.o $(STATICLIB)
|
|
|
|
|
+ $(CC) $(CFLAGS) -o $@ crc32_test64.o $(TEST_LDFLAGS)
|
|
|
|
|
+
|
|
|
|
|
example64$(EXE): example64.o $(STATICLIB)
|
|
|
|
|
$(CC) $(CFLAGS) -o $@ example64.o $(TEST_LDFLAGS)
|
|
|
|
|
|
|
|
|
|
@@ -374,8 +397,8 @@ zconf: $(SRCDIR)zconf.h.in
|
|
|
|
|
mostlyclean: clean
|
|
|
|
|
clean:
|
|
|
|
|
rm -f *.o *.lo *~ \
|
|
|
|
|
- example$(EXE) minigzip$(EXE) examplesh$(EXE) minigzipsh$(EXE) \
|
|
|
|
|
- example64$(EXE) minigzip64$(EXE) \
|
|
|
|
|
+ crc32_test$(EXE) example$(EXE) minigzip$(EXE) crc32_testsh$(EXE) examplesh$(EXE) minigzipsh$(EXE) \
|
|
|
|
|
+ crc32_test64$(EXE) example64$(EXE) minigzip64$(EXE) \
|
|
|
|
|
infcover \
|
|
|
|
|
libz.* foo.gz so_locations \
|
|
|
|
|
_match.s maketree contrib/infback9/*.o
|
|
|
|
|
@@ -399,7 +422,7 @@ tags:
|
|
|
|
|
|
|
|
|
|
adler32.o zutil.o: $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
gzclose.o gzlib.o gzread.o gzwrite.o: $(SRCDIR)zlib.h zconf.h $(SRCDIR)gzguts.h
|
|
|
|
|
-compress.o example.o minigzip.o uncompr.o: $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
+compress.o crc32_test.o example.o minigzip.o uncompr.o: $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
crc32.o: $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h $(SRCDIR)crc32.h
|
|
|
|
|
deflate.o: $(SRCDIR)deflate.h $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
infback.o inflate.o: $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h $(SRCDIR)inftrees.h $(SRCDIR)inflate.h $(SRCDIR)inffast.h $(SRCDIR)inffixed.h
|
|
|
|
|
@@ -409,7 +432,7 @@ trees.o: $(SRCDIR)deflate.h $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h $(SRCDIR)tr
|
|
|
|
|
|
|
|
|
|
adler32.lo zutil.lo: $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
gzclose.lo gzlib.lo gzread.lo gzwrite.lo: $(SRCDIR)zlib.h zconf.h $(SRCDIR)gzguts.h
|
|
|
|
|
-compress.lo example.lo minigzip.lo uncompr.lo: $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
+compress.lo crc32_test.lo example.lo minigzip.lo uncompr.lo: $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
crc32.lo: $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h $(SRCDIR)crc32.h
|
|
|
|
|
deflate.lo: $(SRCDIR)deflate.h $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h
|
|
|
|
|
infback.lo inflate.lo: $(SRCDIR)zutil.h $(SRCDIR)zlib.h zconf.h $(SRCDIR)inftrees.h $(SRCDIR)inflate.h $(SRCDIR)inffast.h $(SRCDIR)inffixed.h
|
|
|
|
|
diff --git a/configure b/configure
|
|
|
|
|
index cd9eeef..e93ff99 100755
|
|
|
|
|
index 0538d58..e37dac8 100755
|
|
|
|
|
--- a/configure
|
|
|
|
|
+++ b/configure
|
|
|
|
|
@@ -839,6 +839,83 @@ else
|
|
|
|
|
echo "Checking for sys/sdt.h ... No." | tee -a configure.log
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
+# test to see if Power8+ implementation is compile time possible
|
|
|
|
|
+echo >> configure.log
|
|
|
|
|
+cat > $test.c <<EOF
|
|
|
|
|
+#if _ARCH_PWR8==1
|
|
|
|
|
+#if __BYTE_ORDER == __BIG_ENDIAN && defined(__clang__)
|
|
|
|
|
+#error "Clang vector instructions aren't big endian compatible"
|
|
|
|
|
+#endif
|
|
|
|
|
+#if defined(__BUILTIN_CPU_SUPPORTS__)
|
|
|
|
|
+/* good and easy */
|
|
|
|
|
+#else
|
|
|
|
|
+#include <sys/auxv.h>
|
|
|
|
|
+#include <bits/hwcap.h>
|
|
|
|
|
+int main()
|
|
|
|
|
+{
|
|
|
|
|
+ return (getauxval(AT_HWCAP2) & PPC_FEATURE2_ARCH_2_07);
|
|
|
|
|
+}
|
|
|
|
|
@@ -876,6 +876,9 @@ cat > $test.c <<EOF
|
|
|
|
|
#ifndef _ARCH_PPC
|
|
|
|
|
#error "Target is not Power"
|
|
|
|
|
#endif
|
|
|
|
|
+#if !(defined(__PPC64__) || defined(__powerpc64__))
|
|
|
|
|
+ #error "Target is not 64 bits"
|
|
|
|
|
+#endif
|
|
|
|
|
+#else
|
|
|
|
|
+#error No Power 8 or newer architecture, may need -mcpu=power8
|
|
|
|
|
+#endif
|
|
|
|
|
+EOF
|
|
|
|
|
+
|
|
|
|
|
+if tryboth $CC -c $CFLAGS $test.c; then
|
|
|
|
|
+ OBJC="$OBJC crc32_power8.o"
|
|
|
|
|
+ PIC_OBJC="$PIC_OBJC crc32_power8.lo"
|
|
|
|
|
+ echo "Checking for runtime cpu detection and Power 8 (or newer) Architecture support... Yes." | tee -a configure.log
|
|
|
|
|
+else
|
|
|
|
|
+ echo "Checking for runtime cpu detection and Power 8 (or newer) Architecture support... No." | tee -a configure.log
|
|
|
|
|
+fi
|
|
|
|
|
+
|
|
|
|
|
+# test to see if we can use a gnu indirection function to detect and load optimized code at runtime
|
|
|
|
|
+echo >> configure.log
|
|
|
|
|
+cat > $test.c <<EOF
|
|
|
|
|
+static unsigned int crc32_real_optimized(unsigned int crc, unsigned char *p,
|
|
|
|
|
+ unsigned long len)
|
|
|
|
|
+{
|
|
|
|
|
+ return 1;
|
|
|
|
|
+}
|
|
|
|
|
+static unsigned int (*(crc32_ifunc(void)))(unsigned int, unsigned char *,unsigned long)
|
|
|
|
|
+{
|
|
|
|
|
+ return crc32_real_optimized;
|
|
|
|
|
+}
|
|
|
|
|
+unsigned int crc32(unsigned int, unsigned char *,unsigned long)
|
|
|
|
|
+ __attribute__ ((ifunc ("crc32_ifunc")));
|
|
|
|
|
+EOF
|
|
|
|
|
+
|
|
|
|
|
+if tryboth $CC -c $CFLAGS $test.c; then
|
|
|
|
|
+ SFLAGS="${SFLAGS} -DZ_IFUNC_NATIVE"
|
|
|
|
|
+ echo "Checking for attribute(ifunc) support... Yes." | tee -a configure.log
|
|
|
|
|
+else
|
|
|
|
|
+ echo "Checking for attribute(ifunc) support... No." | tee -a configure.log
|
|
|
|
|
+
|
|
|
|
|
+ # alternately can we can use a gnu indirection using __asm__ attributes to detect and load optimized code at runtime
|
|
|
|
|
+ echo >> configure.log
|
|
|
|
|
+ cat > $test.c <<EOF
|
|
|
|
|
+static unsigned int crc32_real_optimized(unsigned int crc, unsigned char *p,
|
|
|
|
|
+ unsigned long len)
|
|
|
|
|
+{
|
|
|
|
|
+ return 1;
|
|
|
|
|
+}
|
|
|
|
|
+static unsigned int (*(crc32_ifunc(void)))(unsigned int, unsigned char *,unsigned long)
|
|
|
|
|
+ __asm__ ("crc32");
|
|
|
|
|
+static unsigned int (*(crc32_ifunc(void)))(unsigned int, unsigned char *,unsigned long)
|
|
|
|
|
+{
|
|
|
|
|
+ return crc32_real_optimized;
|
|
|
|
|
+}
|
|
|
|
|
+__asm__(".type crc32, %gnu_indirect_function");
|
|
|
|
|
+EOF
|
|
|
|
|
+
|
|
|
|
|
+ if tryboth $CC -c $CFLAGS $test.c; then
|
|
|
|
|
+ SFLAGS="${SFLAGS} -DZ_IFUNC_ASM"
|
|
|
|
|
+ echo "Checking for asm .type %gnu_indirect_function support... Yes." | tee -a configure.log
|
|
|
|
|
+ else
|
|
|
|
|
+ echo "Checking for asm .type %gnu_indirect_function support... No." | tee -a configure.log
|
|
|
|
|
+ fi
|
|
|
|
|
+fi
|
|
|
|
|
+
|
|
|
|
|
# show the results in the log
|
|
|
|
|
echo >> configure.log
|
|
|
|
|
echo ALL = $ALL >> configure.log
|
|
|
|
|
diff --git a/contrib/power8-crc/clang_workaround.h b/contrib/power8-crc/clang_workaround.h
|
|
|
|
|
#ifndef HAVE_IFUNC
|
|
|
|
|
#error "Target doesn't support ifunc"
|
|
|
|
|
#endif
|
|
|
|
|
@@ -889,8 +892,8 @@ if tryboth $CC -c $CFLAGS $test.c; then
|
|
|
|
|
|
|
|
|
|
if tryboth $CC -c $CFLAGS -mcpu=power8 $test.c; then
|
|
|
|
|
POWER8="-DZ_POWER8"
|
|
|
|
|
- PIC_OBJC="${PIC_OBJC}"
|
|
|
|
|
- OBJC="${OBJC}"
|
|
|
|
|
+ PIC_OBJC="${PIC_OBJC} crc32_z_power8.lo"
|
|
|
|
|
+ OBJC="${OBJC} crc32_z_power8.o"
|
|
|
|
|
echo "Checking for -mcpu=power8 support... Yes." | tee -a configure.log
|
|
|
|
|
else
|
|
|
|
|
echo "Checking for -mcpu=power8 support... No." | tee -a configure.log
|
|
|
|
|
diff --git a/contrib/README.contrib b/contrib/README.contrib
|
|
|
|
|
index 2a53f90..5411ec6 100644
|
|
|
|
|
--- a/contrib/README.contrib
|
|
|
|
|
+++ b/contrib/README.contrib
|
|
|
|
|
@@ -67,7 +67,8 @@ minizip/ by Gilles Vollant <info@winimage.com>
|
|
|
|
|
pascal/ by Bob Dellaca <bobdl@xtra.co.nz> et al.
|
|
|
|
|
Support for Pascal
|
|
|
|
|
|
|
|
|
|
-power/ by Matheus Castanho <msc@linux.ibm.com>
|
|
|
|
|
+power/ by Daniel Black <daniel@linux.ibm.com>
|
|
|
|
|
+ Matheus Castanho <msc@linux.ibm.com>
|
|
|
|
|
and Rogerio Alves <rcardoso@linux.ibm.com>
|
|
|
|
|
Optimized functions for Power processors
|
|
|
|
|
|
|
|
|
|
diff --git a/contrib/power/clang_workaround.h b/contrib/power/clang_workaround.h
|
|
|
|
|
new file mode 100644
|
|
|
|
|
index 0000000..09c411b
|
|
|
|
|
index 0000000..b5e7dae
|
|
|
|
|
--- /dev/null
|
|
|
|
|
+++ b/contrib/power8-crc/clang_workaround.h
|
|
|
|
|
+++ b/contrib/power/clang_workaround.h
|
|
|
|
|
@@ -0,0 +1,82 @@
|
|
|
|
|
+#ifndef CLANG_WORKAROUNDS_H
|
|
|
|
|
+#define CLANG_WORKAROUNDS_H
|
|
|
|
@ -217,12 +318,11 @@ index 0000000..09c411b
|
|
|
|
|
+#endif /* vec_xxpermdi */
|
|
|
|
|
+
|
|
|
|
|
+#endif
|
|
|
|
|
\ No newline at end of file
|
|
|
|
|
diff --git a/contrib/power8-crc/crc32_constants.h b/contrib/power8-crc/crc32_constants.h
|
|
|
|
|
diff --git a/contrib/power/crc32_constants.h b/contrib/power/crc32_constants.h
|
|
|
|
|
new file mode 100644
|
|
|
|
|
index 0000000..58088dc
|
|
|
|
|
--- /dev/null
|
|
|
|
|
+++ b/contrib/power8-crc/crc32_constants.h
|
|
|
|
|
+++ b/contrib/power/crc32_constants.h
|
|
|
|
|
@@ -0,0 +1,1206 @@
|
|
|
|
|
+/*
|
|
|
|
|
+*
|
|
|
|
@ -1430,12 +1530,12 @@ index 0000000..58088dc
|
|
|
|
|
+#endif /* POWER8_INTRINSICS */
|
|
|
|
|
+
|
|
|
|
|
+#endif /* __ASSEMBLER__ */
|
|
|
|
|
diff --git a/contrib/power8-crc/vec_crc32.c b/contrib/power8-crc/vec_crc32.c
|
|
|
|
|
diff --git a/contrib/power/crc32_z_power8.c b/contrib/power/crc32_z_power8.c
|
|
|
|
|
new file mode 100644
|
|
|
|
|
index 0000000..bb2204b
|
|
|
|
|
index 0000000..7858cfe
|
|
|
|
|
--- /dev/null
|
|
|
|
|
+++ b/contrib/power8-crc/vec_crc32.c
|
|
|
|
|
@@ -0,0 +1,674 @@
|
|
|
|
|
+++ b/contrib/power/crc32_z_power8.c
|
|
|
|
|
@@ -0,0 +1,679 @@
|
|
|
|
|
+/*
|
|
|
|
|
+ * Calculate the checksum of data that is 16 byte aligned and a multiple of
|
|
|
|
|
+ * 16 bytes.
|
|
|
|
@ -1468,6 +1568,8 @@ index 0000000..bb2204b
|
|
|
|
|
+ */
|
|
|
|
|
+
|
|
|
|
|
+#include <altivec.h>
|
|
|
|
|
+#include "../../zutil.h"
|
|
|
|
|
+#include "power.h"
|
|
|
|
|
+
|
|
|
|
|
+#define POWER8_INTRINSICS
|
|
|
|
|
+#define CRC_TABLE
|
|
|
|
@ -1502,16 +1604,18 @@ index 0000000..bb2204b
|
|
|
|
|
+static unsigned int __attribute__ ((aligned (32)))
|
|
|
|
|
+__crc32_vpmsum(unsigned int crc, const void* p, unsigned long len);
|
|
|
|
|
+
|
|
|
|
|
+#ifndef CRC32_FUNCTION
|
|
|
|
|
+#define CRC32_FUNCTION crc32_vpmsum
|
|
|
|
|
+#endif
|
|
|
|
|
+
|
|
|
|
|
+unsigned int CRC32_FUNCTION(unsigned int crc, const unsigned char *p,
|
|
|
|
|
+ unsigned long len)
|
|
|
|
|
+unsigned long ZLIB_INTERNAL _crc32_z_power8(uLong _crc, const Bytef *_p,
|
|
|
|
|
+ z_size_t _len)
|
|
|
|
|
+{
|
|
|
|
|
+ unsigned int prealign;
|
|
|
|
|
+ unsigned int tail;
|
|
|
|
|
+
|
|
|
|
|
+ /* Map zlib API to crc32_vpmsum API */
|
|
|
|
|
+ unsigned int crc = (unsigned int) (0xffffffff & _crc);
|
|
|
|
|
+ const unsigned char *p = _p;
|
|
|
|
|
+ unsigned long len = (unsigned long) _len;
|
|
|
|
|
+
|
|
|
|
|
+ if (p == (const unsigned char *) 0x0) return 0;
|
|
|
|
|
+#ifdef CRC_XOR
|
|
|
|
|
+ crc ^= 0xffffffff;
|
|
|
|
|
+#endif
|
|
|
|
@ -1541,7 +1645,8 @@ index 0000000..bb2204b
|
|
|
|
|
+ crc ^= 0xffffffff;
|
|
|
|
|
+#endif
|
|
|
|
|
+
|
|
|
|
|
+ return crc;
|
|
|
|
|
+ /* Convert to zlib API */
|
|
|
|
|
+ return (unsigned long) crc;
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+#if defined (__clang__)
|
|
|
|
@ -2110,149 +2215,280 @@ index 0000000..bb2204b
|
|
|
|
|
+
|
|
|
|
|
+ return result;
|
|
|
|
|
+}
|
|
|
|
|
diff --git a/contrib/power/crc32_z_resolver.c b/contrib/power/crc32_z_resolver.c
|
|
|
|
|
new file mode 100644
|
|
|
|
|
index 0000000..f4e9aa4
|
|
|
|
|
--- /dev/null
|
|
|
|
|
+++ b/contrib/power/crc32_z_resolver.c
|
|
|
|
|
@@ -0,0 +1,15 @@
|
|
|
|
|
+/* Copyright (C) 2019 Matheus Castanho <msc@linux.ibm.com>, IBM
|
|
|
|
|
+ * For conditions of distribution and use, see copyright notice in zlib.h
|
|
|
|
|
+ */
|
|
|
|
|
+
|
|
|
|
|
+#include "../gcc/zifunc.h"
|
|
|
|
|
+#include "power.h"
|
|
|
|
|
+
|
|
|
|
|
+Z_IFUNC(crc32_z) {
|
|
|
|
|
+#ifdef Z_POWER8
|
|
|
|
|
+ if (__builtin_cpu_supports("arch_2_07"))
|
|
|
|
|
+ return _crc32_z_power8;
|
|
|
|
|
+#endif
|
|
|
|
|
+
|
|
|
|
|
+ return crc32_z_default;
|
|
|
|
|
+}
|
|
|
|
|
diff --git a/contrib/power/power.h b/contrib/power/power.h
|
|
|
|
|
index b42c7d6..79123aa 100644
|
|
|
|
|
--- a/contrib/power/power.h
|
|
|
|
|
+++ b/contrib/power/power.h
|
|
|
|
|
@@ -2,3 +2,7 @@
|
|
|
|
|
* 2019 Rogerio Alves <rogerio.alves@ibm.com>, IBM
|
|
|
|
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
|
|
|
|
*/
|
|
|
|
|
+
|
|
|
|
|
+#include "../../zconf.h"
|
|
|
|
|
+
|
|
|
|
|
+unsigned long _crc32_z_power8(unsigned long, const Bytef *, z_size_t);
|
|
|
|
|
diff --git a/crc32.c b/crc32.c
|
|
|
|
|
index 9580440..406d350 100644
|
|
|
|
|
index 9580440..b0cda20 100644
|
|
|
|
|
--- a/crc32.c
|
|
|
|
|
+++ b/crc32.c
|
|
|
|
|
@@ -199,13 +199,78 @@ const z_crc_t FAR * ZEXPORT get_crc_table()
|
|
|
|
|
@@ -199,6 +199,13 @@ const z_crc_t FAR * ZEXPORT get_crc_table()
|
|
|
|
|
#define DO8 DO1; DO1; DO1; DO1; DO1; DO1; DO1; DO1
|
|
|
|
|
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
-unsigned long ZEXPORT crc32_z(crc, buf, len)
|
|
|
|
|
+local
|
|
|
|
|
+unsigned long ZEXPORT crc32_table_lookup(crc, buf, len)
|
|
|
|
|
+#ifdef Z_POWER_OPT
|
|
|
|
|
+/* Rename function so resolver can use its symbol. The default version will be
|
|
|
|
|
+ * returned by the resolver if the host has no support for an optimized version.
|
|
|
|
|
+ */
|
|
|
|
|
+#define crc32_z crc32_z_default
|
|
|
|
|
+#endif /* Z_POWER_OPT */
|
|
|
|
|
+
|
|
|
|
|
unsigned long ZEXPORT crc32_z(crc, buf, len)
|
|
|
|
|
unsigned long crc;
|
|
|
|
|
const unsigned char FAR *buf;
|
|
|
|
|
z_size_t len;
|
|
|
|
|
{
|
|
|
|
|
if (buf == Z_NULL) return 0UL;
|
|
|
|
|
@@ -233,6 +240,11 @@ unsigned long ZEXPORT crc32_z(crc, buf, len)
|
|
|
|
|
return crc ^ 0xffffffffUL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
+ crc = crc ^ 0xffffffffUL;
|
|
|
|
|
+ while (len >= 8) {
|
|
|
|
|
+ DO8;
|
|
|
|
|
+ len -= 8;
|
|
|
|
|
+ }
|
|
|
|
|
+ if (len) do {
|
|
|
|
|
+ DO1;
|
|
|
|
|
+ } while (--len);
|
|
|
|
|
+ return crc ^ 0xffffffffUL;
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+/* Small helper function to compare optfun against the reference table lookup
|
|
|
|
|
+ * return test_ref_comparision_##optfn in crc32_z_ifunc
|
|
|
|
|
+#include <assert.h>
|
|
|
|
|
+#define TEST_COMPARE(optfn) \
|
|
|
|
|
+ static unsigned long test_ref_comparision_ ## optfn(unsigned long crc, const unsigned char FAR *p, z_size_t len) \
|
|
|
|
|
+ { \
|
|
|
|
|
+ unsigned long crc_tbl_lookup = crc32_table_lookup(crc, p, len); \
|
|
|
|
|
+ unsigned long optcrc = optfn(crc, p, len); \
|
|
|
|
|
+ assert( optcrc == crc_tbl_lookup ); \
|
|
|
|
|
+ return optcrc; \
|
|
|
|
|
+ }
|
|
|
|
|
+*/
|
|
|
|
|
+#ifdef Z_POWER_OPT
|
|
|
|
|
+#undef crc32_z
|
|
|
|
|
+#include "contrib/power/crc32_z_resolver.c"
|
|
|
|
|
+#endif /* Z_POWER_OPT */
|
|
|
|
|
+
|
|
|
|
|
+#ifdef Z_IFUNC_ASM
|
|
|
|
|
+unsigned long (*(crc32_z_ifunc(void)))(unsigned long, const unsigned char FAR *, z_size_t)
|
|
|
|
|
+ __asm__ ("crc32_z");
|
|
|
|
|
+__asm__(".type crc32_z, %gnu_indirect_function");
|
|
|
|
|
+#elif defined(Z_IFUNC_NATIVE)
|
|
|
|
|
+unsigned long ZEXPORT crc32_z(
|
|
|
|
|
+ unsigned long crc,
|
|
|
|
|
+ const unsigned char FAR *buf,
|
|
|
|
|
+ z_size_t len)
|
|
|
|
|
+ __attribute__ ((ifunc ("crc32_z_ifunc")));
|
|
|
|
|
+#endif
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
unsigned long ZEXPORT crc32(crc, buf, len)
|
|
|
|
|
unsigned long crc;
|
|
|
|
|
diff --git a/test/crc32_test.c b/test/crc32_test.c
|
|
|
|
|
new file mode 100644
|
|
|
|
|
index 0000000..3155553
|
|
|
|
|
--- /dev/null
|
|
|
|
|
+++ b/test/crc32_test.c
|
|
|
|
|
@@ -0,0 +1,205 @@
|
|
|
|
|
+/* crc32_tes.c -- unit test for crc32 in the zlib compression library
|
|
|
|
|
+ * Copyright (C) 1995-2006, 2010, 2011, 2016, 2019 Rogerio Alves
|
|
|
|
|
+ * For conditions of distribution and use, see copyright notice in zlib.h
|
|
|
|
|
+ */
|
|
|
|
|
+
|
|
|
|
|
+#if _ARCH_PWR8==1
|
|
|
|
|
+unsigned long crc32_vpmsum(unsigned long, const unsigned char FAR *, z_size_t);
|
|
|
|
|
+/* for testing TEST_COMPARE(crc32_vpmsum) */
|
|
|
|
|
+#ifndef __BUILTIN_CPU_SUPPORTS__
|
|
|
|
|
+#include <sys/auxv.h>
|
|
|
|
|
+#include <bits/hwcap.h>
|
|
|
|
|
+#endif
|
|
|
|
|
+#endif
|
|
|
|
|
+#include "zlib.h"
|
|
|
|
|
+#include <stdio.h>
|
|
|
|
|
+
|
|
|
|
|
+/* due to a quirk of gnu_indirect_function - "local" (aka static) is applied to
|
|
|
|
|
+ * crc32_z which is not desired. crc32_z_ifunc is implictly "local" */
|
|
|
|
|
+#ifndef Z_IFUNC_ASM
|
|
|
|
|
+local
|
|
|
|
|
+#ifdef STDC
|
|
|
|
|
+# include <string.h>
|
|
|
|
|
+# include <stdlib.h>
|
|
|
|
|
+#endif
|
|
|
|
|
+unsigned long (*(crc32_z_ifunc(void)))(unsigned long, const unsigned char FAR *, z_size_t)
|
|
|
|
|
+{
|
|
|
|
|
+#if _ARCH_PWR8==1
|
|
|
|
|
+#if defined(__BUILTIN_CPU_SUPPORTS__)
|
|
|
|
|
+ if (__builtin_cpu_supports("arch_2_07"))
|
|
|
|
|
+ return crc32_vpmsum;
|
|
|
|
|
+#else
|
|
|
|
|
+ if (getauxval(AT_HWCAP2) & PPC_FEATURE2_ARCH_2_07)
|
|
|
|
|
+ return crc32_vpmsum;
|
|
|
|
|
+#endif
|
|
|
|
|
+#endif /* _ARCH_PWR8 */
|
|
|
|
|
+
|
|
|
|
|
+/* return a function pointer for optimized arches here */
|
|
|
|
|
+void test_crc32 OF((uLong crc, Byte* buf, z_size_t len, uLong chk, int line));
|
|
|
|
|
+int main OF((void));
|
|
|
|
|
+
|
|
|
|
|
#ifdef DYNAMIC_CRC_TABLE
|
|
|
|
|
if (crc_table_empty)
|
|
|
|
|
make_crc_table();
|
|
|
|
|
@@ -217,22 +282,31 @@ unsigned long ZEXPORT crc32_z(crc, buf, len)
|
|
|
|
|
|
|
|
|
|
endian = 1;
|
|
|
|
|
if (*((unsigned char *)(&endian)))
|
|
|
|
|
- return crc32_little(crc, buf, len);
|
|
|
|
|
+ return crc32_little;
|
|
|
|
|
else
|
|
|
|
|
- return crc32_big(crc, buf, len);
|
|
|
|
|
+ return crc32_big;
|
|
|
|
|
}
|
|
|
|
|
#endif /* BYFOUR */
|
|
|
|
|
- crc = crc ^ 0xffffffffUL;
|
|
|
|
|
- while (len >= 8) {
|
|
|
|
|
- DO8;
|
|
|
|
|
- len -= 8;
|
|
|
|
|
- }
|
|
|
|
|
- if (len) do {
|
|
|
|
|
- DO1;
|
|
|
|
|
- } while (--len);
|
|
|
|
|
- return crc ^ 0xffffffffUL;
|
|
|
|
|
+
|
|
|
|
|
+ return crc32_table_lookup;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
+#if !defined(Z_IFUNC_ASM) && !defined(Z_IFUNC_NATIVE)
|
|
|
|
|
+typedef struct {
|
|
|
|
|
+ int line;
|
|
|
|
|
+ uLong crc;
|
|
|
|
|
+ char* buf;
|
|
|
|
|
+ int len;
|
|
|
|
|
+ uLong expect;
|
|
|
|
|
+} crc32_test;
|
|
|
|
|
+
|
|
|
|
|
+unsigned long ZEXPORT crc32_z(crc, buf, len)
|
|
|
|
|
+ unsigned long crc;
|
|
|
|
|
+ const unsigned char FAR *buf;
|
|
|
|
|
+void test_crc32(crc, buf, len, chk, line)
|
|
|
|
|
+ uLong crc;
|
|
|
|
|
+ Byte *buf;
|
|
|
|
|
+ z_size_t len;
|
|
|
|
|
+ uLong chk;
|
|
|
|
|
+ int line;
|
|
|
|
|
+{
|
|
|
|
|
+ static unsigned long ZEXPORT (*crc32_func)(unsigned long, const unsigned char FAR *, z_size_t) = NULL;
|
|
|
|
|
+
|
|
|
|
|
+ if (!crc32_func)
|
|
|
|
|
+ crc32_func = crc32_z_ifunc();
|
|
|
|
|
+ return (*crc32_func)(crc, buf, len);
|
|
|
|
|
+ uLong res = crc32(crc, buf, len);
|
|
|
|
|
+ if (res != chk) {
|
|
|
|
|
+ fprintf(stderr, "FAIL [%d]: crc32 returned 0x%08X expected 0x%08X\n",
|
|
|
|
|
+ line, (unsigned int)res, (unsigned int)chk);
|
|
|
|
|
+ exit(1);
|
|
|
|
|
+ }
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+#endif /* defined(Z_IFUNC_ASM) || defined(Z_IFUNC_NATIVE) */
|
|
|
|
|
+
|
|
|
|
|
/* ========================================================================= */
|
|
|
|
|
unsigned long ZEXPORT crc32(crc, buf, len)
|
|
|
|
|
unsigned long crc;
|
|
|
|
|
@@ -271,6 +345,7 @@ local unsigned long crc32_little(crc, buf, len)
|
|
|
|
|
register z_crc_t c;
|
|
|
|
|
register const z_crc_t FAR *buf4;
|
|
|
|
|
|
|
|
|
|
+ if (buf == Z_NULL) return 0UL;
|
|
|
|
|
c = (z_crc_t)crc;
|
|
|
|
|
c = ~c;
|
|
|
|
|
while (len && ((ptrdiff_t)buf & 3)) {
|
|
|
|
|
@@ -311,6 +386,7 @@ local unsigned long crc32_big(crc, buf, len)
|
|
|
|
|
register z_crc_t c;
|
|
|
|
|
register const z_crc_t FAR *buf4;
|
|
|
|
|
|
|
|
|
|
+ if (buf == Z_NULL) return 0UL;
|
|
|
|
|
c = ZSWAP32((z_crc_t)crc);
|
|
|
|
|
c = ~c;
|
|
|
|
|
while (len && ((ptrdiff_t)buf & 3)) {
|
|
|
|
|
+static const crc32_test tests[] = {
|
|
|
|
|
+ {__LINE__, 0x0, 0x0, 0, 0x0},
|
|
|
|
|
+ {__LINE__, 0xffffffff, 0x0, 0, 0x0},
|
|
|
|
|
+ {__LINE__, 0x0, 0x0, 255, 0x0}, /* BZ 174799. */
|
|
|
|
|
+ {__LINE__, 0x0, 0x0, 256, 0x0},
|
|
|
|
|
+ {__LINE__, 0x0, 0x0, 257, 0x0},
|
|
|
|
|
+ {__LINE__, 0x0, 0x0, 32767, 0x0},
|
|
|
|
|
+ {__LINE__, 0x0, 0x0, 32768, 0x0},
|
|
|
|
|
+ {__LINE__, 0x0, 0x0, 32769, 0x0},
|
|
|
|
|
+ {__LINE__, 0x0, "", 0, 0x0},
|
|
|
|
|
+ {__LINE__, 0xffffffff, "", 0, 0xffffffff},
|
|
|
|
|
+ {__LINE__, 0x0, "abacus", 6, 0xc3d7115b},
|
|
|
|
|
+ {__LINE__, 0x0, "backlog", 7, 0x269205},
|
|
|
|
|
+ {__LINE__, 0x0, "campfire", 8, 0x22a515f8},
|
|
|
|
|
+ {__LINE__, 0x0, "delta", 5, 0x9643fed9},
|
|
|
|
|
+ {__LINE__, 0x0, "executable", 10, 0xd68eda01},
|
|
|
|
|
+ {__LINE__, 0x0, "file", 4, 0x8c9f3610},
|
|
|
|
|
+ {__LINE__, 0x0, "greatest", 8, 0xc1abd6cd},
|
|
|
|
|
+ {__LINE__, 0x0, "hello", 5, 0x3610a686},
|
|
|
|
|
+ {__LINE__, 0x0, "inverter", 8, 0xc9e962c9},
|
|
|
|
|
+ {__LINE__, 0x0, "jigsaw", 6, 0xce4e3f69},
|
|
|
|
|
+ {__LINE__, 0x0, "karate", 6, 0x890be0e2},
|
|
|
|
|
+ {__LINE__, 0x0, "landscape", 9, 0xc4e0330b},
|
|
|
|
|
+ {__LINE__, 0x0, "machine", 7, 0x1505df84},
|
|
|
|
|
+ {__LINE__, 0x0, "nanometer", 9, 0xd4e19f39},
|
|
|
|
|
+ {__LINE__, 0x0, "oblivion", 8, 0xdae9de77},
|
|
|
|
|
+ {__LINE__, 0x0, "panama", 6, 0x66b8979c},
|
|
|
|
|
+ {__LINE__, 0x0, "quest", 5, 0x4317f817},
|
|
|
|
|
+ {__LINE__, 0x0, "resource", 8, 0xbc91f416},
|
|
|
|
|
+ {__LINE__, 0x0, "secret", 6, 0x5ca2e8e5},
|
|
|
|
|
+ {__LINE__, 0x0, "test", 4, 0xd87f7e0c},
|
|
|
|
|
+ {__LINE__, 0x0, "ultimate", 8, 0x3fc79b0b},
|
|
|
|
|
+ {__LINE__, 0x0, "vector", 6, 0x1b6e485b},
|
|
|
|
|
+ {__LINE__, 0x0, "walrus", 6, 0xbe769b97},
|
|
|
|
|
+ {__LINE__, 0x0, "xeno", 4, 0xe7a06444},
|
|
|
|
|
+ {__LINE__, 0x0, "yelling", 7, 0xfe3944e5},
|
|
|
|
|
+ {__LINE__, 0x0, "zlib", 4, 0x73887d3a},
|
|
|
|
|
+ {__LINE__, 0x0, "4BJD7PocN1VqX0jXVpWB", 20, 0xd487a5a1},
|
|
|
|
|
+ {__LINE__, 0x0, "F1rPWI7XvDs6nAIRx41l", 20, 0x61a0132e},
|
|
|
|
|
+ {__LINE__, 0x0, "ldhKlsVkPFOveXgkGtC2", 20, 0xdf02f76},
|
|
|
|
|
+ {__LINE__, 0x0, "5KKnGOOrs8BvJ35iKTOS", 20, 0x579b2b0a},
|
|
|
|
|
+ {__LINE__, 0x0, "0l1tw7GOcem06Ddu7yn4", 20, 0xf7d16e2d},
|
|
|
|
|
+ {__LINE__, 0x0, "MCr47CjPIn9R1IvE1Tm5", 20, 0x731788f5},
|
|
|
|
|
+ {__LINE__, 0x0, "UcixbzPKTIv0SvILHVdO", 20, 0x7112bb11},
|
|
|
|
|
+ {__LINE__, 0x0, "dGnAyAhRQDsWw0ESou24", 20, 0xf32a0dac},
|
|
|
|
|
+ {__LINE__, 0x0, "di0nvmY9UYMYDh0r45XT", 20, 0x625437bb},
|
|
|
|
|
+ {__LINE__, 0x0, "2XKDwHfAhFsV0RhbqtvH", 20, 0x896930f9},
|
|
|
|
|
+ {__LINE__, 0x0, "ZhrANFIiIvRnqClIVyeD", 20, 0x8579a37},
|
|
|
|
|
+ {__LINE__, 0x0, "v7Q9ehzioTOVeDIZioT1", 20, 0x632aa8e0},
|
|
|
|
|
+ {__LINE__, 0x0, "Yod5hEeKcYqyhfXbhxj2", 20, 0xc829af29},
|
|
|
|
|
+ {__LINE__, 0x0, "GehSWY2ay4uUKhehXYb0", 20, 0x1b08b7e8},
|
|
|
|
|
+ {__LINE__, 0x0, "kwytJmq6UqpflV8Y8GoE", 20, 0x4e33b192},
|
|
|
|
|
+ {__LINE__, 0x0, "70684206568419061514", 20, 0x59a179f0},
|
|
|
|
|
+ {__LINE__, 0x0, "42015093765128581010", 20, 0xcd1013d7},
|
|
|
|
|
+ {__LINE__, 0x0, "88214814356148806939", 20, 0xab927546},
|
|
|
|
|
+ {__LINE__, 0x0, "43472694284527343838", 20, 0x11f3b20c},
|
|
|
|
|
+ {__LINE__, 0x0, "49769333513942933689", 20, 0xd562d4ca},
|
|
|
|
|
+ {__LINE__, 0x0, "54979784887993251199", 20, 0x233395f7},
|
|
|
|
|
+ {__LINE__, 0x0, "58360544869206793220", 20, 0x2d167fd5},
|
|
|
|
|
+ {__LINE__, 0x0, "27347953487840714234", 20, 0x8b5108ba},
|
|
|
|
|
+ {__LINE__, 0x0, "07650690295365319082", 20, 0xc46b3cd8},
|
|
|
|
|
+ {__LINE__, 0x0, "42655507906821911703", 20, 0xc10b2662},
|
|
|
|
|
+ {__LINE__, 0x0, "29977409200786225655", 20, 0xc9a0f9d2},
|
|
|
|
|
+ {__LINE__, 0x0, "85181542907229116674", 20, 0x9341357b},
|
|
|
|
|
+ {__LINE__, 0x0, "87963594337989416799", 20, 0xf0424937},
|
|
|
|
|
+ {__LINE__, 0x0, "21395988329504168551", 20, 0xd7c4c31f},
|
|
|
|
|
+ {__LINE__, 0x0, "51991013580943379423", 20, 0xf11edcc4},
|
|
|
|
|
+ {__LINE__, 0x0, "*]+@!);({_$;}[_},?{?;(_?,=-][@", 30, 0x40795df4},
|
|
|
|
|
+ {__LINE__, 0x0, "_@:_).&(#.[:[{[:)$++-($_;@[)}+", 30, 0xdd61a631},
|
|
|
|
|
+ {__LINE__, 0x0, "&[!,[$_==}+.]@!;*(+},[;:)$;)-@", 30, 0xca907a99},
|
|
|
|
|
+ {__LINE__, 0x0, "]{.[.+?+[[=;[?}_#&;[=)__$$:+=_", 30, 0xf652deac},
|
|
|
|
|
+ {__LINE__, 0x0, "-%.)=/[@].:.(:,()$;=%@-$?]{%+%", 30, 0xaf39a5a9},
|
|
|
|
|
+ {__LINE__, 0x0, "+]#$(@&.=:,*];/.!]%/{:){:@(;)$", 30, 0x6bebb4cf},
|
|
|
|
|
+ {__LINE__, 0x0, ")-._.:?[&:.=+}(*$/=!.${;(=$@!}", 30, 0x76430bac},
|
|
|
|
|
+ {__LINE__, 0x0, ":(_*&%/[[}+,?#$&*+#[([*-/#;%(]", 30, 0x6c80c388},
|
|
|
|
|
+ {__LINE__, 0x0, "{[#-;:$/{)(+[}#]/{&!%(@)%:@-$:", 30, 0xd54d977d},
|
|
|
|
|
+ {__LINE__, 0x0, "_{$*,}(&,@.)):=!/%(&(,,-?$}}}!", 30, 0xe3966ad5},
|
|
|
|
|
+ {__LINE__, 0x0, "e$98KNzqaV)Y:2X?]77].{gKRD4G5{mHZk,Z)SpU%L3FSgv!Wb8MLAFdi{+fp)c,@8m6v)yXg@]HBDFk?.4&}g5_udE*JHCiH=aL", 100, 0xe7c71db9},
|
|
|
|
|
+ {__LINE__, 0x0, "r*Fd}ef+5RJQ;+W=4jTR9)R*p!B;]Ed7tkrLi;88U7g@3v!5pk2X6D)vt,.@N8c]@yyEcKi[vwUu@.Ppm@C6%Mv*3Nw}Y,58_aH)", 100, 0xeaa52777},
|
|
|
|
|
+ {__LINE__, 0x0, "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&", 100, 0xcd472048},
|
|
|
|
|
+ {__LINE__, 0x7a30360d, "abacus", 6, 0xf8655a84},
|
|
|
|
|
+ {__LINE__, 0x6fd767ee, "backlog", 7, 0x1ed834b1},
|
|
|
|
|
+ {__LINE__, 0xefeb7589, "campfire", 8, 0x686cfca},
|
|
|
|
|
+ {__LINE__, 0x61cf7e6b, "delta", 5, 0x1554e4b1},
|
|
|
|
|
+ {__LINE__, 0xdc712e2, "executable", 10, 0x761b4254},
|
|
|
|
|
+ {__LINE__, 0xad23c7fd, "file", 4, 0x7abdd09b},
|
|
|
|
|
+ {__LINE__, 0x85cb2317, "greatest", 8, 0x4ba91c6b},
|
|
|
|
|
+ {__LINE__, 0x9eed31b0, "inverter", 8, 0xd5e78ba5},
|
|
|
|
|
+ {__LINE__, 0xb94f34ca, "jigsaw", 6, 0x23649109},
|
|
|
|
|
+ {__LINE__, 0xab058a2, "karate", 6, 0xc5591f41},
|
|
|
|
|
+ {__LINE__, 0x5bff2b7a, "landscape", 9, 0xf10eb644},
|
|
|
|
|
+ {__LINE__, 0x605c9a5f, "machine", 7, 0xbaa0a636},
|
|
|
|
|
+ {__LINE__, 0x51bdeea5, "nanometer", 9, 0x6af89afb},
|
|
|
|
|
+ {__LINE__, 0x85c21c79, "oblivion", 8, 0xecae222b},
|
|
|
|
|
+ {__LINE__, 0x97216f56, "panama", 6, 0x47dffac4},
|
|
|
|
|
+ {__LINE__, 0x18444af2, "quest", 5, 0x70c2fe36},
|
|
|
|
|
+ {__LINE__, 0xbe6ce359, "resource", 8, 0x1471d925},
|
|
|
|
|
+ {__LINE__, 0x843071f1, "secret", 6, 0x50c9a0db},
|
|
|
|
|
+ {__LINE__, 0xf2480c60, "ultimate", 8, 0xf973daf8},
|
|
|
|
|
+ {__LINE__, 0x2d2feb3d, "vector", 6, 0x344ac03d},
|
|
|
|
|
+ {__LINE__, 0x7490310a, "walrus", 6, 0x6d1408ef},
|
|
|
|
|
+ {__LINE__, 0x97d247d4, "xeno", 4, 0xe62670b5},
|
|
|
|
|
+ {__LINE__, 0x93cf7599, "yelling", 7, 0x1b36da38},
|
|
|
|
|
+ {__LINE__, 0x73c84278, "zlib", 4, 0x6432d127},
|
|
|
|
|
+ {__LINE__, 0x228a87d1, "4BJD7PocN1VqX0jXVpWB", 20, 0x997107d0},
|
|
|
|
|
+ {__LINE__, 0xa7a048d0, "F1rPWI7XvDs6nAIRx41l", 20, 0xdc567274},
|
|
|
|
|
+ {__LINE__, 0x1f0ded40, "ldhKlsVkPFOveXgkGtC2", 20, 0xdcc63870},
|
|
|
|
|
+ {__LINE__, 0xa804a62f, "5KKnGOOrs8BvJ35iKTOS", 20, 0x6926cffd},
|
|
|
|
|
+ {__LINE__, 0x508fae6a, "0l1tw7GOcem06Ddu7yn4", 20, 0xb52b38bc},
|
|
|
|
|
+ {__LINE__, 0xe5adaf4f, "MCr47CjPIn9R1IvE1Tm5", 20, 0xf83b8178},
|
|
|
|
|
+ {__LINE__, 0x67136a40, "UcixbzPKTIv0SvILHVdO", 20, 0xc5213070},
|
|
|
|
|
+ {__LINE__, 0xb00c4a10, "dGnAyAhRQDsWw0ESou24", 20, 0xbc7648b0},
|
|
|
|
|
+ {__LINE__, 0x2e0c84b5, "di0nvmY9UYMYDh0r45XT", 20, 0xd8123a72},
|
|
|
|
|
+ {__LINE__, 0x81238d44, "2XKDwHfAhFsV0RhbqtvH", 20, 0xd5ac5620},
|
|
|
|
|
+ {__LINE__, 0xf853aa92, "ZhrANFIiIvRnqClIVyeD", 20, 0xceae099d},
|
|
|
|
|
+ {__LINE__, 0x5a692325, "v7Q9ehzioTOVeDIZioT1", 20, 0xb07d2b24},
|
|
|
|
|
+ {__LINE__, 0x3275b9f, "Yod5hEeKcYqyhfXbhxj2", 20, 0x24ce91df},
|
|
|
|
|
+ {__LINE__, 0x38371feb, "GehSWY2ay4uUKhehXYb0", 20, 0x707b3b30},
|
|
|
|
|
+ {__LINE__, 0xafc8bf62, "kwytJmq6UqpflV8Y8GoE", 20, 0x16abc6a9},
|
|
|
|
|
+ {__LINE__, 0x9b07db73, "70684206568419061514", 20, 0xae1fb7b7},
|
|
|
|
|
+ {__LINE__, 0xe75b214, "42015093765128581010", 20, 0xd4eecd2d},
|
|
|
|
|
+ {__LINE__, 0x72d0fe6f, "88214814356148806939", 20, 0x4660ec7},
|
|
|
|
|
+ {__LINE__, 0xf857a4b1, "43472694284527343838", 20, 0xfd8afdf7},
|
|
|
|
|
+ {__LINE__, 0x54b8e14, "49769333513942933689", 20, 0xc6d1b5f2},
|
|
|
|
|
+ {__LINE__, 0xd6aa5616, "54979784887993251199", 20, 0x32476461},
|
|
|
|
|
+ {__LINE__, 0x11e63098, "58360544869206793220", 20, 0xd917cf1a},
|
|
|
|
|
+ {__LINE__, 0xbe92385, "27347953487840714234", 20, 0x4ad14a12},
|
|
|
|
|
+ {__LINE__, 0x49511de0, "07650690295365319082", 20, 0xe37b5c6c},
|
|
|
|
|
+ {__LINE__, 0x3db13bc1, "42655507906821911703", 20, 0x7cc497f1},
|
|
|
|
|
+ {__LINE__, 0xbb899bea, "29977409200786225655", 20, 0x99781bb2},
|
|
|
|
|
+ {__LINE__, 0xf6cd9436, "85181542907229116674", 20, 0x132256a1},
|
|
|
|
|
+ {__LINE__, 0x9109e6c3, "87963594337989416799", 20, 0xbfdb2c83},
|
|
|
|
|
+ {__LINE__, 0x75770fc, "21395988329504168551", 20, 0x8d9d1e81},
|
|
|
|
|
+ {__LINE__, 0x69b1d19b, "51991013580943379423", 20, 0x7b6d4404},
|
|
|
|
|
+ {__LINE__, 0xc6132975, "*]+@!);({_$;}[_},?{?;(_?,=-][@", 30, 0x8619f010},
|
|
|
|
|
+ {__LINE__, 0xd58cb00c, "_@:_).&(#.[:[{[:)$++-($_;@[)}+", 30, 0x15746ac3},
|
|
|
|
|
+ {__LINE__, 0xb63b8caa, "&[!,[$_==}+.]@!;*(+},[;:)$;)-@", 30, 0xaccf812f},
|
|
|
|
|
+ {__LINE__, 0x8a45a2b8, "]{.[.+?+[[=;[?}_#&;[=)__$$:+=_", 30, 0x78af45de},
|
|
|
|
|
+ {__LINE__, 0xcbe95b78, "-%.)=/[@].:.(:,()$;=%@-$?]{%+%", 30, 0x25b06b59},
|
|
|
|
|
+ {__LINE__, 0x4ef8a54b, "+]#$(@&.=:,*];/.!]%/{:){:@(;)$", 30, 0x4ba0d08f},
|
|
|
|
|
+ {__LINE__, 0x76ad267a, ")-._.:?[&:.=+}(*$/=!.${;(=$@!}", 30, 0xe26b6aac},
|
|
|
|
|
+ {__LINE__, 0x569e613c, ":(_*&%/[[}+,?#$&*+#[([*-/#;%(]", 30, 0x7e2b0a66},
|
|
|
|
|
+ {__LINE__, 0x36aa61da, "{[#-;:$/{)(+[}#]/{&!%(@)%:@-$:", 30, 0xb3430dc7},
|
|
|
|
|
+ {__LINE__, 0xf67222df, "_{$*,}(&,@.)):=!/%(&(,,-?$}}}!", 30, 0x626c17a},
|
|
|
|
|
+ {__LINE__, 0x74b34fd3, "e$98KNzqaV)Y:2X?]77].{gKRD4G5{mHZk,Z)SpU%L3FSgv!Wb8MLAFdi{+fp)c,@8m6v)yXg@]HBDFk?.4&}g5_udE*JHCiH=aL", 100, 0xccf98060},
|
|
|
|
|
+ {__LINE__, 0x351fd770, "r*Fd}ef+5RJQ;+W=4jTR9)R*p!B;]Ed7tkrLi;88U7g@3v!5pk2X6D)vt,.@N8c]@yyEcKi[vwUu@.Ppm@C6%Mv*3Nw}Y,58_aH)", 100, 0xd8b95312},
|
|
|
|
|
+ {__LINE__, 0xc45aef77, "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&", 100, 0xbb1c9912},
|
|
|
|
|
+ {__LINE__, 0xc45aef77, "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&"
|
|
|
|
|
+ "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&"
|
|
|
|
|
+ "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&"
|
|
|
|
|
+ "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&"
|
|
|
|
|
+ "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&"
|
|
|
|
|
+ "h{bcmdC+a;t+Cf{6Y_dFq-{X4Yu&7uNfVDh?q&_u.UWJU],-GiH7ADzb7-V.Q%4=+v!$L9W+T=bP]$_:]Vyg}A.ygD.r;h-D]m%&", 600, 0x888AFA5B}
|
|
|
|
|
+};
|
|
|
|
|
+
|
|
|
|
|
+static const int test_size = sizeof(tests) / sizeof(tests[0]);
|
|
|
|
|
+
|
|
|
|
|
+int main(void)
|
|
|
|
|
+{
|
|
|
|
|
+ int i;
|
|
|
|
|
+ for (i = 0; i < test_size; i++) {
|
|
|
|
|
+ test_crc32(tests[i].crc, (Byte*) tests[i].buf, tests[i].len,
|
|
|
|
|
+ tests[i].expect, tests[i].line);
|
|
|
|
|
+ }
|
|
|
|
|
+ return 0;
|
|
|
|
|
+}
|
|
|
|
|
--
|
|
|
|
|
2.19.1
|
|
|
|
|
2.39.1
|
|
|
|
|
|