forked from envoyproxy/envoy
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[bp/1.31] c-ares gRPC library: fix a bug impacting gRPC's use of c-ar…
…es (envoyproxy#35487) Signed-off-by: Adi Suissa-Peleg <adip@google.com>
- Loading branch information
Showing
3 changed files
with
66 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
From a070d7835d667b2fae5266fe1b790677dae47d25 Mon Sep 17 00:00:00 2001 | ||
From: Brad House <brad@brad-house.com> | ||
Date: Thu, 12 Oct 2023 09:29:14 -0400 | ||
Subject: [PATCH] Socket callbacks were passed SOCK_STREAM instead of | ||
SOCK_DGRAM on udp | ||
|
||
A regression was introduced in 1.20.0 that would pass SOCK_STREAM on udp | ||
connections due to code refactoring. If a client application validated this | ||
data, it could cause issues as seen in gRPC. | ||
|
||
Fixes Issue: #571 | ||
Fix By: Brad House (@bradh352) | ||
--- | ||
src/lib/ares_process.c | 10 ++++------ | ||
1 file changed, 4 insertions(+), 6 deletions(-) | ||
|
||
diff --git a/src/lib/ares_process.c b/src/lib/ares_process.c | ||
index ca597db7ad..2f8e4de30d 100644 | ||
--- a/src/lib/ares_process.c | ||
+++ b/src/lib/ares_process.c | ||
@@ -1065,6 +1065,7 @@ static ares_status_t open_socket(ares_channel channel, | ||
unsigned short port; | ||
struct server_connection *conn; | ||
ares__llist_node_t *node; | ||
+ int type = is_tcp?SOCK_STREAM:SOCK_DGRAM; | ||
|
||
if (is_tcp) { | ||
port = aresx_sitous(server->addr.tcp_port? | ||
@@ -1098,8 +1099,7 @@ static ares_status_t open_socket(ares_channel channel, | ||
} | ||
|
||
/* Acquire a socket. */ | ||
- s = ares__open_socket(channel, server->addr.family, | ||
- is_tcp?SOCK_STREAM:SOCK_DGRAM, 0); | ||
+ s = ares__open_socket(channel, server->addr.family, type, 0); | ||
if (s == ARES_SOCKET_BAD) | ||
return ARES_ECONNREFUSED; | ||
|
||
@@ -1129,8 +1129,7 @@ static ares_status_t open_socket(ares_channel channel, | ||
#endif | ||
|
||
if (channel->sock_config_cb) { | ||
- int err = channel->sock_config_cb(s, SOCK_STREAM, | ||
- channel->sock_config_cb_data); | ||
+ int err = channel->sock_config_cb(s, type, channel->sock_config_cb_data); | ||
if (err < 0) { | ||
ares__close_socket(channel, s); | ||
return ARES_ECONNREFUSED; | ||
@@ -1148,8 +1147,7 @@ static ares_status_t open_socket(ares_channel channel, | ||
} | ||
|
||
if (channel->sock_create_cb) { | ||
- int err = channel->sock_create_cb(s, SOCK_STREAM, | ||
- channel->sock_create_cb_data); | ||
+ int err = channel->sock_create_cb(s, type, channel->sock_create_cb_data); | ||
if (err < 0) { | ||
ares__close_socket(channel, s); | ||
return ARES_ECONNREFUSED; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters