diff options
author | Sadaf Ebrahimi <sadafebrahimi@google.com> | 2023-01-13 22:19:38 +0000 |
---|---|---|
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2023-01-13 22:19:38 +0000 |
commit | d5431ffadc76a9b045f69611122b94275a346460 (patch) | |
tree | 839151e2482e971efb6bf88084a98f490f048da4 | |
parent | e21c7248e31c1a0ca4e03a3af867ec60a013a96c (diff) | |
parent | 9cd61595ad6dfb22ff6fe4e86c9f9c6de6af4d23 (diff) | |
download | angle-d5431ffadc76a9b045f69611122b94275a346460.tar.gz |
[automerge] Fix a bug when getting a gzip header extra field with inflate(). 2p: b8b2479b44 am: 9cd61595ad
Original change: https://googleplex-android-review.googlesource.com/c/platform/external/angle/+/20874827
Change-Id: I02cb9d6805f18da01879f2f913daf7d3418182bf
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
-rw-r--r-- | third_party/zlib/contrib/optimizations/inflate.c | 5 | ||||
-rw-r--r-- | third_party/zlib/inflate.c | 5 |
2 files changed, 6 insertions, 4 deletions
diff --git a/third_party/zlib/contrib/optimizations/inflate.c b/third_party/zlib/contrib/optimizations/inflate.c index 81d558bd6e..93776ac579 100644 --- a/third_party/zlib/contrib/optimizations/inflate.c +++ b/third_party/zlib/contrib/optimizations/inflate.c @@ -771,8 +771,9 @@ int flush; if (copy > have) copy = have; if (copy) { if (state->head != Z_NULL && - state->head->extra != Z_NULL) { - len = state->head->extra_len - state->length; + state->head->extra != Z_NULL && + (len = state->head->extra_len - state->length) < + state->head->extra_max) { zmemcpy(state->head->extra + len, next, len + copy > state->head->extra_max ? state->head->extra_max - len : copy); diff --git a/third_party/zlib/inflate.c b/third_party/zlib/inflate.c index 68902e81bd..9057a574bb 100644 --- a/third_party/zlib/inflate.c +++ b/third_party/zlib/inflate.c @@ -760,8 +760,9 @@ int flush; if (copy > have) copy = have; if (copy) { if (state->head != Z_NULL && - state->head->extra != Z_NULL) { - len = state->head->extra_len - state->length; + state->head->extra != Z_NULL && + (len = state->head->extra_len - state->length) < + state->head->extra_max) { zmemcpy(state->head->extra + len, next, len + copy > state->head->extra_max ? state->head->extra_max - len : copy); |