SHA256
3
0
forked from pool/zlib

- Update 410.patch to contain latest fixes from IBM bsc#1166260

* The build behaviour changed

OBS-URL: https://build.opensuse.org/package/show/devel:libraries:c_c++/zlib?expand=0&rev=63
This commit is contained in:
Tomáš Chvátal 2020-04-23 08:19:24 +00:00 committed by Git OBS Bridge
parent 5ad2848cad
commit 4ae3c87bd7
3 changed files with 149 additions and 91 deletions

201
410.patch
View File

@ -1,9 +1,9 @@
From 230b5152e9660eb5e5821c2dbc84ae300dfe1fb1 Mon Sep 17 00:00:00 2001 From 79ccd96ec69d2367291568c586aeaae941d2635c Mon Sep 17 00:00:00 2001
From: Ilya Leoshkevich <iii@linux.ibm.com> From: Ilya Leoshkevich <iii@linux.ibm.com>
Date: Wed, 18 Jul 2018 13:14:07 +0200 Date: Wed, 18 Jul 2018 13:14:07 +0200
Subject: [PATCH] Add support for IBM Z hardware-accelerated deflate Subject: [PATCH] Add support for IBM Z hardware-accelerated deflate
Future versions of IBM Z mainframes will provide DFLTCC instruction, IBM Z mainframes starting from version z15 provide DFLTCC instruction,
which implements deflate algorithm in hardware with estimated which implements deflate algorithm in hardware with estimated
compression and decompression performance orders of magnitude faster compression and decompression performance orders of magnitude faster
than the current zlib and ratio comparable with that of level 1. than the current zlib and ratio comparable with that of level 1.
@ -11,15 +11,15 @@ than the current zlib and ratio comparable with that of level 1.
This patch adds DFLTCC support to zlib. In order to enable it, the This patch adds DFLTCC support to zlib. In order to enable it, the
following build commands should be used: following build commands should be used:
$ CFLAGS=-DDFLTCC ./configure $ ./configure --dfltcc
$ make OBJA=dfltcc.o PIC_OBJA=dfltcc.lo $ make
When built like this, zlib would compress in hardware on level 1, and in When built like this, zlib would compress in hardware on level 1, and in
software on all other levels. Decompression will always happen in software on all other levels. Decompression will always happen in
hardware. In order to enable DFLTCC compression for levels 1-6 (i.e. to hardware. In order to enable DFLTCC compression for levels 1-6 (i.e. to
make it used by default) one could either add -DDFLTCC_LEVEL_MASK=0x7e make it used by default) one could either add -DDFLTCC_LEVEL_MASK=0x7e
at compile time, or set the environment variable DFLTCC_LEVEL_MASK to to CFLAGS at compile time, or set the environment variable
0x7e at run time. DFLTCC_LEVEL_MASK to 0x7e at run time.
Two DFLTCC compression calls produce the same results only when they Two DFLTCC compression calls produce the same results only when they
both are made on machines of the same generation, and when the both are made on machines of the same generation, and when the
@ -34,15 +34,14 @@ DFLTCC does not support every single zlib feature, in particular:
* inflate(Z_BLOCK) and inflate(Z_TREES) * inflate(Z_BLOCK) and inflate(Z_TREES)
* inflateMark() * inflateMark()
* inflatePrime() * inflatePrime()
* deflateParams() after the first deflate() call
When used, these functions will either switch to software, or, in case When used, these functions will either switch to software, or, in case
this is not possible, gracefully fail. this is not possible, gracefully fail.
This patch tries to add DFLTCC support in a least intrusive way. This patch tries to add DFLTCC support in the least intrusive way.
All SystemZ-specific code was placed into a separate file, but All SystemZ-specific code is placed into a separate file, but
unfortunately there is still a noticeable amount of changes in the unfortunately there is still a noticeable amount of changes in the
main zlib code. Below is the summary of those changes. main zlib code. Below is the summary of these changes.
DFLTCC takes as arguments a parameter block, an input buffer, an output DFLTCC takes as arguments a parameter block, an input buffer, an output
buffer and a window. Since DFLTCC requires parameter block to be buffer and a window. Since DFLTCC requires parameter block to be
@ -61,9 +60,12 @@ deflateResetKeep() and inflateResetKeep() now update the DFLTCC
parameter block, which is allocated alongside zlib state, using parameter block, which is allocated alongside zlib state, using
the new DEFLATE_RESET_KEEP_HOOK and INFLATE_RESET_KEEP_HOOK macros. the new DEFLATE_RESET_KEEP_HOOK and INFLATE_RESET_KEEP_HOOK macros.
In order to make unsupported deflateParams(), inflatePrime() and The new DEFLATE_PARAMS_HOOK switches between hardware and software
inflateMark() calls to fail gracefully, the new DEFLATE_PARAMS_HOOK, deflate implementations when deflateParams() arguments demand this.
INFLATE_PRIME_HOOK and INFLATE_MARK_HOOK macros were introduced.
In order to make unsupported inflatePrime() and inflateMark() calls
fail gracefully, the new INFLATE_PRIME_HOOK and INFLATE_MARK_HOOK macros
were introduced.
The algorithm implemented in hardware has different compression ratio The algorithm implemented in hardware has different compression ratio
than the one implemented in software. In order for deflateBound() to than the one implemented in software. In order for deflateBound() to
@ -93,12 +95,12 @@ might be not allocated yet, inflate_ensure_window was factored out of
updatewindow and made ZLIB_INTERNAL. updatewindow and made ZLIB_INTERNAL.
--- ---
Makefile.in | 8 + Makefile.in | 8 +
configure | 13 + configure | 20 +
contrib/README.contrib | 4 + contrib/README.contrib | 4 +
contrib/s390/dfltcc.c | 904 ++++++++++++++++++++++++++++++++++ contrib/s390/dfltcc.c | 920 ++++++++++++++++++++++++++++++++++
contrib/s390/dfltcc.h | 55 +++ contrib/s390/dfltcc.h | 55 ++
contrib/s390/dfltcc_deflate.h | 50 ++ contrib/s390/dfltcc_deflate.h | 54 ++
deflate.c | 60 ++- deflate.c | 68 ++-
deflate.h | 12 + deflate.h | 12 +
gzguts.h | 4 + gzguts.h | 4 +
inflate.c | 85 +++- inflate.c | 85 +++-
@ -106,7 +108,7 @@ updatewindow and made ZLIB_INTERNAL.
test/infcover.c | 2 +- test/infcover.c | 2 +-
test/minigzip.c | 4 + test/minigzip.c | 4 +
trees.c | 13 +- trees.c | 13 +-
14 files changed, 1165 insertions(+), 51 deletions(-) 14 files changed, 1197 insertions(+), 54 deletions(-)
create mode 100644 contrib/s390/dfltcc.c create mode 100644 contrib/s390/dfltcc.c
create mode 100644 contrib/s390/dfltcc.h create mode 100644 contrib/s390/dfltcc.h
create mode 100644 contrib/s390/dfltcc_deflate.h create mode 100644 contrib/s390/dfltcc_deflate.h
@ -134,7 +136,28 @@ Index: zlib-1.2.11/configure
=================================================================== ===================================================================
--- zlib-1.2.11.orig/configure --- zlib-1.2.11.orig/configure
+++ zlib-1.2.11/configure +++ zlib-1.2.11/configure
@@ -911,6 +911,19 @@ EOF @@ -114,6 +114,7 @@ case "$1" in
echo ' configure [--const] [--zprefix] [--prefix=PREFIX] [--eprefix=EXPREFIX]' | tee -a configure.log
echo ' [--static] [--64] [--libdir=LIBDIR] [--sharedlibdir=LIBDIR]' | tee -a configure.log
echo ' [--includedir=INCLUDEDIR] [--archs="-arch i386 -arch x86_64"]' | tee -a configure.log
+ echo ' [--dfltcc]' | tee -a configure.log
exit 0 ;;
-p*=* | --prefix=*) prefix=`echo $1 | sed 's/.*=//'`; shift ;;
-e*=* | --eprefix=*) exec_prefix=`echo $1 | sed 's/.*=//'`; shift ;;
@@ -137,6 +138,12 @@ case "$1" in
-c* | --const) zconst=1; shift ;;
-w* | --warn) warn=1; shift ;;
-d* | --debug) debug=1; shift ;;
+ --dfltcc)
+ CFLAGS="$CFLAGS -DDFLTCC"
+ OBJC="$OBJC dfltcc.o"
+ PIC_OBJC="$PIC_OBJC dfltcc.lo"
+ shift
+ ;;
*)
echo "unknown option: $1" | tee -a configure.log
echo "$0 --help for help" | tee -a configure.log
@@ -911,6 +918,19 @@ EOF
fi fi
fi fi
@ -173,14 +196,14 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
=================================================================== ===================================================================
--- /dev/null --- /dev/null
+++ zlib-1.2.11/contrib/s390/dfltcc.c +++ zlib-1.2.11/contrib/s390/dfltcc.c
@@ -0,0 +1,904 @@ @@ -0,0 +1,920 @@
+/* dfltcc.c - SystemZ DEFLATE CONVERSION CALL support. */ +/* dfltcc.c - SystemZ DEFLATE CONVERSION CALL support. */
+ +
+/* +/*
+ Use the following commands to build zlib with DFLTCC support: + Use the following commands to build zlib with DFLTCC support:
+ +
+ $ CFLAGS=-DDFLTCC ./configure + $ ./configure --dfltcc
+ $ make OBJA=dfltcc.o PIC_OBJA=dfltcc.lo + $ make
+*/ +*/
+ +
+#define _GNU_SOURCE +#define _GNU_SOURCE
@ -407,31 +430,28 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
+/* +/*
+ Compress. + Compress.
+ */ + */
+local inline int dfltcc_are_params_ok(int level, +local inline int dfltcc_can_deflate_with_params(z_streamp strm,
+ int level,
+ uInt window_bits, + uInt window_bits,
+ int strategy, + int strategy);
+ uLong level_mask); +local inline int dfltcc_can_deflate_with_params(strm,
+local inline int dfltcc_are_params_ok(level, window_bits, strategy, level_mask) + level,
+ window_bits,
+ strategy)
+ z_streamp strm;
+ int level; + int level;
+ uInt window_bits; + uInt window_bits;
+ int strategy; + int strategy;
+ uLong level_mask;
+{
+ return (level_mask & (1 << level)) != 0 &&
+ (window_bits == HB_BITS) &&
+ (strategy == Z_FIXED || strategy == Z_DEFAULT_STRATEGY);
+}
+
+
+int ZLIB_INTERNAL dfltcc_can_deflate(strm)
+ z_streamp strm;
+{ +{
+ deflate_state FAR *state = (deflate_state FAR *)strm->state; + deflate_state FAR *state = (deflate_state FAR *)strm->state;
+ struct dfltcc_state FAR *dfltcc_state = GET_DFLTCC_STATE(state); + struct dfltcc_state FAR *dfltcc_state = GET_DFLTCC_STATE(state);
+ +
+ /* Unsupported compression settings */ + /* Unsupported compression settings */
+ if (!dfltcc_are_params_ok(state->level, state->w_bits, state->strategy, + if ((dfltcc_state->level_mask & (1 << level)) == 0)
+ dfltcc_state->level_mask)) + return 0;
+ if (window_bits != HB_BITS)
+ return 0;
+ if (strategy != Z_FIXED && strategy != Z_DEFAULT_STRATEGY)
+ return 0; + return 0;
+ +
+ /* Unsupported hardware */ + /* Unsupported hardware */
@ -443,6 +463,17 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
+ return 1; + return 1;
+} +}
+ +
+int ZLIB_INTERNAL dfltcc_can_deflate(strm)
+ z_streamp strm;
+{
+ deflate_state FAR *state = (deflate_state FAR *)strm->state;
+
+ return dfltcc_can_deflate_with_params(strm,
+ state->level,
+ state->w_bits,
+ state->strategy);
+}
+
+local void dfltcc_gdht OF((z_streamp strm)); +local void dfltcc_gdht OF((z_streamp strm));
+local void dfltcc_gdht(strm) +local void dfltcc_gdht(strm)
+ z_streamp strm; + z_streamp strm;
@ -526,22 +557,24 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
+ soft_bcc = 0; + soft_bcc = 0;
+ no_flush = flush == Z_NO_FLUSH; + no_flush = flush == Z_NO_FLUSH;
+ +
+ /* Trailing empty block. Switch to software, except when Continuation Flag + /* No input data. Return, except when Continuation Flag is set, which means
+ * is set, which means that DFLTCC has buffered some output in the + * that DFLTCC has buffered some output in the parameter block and needs to
+ * parameter block and needs to be called again in order to flush it. + * be called again in order to flush it.
+ */ + */
+ if (flush == Z_FINISH && strm->avail_in == 0 && !param->cf) { + if (strm->avail_in == 0 && !param->cf) {
+ if (param->bcf) {
+ /* A block is still open, and the hardware does not support closing + /* A block is still open, and the hardware does not support closing
+ * blocks without adding data. Thus, close it manually. + * blocks without adding data. Thus, close it manually.
+ */ + */
+ if (!no_flush && param->bcf) {
+ send_eobs(strm, param); + send_eobs(strm, param);
+ param->bcf = 0; + param->bcf = 0;
+ } + }
+ /* Let one of deflate_* functions write a trailing empty block. */
+ if (flush == Z_FINISH)
+ return 0; + return 0;
+ } + /* Clear history. */
+ + if (flush == Z_FULL_FLUSH)
+ if (strm->avail_in == 0 && !param->cf) { + param->hl = 0;
+ *result = need_more; + *result = need_more;
+ return 1; + return 1;
+ } + }
@ -595,7 +628,7 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
+ param->cvt = state->wrap == 2 ? CVT_CRC32 : CVT_ADLER32; + param->cvt = state->wrap == 2 ? CVT_CRC32 : CVT_ADLER32;
+ if (!no_flush) + if (!no_flush)
+ /* We need to close a block. Always do this in software - when there is + /* We need to close a block. Always do this in software - when there is
+ * no input data, the hardware will not nohor BCC. */ + * no input data, the hardware will not honor BCC. */
+ soft_bcc = 1; + soft_bcc = 1;
+ if (flush == Z_FINISH && !param->bcf) + if (flush == Z_FINISH && !param->bcf)
+ /* We are about to open a BFINAL block, set Block Header Final bit + /* We are about to open a BFINAL block, set Block Header Final bit
@ -610,8 +643,8 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
+ param->sbb = (unsigned int)state->bi_valid; + param->sbb = (unsigned int)state->bi_valid;
+ if (param->sbb > 0) + if (param->sbb > 0)
+ *strm->next_out = (Bytef)state->bi_buf; + *strm->next_out = (Bytef)state->bi_buf;
+ if (param->hl) + /* Honor history and check value */
+ param->nt = 0; /* Honor history */ + param->nt = 0;
+ param->cv = state->wrap == 2 ? ZSWAP32(strm->adler) : strm->adler; + param->cv = state->wrap == 2 ? ZSWAP32(strm->adler) : strm->adler;
+ +
+ /* When opening a block, choose a Huffman-Table Type */ + /* When opening a block, choose a Huffman-Table Type */
@ -971,17 +1004,20 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
+ fly with deflateParams, we need to convert between hardware and software + fly with deflateParams, we need to convert between hardware and software
+ window formats. + window formats.
+*/ +*/
+int ZLIB_INTERNAL dfltcc_deflate_params(strm, level, strategy) +int ZLIB_INTERNAL dfltcc_deflate_params(strm, level, strategy, flush)
+ z_streamp strm; + z_streamp strm;
+ int level; + int level;
+ int strategy; + int strategy;
+ int *flush;
+{ +{
+ deflate_state FAR *state = (deflate_state FAR *)strm->state; + deflate_state FAR *state = (deflate_state FAR *)strm->state;
+ struct dfltcc_state FAR *dfltcc_state = GET_DFLTCC_STATE(state); + struct dfltcc_state FAR *dfltcc_state = GET_DFLTCC_STATE(state);
+ struct dfltcc_param_v0 FAR *param = &dfltcc_state->param; + struct dfltcc_param_v0 FAR *param = &dfltcc_state->param;
+ int could_deflate = dfltcc_can_deflate(strm); + int could_deflate = dfltcc_can_deflate(strm);
+ int can_deflate = dfltcc_are_params_ok(level, state->w_bits, strategy, + int can_deflate = dfltcc_can_deflate_with_params(strm,
+ dfltcc_state->level_mask); + level,
+ state->w_bits,
+ strategy);
+ +
+ if (can_deflate == could_deflate) + if (can_deflate == could_deflate)
+ /* We continue to work in the same mode - no changes needed */ + /* We continue to work in the same mode - no changes needed */
@ -991,8 +1027,11 @@ Index: zlib-1.2.11/contrib/s390/dfltcc.c
+ /* DFLTCC was not used yet - no changes needed */ + /* DFLTCC was not used yet - no changes needed */
+ return Z_OK; + return Z_OK;
+ +
+ /* Switching between hardware and software is not implemented */ + /* For now, do not convert between window formats - simply get rid of the
+ return Z_STREAM_ERROR; + * old data instead.
+ */
+ *flush = Z_FULL_FLUSH;
+ return Z_OK;
+} +}
+ +
+/* +/*
@ -1142,7 +1181,7 @@ Index: zlib-1.2.11/contrib/s390/dfltcc_deflate.h
=================================================================== ===================================================================
--- /dev/null --- /dev/null
+++ zlib-1.2.11/contrib/s390/dfltcc_deflate.h +++ zlib-1.2.11/contrib/s390/dfltcc_deflate.h
@@ -0,0 +1,50 @@ @@ -0,0 +1,54 @@
+#ifndef DFLTCC_DEFLATE_H +#ifndef DFLTCC_DEFLATE_H
+#define DFLTCC_DEFLATE_H +#define DFLTCC_DEFLATE_H
+ +
@ -1154,7 +1193,8 @@ Index: zlib-1.2.11/contrib/s390/dfltcc_deflate.h
+ block_state *result)); + block_state *result));
+int ZLIB_INTERNAL dfltcc_deflate_params OF((z_streamp strm, +int ZLIB_INTERNAL dfltcc_deflate_params OF((z_streamp strm,
+ int level, + int level,
+ int strategy)); + int strategy,
+ int *flush));
+int ZLIB_INTERNAL dfltcc_deflate_set_dictionary OF((z_streamp strm, +int ZLIB_INTERNAL dfltcc_deflate_set_dictionary OF((z_streamp strm,
+ const Bytef *dictionary, + const Bytef *dictionary,
+ uInt dict_length)); + uInt dict_length));
@ -1174,11 +1214,14 @@ Index: zlib-1.2.11/contrib/s390/dfltcc_deflate.h
+ } while (0) + } while (0)
+#define DEFLATE_RESET_KEEP_HOOK(strm) \ +#define DEFLATE_RESET_KEEP_HOOK(strm) \
+ dfltcc_reset((strm), sizeof(deflate_state)) + dfltcc_reset((strm), sizeof(deflate_state))
+#define DEFLATE_PARAMS_HOOK(strm, level, strategy) \ +#define DEFLATE_PARAMS_HOOK(strm, level, strategy, hook_flush) \
+ do { \ + do { \
+ int err; \ + int err; \
+\ +\
+ err = dfltcc_deflate_params((strm), (level), (strategy)); \ + err = dfltcc_deflate_params((strm), \
+ (level), \
+ (strategy), \
+ (hook_flush)); \
+ if (err == Z_STREAM_ERROR) \ + if (err == Z_STREAM_ERROR) \
+ return err; \ + return err; \
+ } while (0) + } while (0)
@ -1221,7 +1264,7 @@ Index: zlib-1.2.11/deflate.c
+#define DEFLATE_SET_DICTIONARY_HOOK(strm, dict, dict_len) do {} while (0) +#define DEFLATE_SET_DICTIONARY_HOOK(strm, dict, dict_len) do {} while (0)
+#define DEFLATE_GET_DICTIONARY_HOOK(strm, dict, dict_len) do {} while (0) +#define DEFLATE_GET_DICTIONARY_HOOK(strm, dict, dict_len) do {} while (0)
+#define DEFLATE_RESET_KEEP_HOOK(strm) do {} while (0) +#define DEFLATE_RESET_KEEP_HOOK(strm) do {} while (0)
+#define DEFLATE_PARAMS_HOOK(strm, level, strategy) do {} while (0) +#define DEFLATE_PARAMS_HOOK(strm, level, strategy, hook_flush) do {} while (0)
+#define DEFLATE_BOUND_ADJUST_COMPLEN(strm, complen, sourceLen) do {} while (0) +#define DEFLATE_BOUND_ADJUST_COMPLEN(strm, complen, sourceLen) do {} while (0)
+#define DEFLATE_NEED_CONSERVATIVE_BOUND(strm) 0 +#define DEFLATE_NEED_CONSERVATIVE_BOUND(strm) 0
+#define DEFLATE_HOOK(strm, flush, bstate) 0 +#define DEFLATE_HOOK(strm, flush, bstate) 0
@ -1285,15 +1328,33 @@ Index: zlib-1.2.11/deflate.c
return Z_OK; return Z_OK;
} }
@@ -584,6 +601,7 @@ int ZEXPORT deflateParams(strm, level, s @@ -572,6 +589,7 @@ int ZEXPORT deflateParams(strm, level, s
{
deflate_state *s;
compress_func func;
+ int hook_flush = Z_NO_FLUSH;
if (deflateStateCheck(strm)) return Z_STREAM_ERROR;
s = strm->state;
@@ -584,12 +602,14 @@ int ZEXPORT deflateParams(strm, level, s
if (level < 0 || level > 9 || strategy < 0 || strategy > Z_FIXED) { if (level < 0 || level > 9 || strategy < 0 || strategy > Z_FIXED) {
return Z_STREAM_ERROR; return Z_STREAM_ERROR;
} }
+ DEFLATE_PARAMS_HOOK(strm, level, strategy); + DEFLATE_PARAMS_HOOK(strm, level, strategy, &hook_flush);
func = configuration_table[s->level].func; func = configuration_table[s->level].func;
if ((strategy != s->strategy || func != configuration_table[level].func) && - if ((strategy != s->strategy || func != configuration_table[level].func) &&
@@ -659,6 +677,7 @@ uLong ZEXPORT deflateBound(strm, sourceL - s->high_water) {
+ if ((strategy != s->strategy || func != configuration_table[level].func ||
+ hook_flush != Z_NO_FLUSH) && s->high_water) {
/* Flush the last buffer: */
- int err = deflate(strm, Z_BLOCK);
+ int err = deflate(strm, RANK(hook_flush) > RANK(Z_BLOCK) ?
+ hook_flush : Z_BLOCK);
if (err == Z_STREAM_ERROR)
return err;
if (strm->avail_out == 0)
@@ -659,6 +679,7 @@ uLong ZEXPORT deflateBound(strm, sourceL
/* conservative upper bound for compressed data */ /* conservative upper bound for compressed data */
complen = sourceLen + complen = sourceLen +
((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 5; ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 5;
@ -1301,7 +1362,7 @@ Index: zlib-1.2.11/deflate.c
/* if can't get parameters, return conservative bound plus zlib wrapper */ /* if can't get parameters, return conservative bound plus zlib wrapper */
if (deflateStateCheck(strm)) if (deflateStateCheck(strm))
@@ -700,7 +719,8 @@ uLong ZEXPORT deflateBound(strm, sourceL @@ -700,7 +721,8 @@ uLong ZEXPORT deflateBound(strm, sourceL
} }
/* if not default parameters, return conservative bound */ /* if not default parameters, return conservative bound */
@ -1311,7 +1372,7 @@ Index: zlib-1.2.11/deflate.c
return complen + wraplen; return complen + wraplen;
/* default settings: return tight bound for that case */ /* default settings: return tight bound for that case */
@@ -727,7 +747,7 @@ local void putShortMSB (s, b) @@ -727,7 +749,7 @@ local void putShortMSB (s, b)
* applications may wish to modify it to avoid allocating a large * applications may wish to modify it to avoid allocating a large
* strm->next_out buffer and copying into it. (See also read_buf()). * strm->next_out buffer and copying into it. (See also read_buf()).
*/ */
@ -1320,7 +1381,7 @@ Index: zlib-1.2.11/deflate.c
z_streamp strm; z_streamp strm;
{ {
unsigned len; unsigned len;
@@ -997,7 +1017,8 @@ int ZEXPORT deflate (strm, flush) @@ -997,7 +1019,8 @@ int ZEXPORT deflate (strm, flush)
(flush != Z_NO_FLUSH && s->status != FINISH_STATE)) { (flush != Z_NO_FLUSH && s->status != FINISH_STATE)) {
block_state bstate; block_state bstate;
@ -1330,7 +1391,7 @@ Index: zlib-1.2.11/deflate.c
s->strategy == Z_HUFFMAN_ONLY ? deflate_huff(s, flush) : s->strategy == Z_HUFFMAN_ONLY ? deflate_huff(s, flush) :
s->strategy == Z_RLE ? deflate_rle(s, flush) : s->strategy == Z_RLE ? deflate_rle(s, flush) :
(*(configuration_table[s->level].func))(s, flush); (*(configuration_table[s->level].func))(s, flush);
@@ -1086,9 +1107,9 @@ int ZEXPORT deflateEnd (strm) @@ -1086,9 +1109,9 @@ int ZEXPORT deflateEnd (strm)
TRY_FREE(strm, strm->state->pending_buf); TRY_FREE(strm, strm->state->pending_buf);
TRY_FREE(strm, strm->state->head); TRY_FREE(strm, strm->state->head);
TRY_FREE(strm, strm->state->prev); TRY_FREE(strm, strm->state->prev);
@ -1342,7 +1403,7 @@ Index: zlib-1.2.11/deflate.c
strm->state = Z_NULL; strm->state = Z_NULL;
return status == BUSY_STATE ? Z_DATA_ERROR : Z_OK; return status == BUSY_STATE ? Z_DATA_ERROR : Z_OK;
@@ -1119,13 +1140,13 @@ int ZEXPORT deflateCopy (dest, source) @@ -1119,13 +1142,13 @@ int ZEXPORT deflateCopy (dest, source)
zmemcpy((voidpf)dest, (voidpf)source, sizeof(z_stream)); zmemcpy((voidpf)dest, (voidpf)source, sizeof(z_stream));
@ -1359,7 +1420,7 @@ Index: zlib-1.2.11/deflate.c
ds->prev = (Posf *) ZALLOC(dest, ds->w_size, sizeof(Pos)); ds->prev = (Posf *) ZALLOC(dest, ds->w_size, sizeof(Pos));
ds->head = (Posf *) ZALLOC(dest, ds->hash_size, sizeof(Pos)); ds->head = (Posf *) ZALLOC(dest, ds->hash_size, sizeof(Pos));
overlay = (ushf *) ZALLOC(dest, ds->lit_bufsize, sizeof(ush)+2); overlay = (ushf *) ZALLOC(dest, ds->lit_bufsize, sizeof(ush)+2);
@@ -1174,7 +1195,8 @@ local unsigned read_buf(strm, buf, size) @@ -1174,7 +1197,8 @@ local unsigned read_buf(strm, buf, size)
strm->avail_in -= len; strm->avail_in -= len;
zmemcpy(buf, strm->next_in, len); zmemcpy(buf, strm->next_in, len);

View File

@ -1,3 +1,9 @@
-------------------------------------------------------------------
Thu Apr 23 08:17:19 UTC 2020 - Tomáš Chvátal <tchvatal@suse.com>
- Update 410.patch to contain latest fixes from IBM bsc#1166260
* The build behaviour changed
------------------------------------------------------------------- -------------------------------------------------------------------
Tue Oct 29 10:47:18 UTC 2019 - Tomáš Chvátal <tchvatal@suse.com> Tue Oct 29 10:47:18 UTC 2019 - Tomáš Chvátal <tchvatal@suse.com>

View File

@ -21,7 +21,6 @@ Version: 1.2.11
Release: 0 Release: 0
Summary: Library implementing the DEFLATE compression algorithm Summary: Library implementing the DEFLATE compression algorithm
License: Zlib License: Zlib
Group: Development/Libraries/C and C++
URL: http://www.zlib.net/ URL: http://www.zlib.net/
Source0: http://zlib.net/zlib-%{version}.tar.gz Source0: http://zlib.net/zlib-%{version}.tar.gz
Source1: http://zlib.net/zlib-%{version}.tar.gz.asc Source1: http://zlib.net/zlib-%{version}.tar.gz.asc
@ -55,7 +54,6 @@ format.
%package -n libz1 %package -n libz1
Summary: Library implementing the DEFLATE compression algorithm Summary: Library implementing the DEFLATE compression algorithm
Group: System/Libraries
Provides: %{name} = %{version}-%{release} Provides: %{name} = %{version}-%{release}
Obsoletes: %{name} < %{version}-%{release} Obsoletes: %{name} < %{version}-%{release}
@ -67,7 +65,6 @@ format.
%package devel %package devel
Summary: Development files for zlib, a data compression library Summary: Development files for zlib, a data compression library
Group: Development/Languages/C and C++
Requires: glibc-devel Requires: glibc-devel
Requires: libz1 = %{version} Requires: libz1 = %{version}
@ -89,7 +86,6 @@ compression.
%package devel-static %package devel-static
Summary: Static library for zlib Summary: Static library for zlib
Group: Development/Languages/C and C++
Requires: %{name}-devel = %{version} Requires: %{name}-devel = %{version}
Provides: %{name}-devel:%{_libdir}/libz.a Provides: %{name}-devel:%{_libdir}/libz.a
@ -104,14 +100,12 @@ used for development.
%package -n libminizip1 %package -n libminizip1
Summary: Library for manipulation with .zip archives Summary: Library for manipulation with .zip archives
Group: System/Libraries
%description -n libminizip1 %description -n libminizip1
Minizip is a library for manipulation with files from .zip archives. Minizip is a library for manipulation with files from .zip archives.
%package -n minizip-devel %package -n minizip-devel
Summary: Development files for the minizip library Summary: Development files for the minizip library
Group: Development/Languages/C and C++
Requires: %{name}-devel = %{version} Requires: %{name}-devel = %{version}
Requires: libminizip1 = %{version} Requires: libminizip1 = %{version}
Requires: pkgconfig Requires: pkgconfig
@ -133,26 +127,23 @@ cp %{SOURCE4} .
%build %build
%global _lto_cflags %{_lto_cflags} -ffat-lto-objects %global _lto_cflags %{_lto_cflags} -ffat-lto-objects
export LDFLAGS="-Wl,-z,relro,-z,now" export LDFLAGS="-Wl,-z,relro,-z,now"
%ifarch s390x s390
export CFLAGS="%{optflags} -DDFLTCC"
%define addopts OBJA=dfltcc.o PIC_OBJA=dfltcc.lo
%else
export CFLAGS="%{optflags}" export CFLAGS="%{optflags}"
%define addopts %{nil}
%endif
# For sure not autotools build # For sure not autotools build
CC="cc" ./configure \ CC="cc" ./configure \
--shared \ --shared \
--prefix=%{_prefix} \ --prefix=%{_prefix} \
--libdir=/%{_lib} --libdir=/%{_lib}
%ifarch s390x s390
--dfltcc
%endif
%if %{do_profiling} %if %{do_profiling}
make %{?_smp_mflags} CFLAGS="%{optflags} %{cflags_profile_generate}" %{addopts} make %{?_smp_mflags} CFLAGS="%{optflags} %{cflags_profile_generate}"
make check %{?_smp_mflags} make check %{?_smp_mflags}
make %{?_smp_mflags} clean make %{?_smp_mflags} clean
make %{?_smp_mflags} CFLAGS="%{optflags} %{cflags_profile_feedback}" %{addopts} make %{?_smp_mflags} CFLAGS="%{optflags} %{cflags_profile_feedback}"
%else %else
make %{?_smp_mflags} %{addopts} make %{?_smp_mflags}
%endif %endif
# And build minizip # And build minizip
@ -161,7 +152,7 @@ autoreconf -fvi
%configure \ %configure \
--disable-static \ --disable-static \
--disable-silent-rules --disable-silent-rules
make %{?_smp_mflags} %{addopts} make %{?_smp_mflags}
%check %check
make check %{?_smp_mflags} make check %{?_smp_mflags}