mirror of
https://github.com/openssl/openssl.git
synced 2025-03-31 20:10:45 +08:00
Make s_client -quic -debug work
The callback that makes -debug print the data sent/received needed extending for the new QUIC callback codes. Reviewed-by: Tomas Mraz <tomas@openssl.org> Reviewed-by: Hugo Landau <hlandau@openssl.org> Reviewed-by: Paul Dale <pauli@openssl.org> (Merged from https://github.com/openssl/openssl/pull/22480)
This commit is contained in:
parent
8c110311fd
commit
1a91fda183
@ -434,12 +434,15 @@ long bio_dump_callback(BIO *bio, int cmd, const char *argp, size_t len,
|
||||
int argi, long argl, int ret, size_t *processed)
|
||||
{
|
||||
BIO *out;
|
||||
BIO_MMSG_CB_ARGS *mmsgargs;
|
||||
size_t i;
|
||||
|
||||
out = (BIO *)BIO_get_callback_arg(bio);
|
||||
if (out == NULL)
|
||||
return ret;
|
||||
|
||||
if (cmd == (BIO_CB_READ | BIO_CB_RETURN)) {
|
||||
switch (cmd) {
|
||||
case (BIO_CB_READ | BIO_CB_RETURN):
|
||||
if (ret > 0 && processed != NULL) {
|
||||
BIO_printf(out, "read from %p [%p] (%zu bytes => %zu (0x%zX))\n",
|
||||
(void *)bio, (void *)argp, len, *processed, *processed);
|
||||
@ -448,7 +451,9 @@ long bio_dump_callback(BIO *bio, int cmd, const char *argp, size_t len,
|
||||
BIO_printf(out, "read from %p [%p] (%zu bytes => %d)\n",
|
||||
(void *)bio, (void *)argp, len, ret);
|
||||
}
|
||||
} else if (cmd == (BIO_CB_WRITE | BIO_CB_RETURN)) {
|
||||
break;
|
||||
|
||||
case (BIO_CB_WRITE | BIO_CB_RETURN):
|
||||
if (ret > 0 && processed != NULL) {
|
||||
BIO_printf(out, "write to %p [%p] (%zu bytes => %zu (0x%zX))\n",
|
||||
(void *)bio, (void *)argp, len, *processed, *processed);
|
||||
@ -457,6 +462,51 @@ long bio_dump_callback(BIO *bio, int cmd, const char *argp, size_t len,
|
||||
BIO_printf(out, "write to %p [%p] (%zu bytes => %d)\n",
|
||||
(void *)bio, (void *)argp, len, ret);
|
||||
}
|
||||
break;
|
||||
|
||||
case (BIO_CB_RECVMMSG | BIO_CB_RETURN):
|
||||
mmsgargs = (BIO_MMSG_CB_ARGS *)argp;
|
||||
if (ret > 0) {
|
||||
for (i = 0; i < *(mmsgargs->msgs_processed); i++) {
|
||||
BIO_MSG *msg = (BIO_MSG *)((char *)mmsgargs->msg
|
||||
+ (i * mmsgargs->stride));
|
||||
|
||||
BIO_printf(out, "read from %p [%p] (%zu bytes => %zu (0x%zX))\n",
|
||||
(void *)bio, (void *)msg->data, msg->data_len,
|
||||
msg->data_len, msg->data_len);
|
||||
BIO_dump(out, msg->data, msg->data_len);
|
||||
}
|
||||
} else if (mmsgargs->num_msg > 0) {
|
||||
BIO_MSG *msg = mmsgargs->msg;
|
||||
|
||||
BIO_printf(out, "read from %p [%p] (%zu bytes => %d)\n",
|
||||
(void *)bio, (void *)msg->data, msg->data_len, ret);
|
||||
}
|
||||
break;
|
||||
|
||||
case (BIO_CB_SENDMMSG | BIO_CB_RETURN):
|
||||
mmsgargs = (BIO_MMSG_CB_ARGS *)argp;
|
||||
if (ret > 0) {
|
||||
for (i = 0; i < *(mmsgargs->msgs_processed); i++) {
|
||||
BIO_MSG *msg = (BIO_MSG *)((char *)mmsgargs->msg
|
||||
+ (i * mmsgargs->stride));
|
||||
|
||||
BIO_printf(out, "write to %p [%p] (%zu bytes => %zu (0x%zX))\n",
|
||||
(void *)bio, (void *)msg->data, msg->data_len,
|
||||
msg->data_len, msg->data_len);
|
||||
BIO_dump(out, msg->data, msg->data_len);
|
||||
}
|
||||
} else if (mmsgargs->num_msg > 0) {
|
||||
BIO_MSG *msg = mmsgargs->msg;
|
||||
|
||||
BIO_printf(out, "write to %p [%p] (%zu bytes => %d)\n",
|
||||
(void *)bio, (void *)msg->data, msg->data_len, ret);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
/* do nothing */
|
||||
break;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
@ -418,8 +418,8 @@ int BIO_sendmmsg(BIO *b, BIO_MSG *msg,
|
||||
args.msgs_processed = msgs_processed;
|
||||
|
||||
ret = (size_t)bio_call_callback(b, BIO_CB_SENDMMSG, (void *)&args,
|
||||
0, 0, 0, 0, NULL);
|
||||
if (ret == 0)
|
||||
0, 0, 0, 1, NULL);
|
||||
if (ret <= 0)
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -433,7 +433,7 @@ int BIO_sendmmsg(BIO *b, BIO_MSG *msg,
|
||||
|
||||
if (HAS_CALLBACK(b))
|
||||
ret = (size_t)bio_call_callback(b, BIO_CB_SENDMMSG | BIO_CB_RETURN,
|
||||
(void *)&args, ret, 0, 0, 0, NULL);
|
||||
(void *)&args, ret, 0, 0, ret, NULL);
|
||||
|
||||
return ret;
|
||||
}
|
||||
@ -465,8 +465,8 @@ int BIO_recvmmsg(BIO *b, BIO_MSG *msg,
|
||||
args.msgs_processed = msgs_processed;
|
||||
|
||||
ret = bio_call_callback(b, BIO_CB_RECVMMSG, (void *)&args,
|
||||
0, 0, 0, 0, NULL);
|
||||
if (ret == 0)
|
||||
0, 0, 0, 1, NULL);
|
||||
if (ret <= 0)
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -480,7 +480,7 @@ int BIO_recvmmsg(BIO *b, BIO_MSG *msg,
|
||||
|
||||
if (HAS_CALLBACK(b))
|
||||
ret = (size_t)bio_call_callback(b, BIO_CB_RECVMMSG | BIO_CB_RETURN,
|
||||
(void *)&args, ret, 0, 0, 0, NULL);
|
||||
(void *)&args, ret, 0, 0, ret, NULL);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user