diff options
| -rw-r--r-- | arch/ppc64/boot/zlib.c | 3 | ||||
| -rw-r--r-- | lib/inflate.c | 16 | ||||
| -rw-r--r-- | lib/zlib_inflate/inftrees.c | 2 |
3 files changed, 12 insertions, 9 deletions
diff --git a/arch/ppc64/boot/zlib.c b/arch/ppc64/boot/zlib.c index 9d5e4e9832d2..78837e884b8b 100644 --- a/arch/ppc64/boot/zlib.c +++ b/arch/ppc64/boot/zlib.c | |||
| @@ -1307,7 +1307,7 @@ local int huft_build( | |||
| 1307 | { | 1307 | { |
| 1308 | *t = (inflate_huft *)Z_NULL; | 1308 | *t = (inflate_huft *)Z_NULL; |
| 1309 | *m = 0; | 1309 | *m = 0; |
| 1310 | return Z_OK; | 1310 | return Z_DATA_ERROR; |
| 1311 | } | 1311 | } |
| 1312 | 1312 | ||
| 1313 | 1313 | ||
| @@ -1351,6 +1351,7 @@ local int huft_build( | |||
| 1351 | if ((j = *p++) != 0) | 1351 | if ((j = *p++) != 0) |
| 1352 | v[x[j]++] = i; | 1352 | v[x[j]++] = i; |
| 1353 | } while (++i < n); | 1353 | } while (++i < n); |
| 1354 | n = x[g]; /* set n to length of v */ | ||
| 1354 | 1355 | ||
| 1355 | 1356 | ||
| 1356 | /* Generate the Huffman codes and for each, make the table entries */ | 1357 | /* Generate the Huffman codes and for each, make the table entries */ |
diff --git a/lib/inflate.c b/lib/inflate.c index 75e7d303c72e..6db6e98d1637 100644 --- a/lib/inflate.c +++ b/lib/inflate.c | |||
| @@ -326,7 +326,7 @@ DEBG("huft1 "); | |||
| 326 | { | 326 | { |
| 327 | *t = (struct huft *)NULL; | 327 | *t = (struct huft *)NULL; |
| 328 | *m = 0; | 328 | *m = 0; |
| 329 | return 0; | 329 | return 2; |
| 330 | } | 330 | } |
| 331 | 331 | ||
| 332 | DEBG("huft2 "); | 332 | DEBG("huft2 "); |
| @@ -374,6 +374,7 @@ DEBG("huft5 "); | |||
| 374 | if ((j = *p++) != 0) | 374 | if ((j = *p++) != 0) |
| 375 | v[x[j]++] = i; | 375 | v[x[j]++] = i; |
| 376 | } while (++i < n); | 376 | } while (++i < n); |
| 377 | n = x[g]; /* set n to length of v */ | ||
| 377 | 378 | ||
| 378 | DEBG("h6 "); | 379 | DEBG("h6 "); |
| 379 | 380 | ||
| @@ -410,12 +411,13 @@ DEBG1("1 "); | |||
| 410 | DEBG1("2 "); | 411 | DEBG1("2 "); |
| 411 | f -= a + 1; /* deduct codes from patterns left */ | 412 | f -= a + 1; /* deduct codes from patterns left */ |
| 412 | xp = c + k; | 413 | xp = c + k; |
| 413 | while (++j < z) /* try smaller tables up to z bits */ | 414 | if (j < z) |
| 414 | { | 415 | while (++j < z) /* try smaller tables up to z bits */ |
| 415 | if ((f <<= 1) <= *++xp) | 416 | { |
| 416 | break; /* enough codes to use up j bits */ | 417 | if ((f <<= 1) <= *++xp) |
| 417 | f -= *xp; /* else deduct codes from patterns */ | 418 | break; /* enough codes to use up j bits */ |
| 418 | } | 419 | f -= *xp; /* else deduct codes from patterns */ |
| 420 | } | ||
| 419 | } | 421 | } |
| 420 | DEBG1("3 "); | 422 | DEBG1("3 "); |
| 421 | z = 1 << j; /* table entries for j-bit table */ | 423 | z = 1 << j; /* table entries for j-bit table */ |
diff --git a/lib/zlib_inflate/inftrees.c b/lib/zlib_inflate/inftrees.c index 874950ec4858..c5f66fbb0dd0 100644 --- a/lib/zlib_inflate/inftrees.c +++ b/lib/zlib_inflate/inftrees.c | |||
| @@ -141,7 +141,7 @@ static int huft_build( | |||
| 141 | { | 141 | { |
| 142 | *t = NULL; | 142 | *t = NULL; |
| 143 | *m = 0; | 143 | *m = 0; |
| 144 | return Z_OK; | 144 | return Z_DATA_ERROR; |
| 145 | } | 145 | } |
| 146 | 146 | ||
| 147 | 147 | ||
