summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTatsuhiro Tsujikawa <tatsuhiro.t@gmail.com>2021-09-12 15:27:33 +0900
committerDaniel Stenberg <daniel@haxx.se>2021-09-12 12:34:32 +0200
commit24a7cbe9d22cb1783a33b94288b656191b0e4375 (patch)
treed54951264faf096320e67ccf310ec733fe65f41b
parentdbe693e76973a12dfe39466c10cd83922813feef (diff)
downloadcurl-24a7cbe9d22cb1783a33b94288b656191b0e4375.tar.gz
ngtcp2: fix build with ngtcp2 and nghttp3
ngtcp2_conn_client_new and nghttp3_conn_client_new are now macros. Check the wrapped functions instead. ngtcp2_stream_close callback now takes flags parameter. Closes #7709
-rw-r--r--configure.ac4
-rw-r--r--lib/vquic/ngtcp2.c8
2 files changed, 8 insertions, 4 deletions
diff --git a/configure.ac b/configure.ac
index 34ec0efd3..152b0472e 100644
--- a/configure.ac
+++ b/configure.ac
@@ -2677,7 +2677,7 @@ if test X"$want_tcp2" != Xno; then
if test "x$cross_compiling" != "xyes"; then
DIR_TCP2=`echo $LD_TCP2 | $SED -e 's/^-L//'`
fi
- AC_CHECK_LIB(ngtcp2, ngtcp2_conn_client_new,
+ AC_CHECK_LIB(ngtcp2, ngtcp2_conn_client_new_versioned,
[
AC_CHECK_HEADERS(ngtcp2/ngtcp2.h,
NGTCP2_ENABLED=1
@@ -2876,7 +2876,7 @@ if test X"$want_nghttp3" != Xno; then
if test "x$cross_compiling" != "xyes"; then
DIR_NGHTTP3=`echo $LD_NGHTTP3 | $SED -e 's/^-L//'`
fi
- AC_CHECK_LIB(nghttp3, nghttp3_conn_client_new,
+ AC_CHECK_LIB(nghttp3, nghttp3_conn_client_new_versioned,
[
AC_CHECK_HEADERS(nghttp3/nghttp3.h,
curl_h3_msg="enabled (ngtcp2 + nghttp3)"
diff --git a/lib/vquic/ngtcp2.c b/lib/vquic/ngtcp2.c
index 776cdc069..9fcfe81a8 100644
--- a/lib/vquic/ngtcp2.c
+++ b/lib/vquic/ngtcp2.c
@@ -559,8 +559,8 @@ cb_acked_stream_data_offset(ngtcp2_conn *tconn, int64_t stream_id,
return 0;
}
-static int cb_stream_close(ngtcp2_conn *tconn, int64_t stream_id,
- uint64_t app_error_code,
+static int cb_stream_close(ngtcp2_conn *tconn, uint32_t flags,
+ int64_t stream_id, uint64_t app_error_code,
void *user_data, void *stream_user_data)
{
struct quicsocket *qs = (struct quicsocket *)user_data;
@@ -569,6 +569,10 @@ static int cb_stream_close(ngtcp2_conn *tconn, int64_t stream_id,
(void)stream_user_data;
/* stream is closed... */
+ if(!(flags & NGTCP2_STREAM_CLOSE_FLAG_APP_ERROR_CODE_SET)) {
+ app_error_code = NGHTTP3_H3_NO_ERROR;
+ }
+
rv = nghttp3_conn_close_stream(qs->h3conn, stream_id,
app_error_code);
if(rv) {