diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2018-02-27 13:03:44 +0100 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2018-02-27 13:03:44 +0100 |
commit | d82ea2ba8f9486d338b3aefe161afd4f77ce7a86 (patch) | |
tree | b07fd8b2e617dd973f2ea39c448c1fd079bd5677 /networking/tcpudp_perhost.c | |
parent | 0e0209ac5312fb0a4cf740f59e3564c6549f4d77 (diff) | |
download | busybox-w32-d82ea2ba8f9486d338b3aefe161afd4f77ce7a86.tar.gz busybox-w32-d82ea2ba8f9486d338b3aefe161afd4f77ce7a86.tar.bz2 busybox-w32-d82ea2ba8f9486d338b3aefe161afd4f77ce7a86.zip |
tcpudp: shrink per-host rate-limiting code
function old new delta
tcpudpsvd_main 1775 1780 +5
ipsvd_perhost_add 108 107 -1
cclen 4 - -4
cc 4 - -4
ipsvd_perhost_init 30 25 -5
ipsvd_perhost_remove 80 44 -36
------------------------------------------------------------------------------
(add/remove: 0/2 grow/shrink: 1/3 up/down: 5/-50) Total: -45 bytes
text data bss dec hex filename
933358 473 6852 940683 e5a8b busybox_old
933326 473 6844 940643 e5a63 busybox_unstripped
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'networking/tcpudp_perhost.c')
-rw-r--r-- | networking/tcpudp_perhost.c | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/networking/tcpudp_perhost.c b/networking/tcpudp_perhost.c index 105410883..2643f8d16 100644 --- a/networking/tcpudp_perhost.c +++ b/networking/tcpudp_perhost.c | |||
@@ -10,25 +10,21 @@ | |||
10 | #include "libbb.h" | 10 | #include "libbb.h" |
11 | #include "tcpudp_perhost.h" | 11 | #include "tcpudp_perhost.h" |
12 | 12 | ||
13 | static struct hcc *cc; | 13 | struct hcc* FAST_FUNC ipsvd_perhost_init(unsigned c) |
14 | static unsigned cclen; | ||
15 | |||
16 | /* to be optimized */ | ||
17 | |||
18 | void ipsvd_perhost_init(unsigned c) | ||
19 | { | 14 | { |
20 | // free(cc); | 15 | // free(cc); |
21 | cc = xzalloc(c * sizeof(*cc)); | 16 | struct hcc *cc = xzalloc((c + 1) * sizeof(*cc)); |
22 | cclen = c; | 17 | cc[c].pid = -1; /* "end" marker */ |
18 | return cc; | ||
23 | } | 19 | } |
24 | 20 | ||
25 | unsigned ipsvd_perhost_add(char *ip, unsigned maxconn, struct hcc **hccpp) | 21 | unsigned FAST_FUNC ipsvd_perhost_add(struct hcc *cc, char *ip, unsigned maxconn, struct hcc **hccpp) |
26 | { | 22 | { |
27 | unsigned i; | 23 | unsigned i; |
28 | unsigned conn = 1; | 24 | unsigned conn = 1; |
29 | int freepos = -1; | 25 | int freepos = -1; |
30 | 26 | ||
31 | for (i = 0; i < cclen; ++i) { | 27 | for (i = 0; cc[i].pid >= 0; ++i) { |
32 | if (!cc[i].ip) { | 28 | if (!cc[i].ip) { |
33 | freepos = i; | 29 | freepos = i; |
34 | continue; | 30 | continue; |
@@ -46,10 +42,10 @@ unsigned ipsvd_perhost_add(char *ip, unsigned maxconn, struct hcc **hccpp) | |||
46 | return conn; | 42 | return conn; |
47 | } | 43 | } |
48 | 44 | ||
49 | void ipsvd_perhost_remove(int pid) | 45 | void FAST_FUNC ipsvd_perhost_remove(struct hcc *cc, int pid) |
50 | { | 46 | { |
51 | unsigned i; | 47 | unsigned i; |
52 | for (i = 0; i < cclen; ++i) { | 48 | for (i = 0; cc[i].pid >= 0; ++i) { |
53 | if (cc[i].pid == pid) { | 49 | if (cc[i].pid == pid) { |
54 | free(cc[i].ip); | 50 | free(cc[i].ip); |
55 | cc[i].ip = NULL; | 51 | cc[i].ip = NULL; |
@@ -59,7 +55,7 @@ void ipsvd_perhost_remove(int pid) | |||
59 | } | 55 | } |
60 | } | 56 | } |
61 | 57 | ||
62 | //void ipsvd_perhost_free(void) | 58 | //void ipsvd_perhost_free(struct hcc *cc) |
63 | //{ | 59 | //{ |
64 | // free(cc); | 60 | // free(cc); |
65 | //} | 61 | //} |