Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
openSUSE:Step:15
curl
curl-CVE-2023-23916.patch
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File curl-CVE-2023-23916.patch of Package curl
From 8c12d047af5849d9d498e13b21a3aaef38e6049f Mon Sep 17 00:00:00 2001 From: Patrick Monnerat <patrick@monnerat.net> Date: Mon, 6 Feb 2023 15:00:43 +0100 Subject: [PATCH] content_encoding: do not reset stage counter for each header --- lib/content_encoding.c | 7 +- lib/urldata.h | 1 + Index: curl-7.60.0/lib/content_encoding.c =================================================================== --- curl-7.60.0.orig/lib/content_encoding.c +++ curl-7.60.0/lib/content_encoding.c @@ -936,7 +936,6 @@ CURLcode Curl_build_unencoding_stack(str { struct Curl_easy *data = conn->data; struct SingleRequest *k = &data->req; - int counter = 0; do { const char *name; @@ -971,9 +970,9 @@ CURLcode Curl_build_unencoding_stack(str if(!encoding) encoding = &error_encoding; /* Defer error at stack use. */ - if(++counter >= MAX_ENCODE_STACK) { - failf(data, "Reject response due to %u content encodings", - counter); + if(k->writer_stack_depth++ >= MAX_ENCODE_STACK) { + failf(data, "Reject response due to more than %u content encodings", + MAX_ENCODE_STACK); return CURLE_BAD_CONTENT_ENCODING; } Index: curl-7.60.0/lib/urldata.h =================================================================== --- curl-7.60.0.orig/lib/urldata.h +++ curl-7.60.0/lib/urldata.h @@ -608,6 +608,7 @@ struct SingleRequest { void *protop; /* Allocated protocol-specific data. Each protocol handler makes sure this points to data it needs. */ + unsigned char writer_stack_depth; /* Unencoding stack depth. */ }; /*
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor