patches for easier mirroring, to eliminate a special copy, to make www.freebsd.org/security a full copy of security.freebsd.org and be eventually be the same. For now files are just sitting there. The symlinks are missing. Discussed on: www (repository location) Discussed with: simon (so)
126 lines
4 KiB
Diff
126 lines
4 KiB
Diff
Index: usr.bin/compress/zopen.c
|
|
===================================================================
|
|
--- usr.bin/compress/zopen.c (revision 225020)
|
|
+++ usr.bin/compress/zopen.c (working copy)
|
|
@@ -486,7 +486,7 @@ zread(void *cookie, char *rbp, int num)
|
|
block_compress = maxbits & BLOCK_MASK;
|
|
maxbits &= BIT_MASK;
|
|
maxmaxcode = 1L << maxbits;
|
|
- if (maxbits > BITS) {
|
|
+ if (maxbits > BITS || maxbits < 12) {
|
|
errno = EFTYPE;
|
|
return (-1);
|
|
}
|
|
@@ -513,17 +513,28 @@ zread(void *cookie, char *rbp, int num)
|
|
for (code = 255; code >= 0; code--)
|
|
tab_prefixof(code) = 0;
|
|
clear_flg = 1;
|
|
- free_ent = FIRST - 1;
|
|
- if ((code = getcode(zs)) == -1) /* O, untimely death! */
|
|
- break;
|
|
+ free_ent = FIRST;
|
|
+ oldcode = -1;
|
|
+ continue;
|
|
}
|
|
incode = code;
|
|
|
|
- /* Special case for KwKwK string. */
|
|
+ /* Special case for kWkWk string. */
|
|
if (code >= free_ent) {
|
|
+ if (code > free_ent || oldcode == -1) {
|
|
+ /* Bad stream. */
|
|
+ errno = EINVAL;
|
|
+ return (-1);
|
|
+ }
|
|
*stackp++ = finchar;
|
|
code = oldcode;
|
|
}
|
|
+ /*
|
|
+ * The above condition ensures that code < free_ent.
|
|
+ * The construction of tab_prefixof in turn guarantees that
|
|
+ * each iteration decreases code and therefore stack usage is
|
|
+ * bound by 1 << BITS - 256.
|
|
+ */
|
|
|
|
/* Generate output characters in reverse order. */
|
|
while (code >= 256) {
|
|
@@ -540,7 +551,7 @@ middle: do {
|
|
} while (stackp > de_stack);
|
|
|
|
/* Generate the new entry. */
|
|
- if ((code = free_ent) < maxmaxcode) {
|
|
+ if ((code = free_ent) < maxmaxcode && oldcode != -1) {
|
|
tab_prefixof(code) = (u_short) oldcode;
|
|
tab_suffixof(code) = finchar;
|
|
free_ent = code + 1;
|
|
Index: usr.bin/gzip/zuncompress.c
|
|
===================================================================
|
|
--- usr.bin/gzip/zuncompress.c (revision 225020)
|
|
+++ usr.bin/gzip/zuncompress.c (working copy)
|
|
@@ -247,7 +247,7 @@ zread(void *cookie, char *rbp, int num)
|
|
zs->zs_block_compress = zs->zs_maxbits & BLOCK_MASK;
|
|
zs->zs_maxbits &= BIT_MASK;
|
|
zs->zs_maxmaxcode = 1L << zs->zs_maxbits;
|
|
- if (zs->zs_maxbits > BITS) {
|
|
+ if (zs->zs_maxbits > BITS || zs->zs_maxbits < 12) {
|
|
errno = EFTYPE;
|
|
return (-1);
|
|
}
|
|
@@ -259,13 +259,7 @@ zread(void *cookie, char *rbp, int num)
|
|
}
|
|
zs->zs_free_ent = zs->zs_block_compress ? FIRST : 256;
|
|
|
|
- zs->u.r.zs_finchar = zs->u.r.zs_oldcode = getcode(zs);
|
|
- if (zs->u.r.zs_oldcode == -1) /* EOF already? */
|
|
- return (0); /* Get out of here */
|
|
-
|
|
- /* First code must be 8 bits = char. */
|
|
- *bp++ = (u_char)zs->u.r.zs_finchar;
|
|
- count--;
|
|
+ zs->u.r.zs_oldcode = -1;
|
|
zs->u.r.zs_stackp = de_stack;
|
|
|
|
while ((zs->u.r.zs_code = getcode(zs)) > -1) {
|
|
@@ -275,17 +269,29 @@ zread(void *cookie, char *rbp, int num)
|
|
zs->u.r.zs_code--)
|
|
tab_prefixof(zs->u.r.zs_code) = 0;
|
|
zs->zs_clear_flg = 1;
|
|
- zs->zs_free_ent = FIRST - 1;
|
|
- if ((zs->u.r.zs_code = getcode(zs)) == -1) /* O, untimely death! */
|
|
- break;
|
|
+ zs->zs_free_ent = FIRST;
|
|
+ zs->u.r.zs_oldcode = -1;
|
|
+ continue;
|
|
}
|
|
zs->u.r.zs_incode = zs->u.r.zs_code;
|
|
|
|
/* Special case for KwKwK string. */
|
|
if (zs->u.r.zs_code >= zs->zs_free_ent) {
|
|
+ if (zs->u.r.zs_code > zs->zs_free_ent ||
|
|
+ zs->u.r.zs_oldcode == -1) {
|
|
+ /* Bad stream. */
|
|
+ errno = EINVAL;
|
|
+ return (-1);
|
|
+ }
|
|
*zs->u.r.zs_stackp++ = zs->u.r.zs_finchar;
|
|
zs->u.r.zs_code = zs->u.r.zs_oldcode;
|
|
}
|
|
+ /*
|
|
+ * The above condition ensures that code < free_ent.
|
|
+ * The construction of tab_prefixof in turn guarantees that
|
|
+ * each iteration decreases code and therefore stack usage is
|
|
+ * bound by 1 << BITS - 256.
|
|
+ */
|
|
|
|
/* Generate output characters in reverse order. */
|
|
while (zs->u.r.zs_code >= 256) {
|
|
@@ -302,7 +308,8 @@ middle: do {
|
|
} while (zs->u.r.zs_stackp > de_stack);
|
|
|
|
/* Generate the new entry. */
|
|
- if ((zs->u.r.zs_code = zs->zs_free_ent) < zs->zs_maxmaxcode) {
|
|
+ if ((zs->u.r.zs_code = zs->zs_free_ent) < zs->zs_maxmaxcode &&
|
|
+ zs->u.r.zs_oldcode != -1) {
|
|
tab_prefixof(zs->u.r.zs_code) = (u_short) zs->u.r.zs_oldcode;
|
|
tab_suffixof(zs->u.r.zs_code) = zs->u.r.zs_finchar;
|
|
zs->zs_free_ent = zs->u.r.zs_code + 1;
|