From b07785d2d1b1ed42ea5f863c006f6ee60eceabc2 Mon Sep 17 00:00:00 2001 From: tiptorrent development team Date: Thu, 9 Sep 2021 12:41:27 +0200 Subject: activate pending clients only for large files small files should not activate pending clients, otherwise max_clients is not fulfilled. --- src/core.c | 6 ++++-- src/core.h | 5 +++++ src/handler.c | 2 +- 3 files changed, 10 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/core.c b/src/core.c index d086dfe..95bb614 100644 --- a/src/core.c +++ b/src/core.c @@ -47,10 +47,12 @@ static void tip_client_release(struct ev_loop *loop, struct tip_client *cli) free((void *)cli->uri); free((void *)cli->path); - free(cli); num_clients--; - tip_client_activate_pending(); + if (tip_client_large_file(cli)) + tip_client_activate_pending(); + + free(cli); } static int tip_client_payload_too_large(struct tip_client *cli) diff --git a/src/core.h b/src/core.h index c1ce388..4b35f82 100644 --- a/src/core.h +++ b/src/core.h @@ -55,6 +55,11 @@ static inline int tip_client_socket(const struct tip_client *cli) return cli->io.fd; } +static inline bool tip_client_large_file(const struct tip_client *cli) +{ + return cli->size > FILE_SIZE_THRESHOLD; +} + void tip_client_pending(struct tip_client *cli); bool tip_client_redirect(struct tip_client *cli); diff --git a/src/handler.c b/src/handler.c index 9bcec71..ab9fdc4 100644 --- a/src/handler.c +++ b/src/handler.c @@ -101,7 +101,7 @@ int tip_client_state_process_payload(struct tip_client *cli) cli->allow_redirect = allow_redirect; num_clients++; - if (cli->size > FILE_SIZE_THRESHOLD && num_clients > max_clients) { + if (tip_client_large_file(cli) && num_clients > max_clients) { if (!tip_client_redirect(cli)) { tip_client_pending(cli); return 1; -- cgit v1.2.3-18-g5258