diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2019-05-31 23:39:22 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2019-05-31 23:39:22 +0200 |
commit | 65c34c52df3ed46f0b811d1858c271a373ab6af5 (patch) | |
tree | 8c9a08f6ff1b442dbb642995d1870cb2efd87a0d /networking/udhcp/signalpipe.c | |
parent | 91755cb16d496d1094f5d81051a1e1e6f27a21c1 (diff) | |
download | busybox-w32-65c34c52df3ed46f0b811d1858c271a373ab6af5.tar.gz busybox-w32-65c34c52df3ed46f0b811d1858c271a373ab6af5.tar.bz2 busybox-w32-65c34c52df3ed46f0b811d1858c271a373ab6af5.zip |
dhcp: get rid of static data signal_pipe
function old new delta
udhcp_sp_setup 65 110 +45
udhcp_sp_fd_set 60 59 -1
udhcpd_main 1442 1437 -5
udhcpc_main 2684 2679 -5
signal_pipe 8 - -8
packed_usage 33292 33284 -8
------------------------------------------------------------------------------
(add/remove: 0/1 grow/shrink: 1/4 up/down: 45/-27) Total: 18 bytes
text data bss dec hex filename
952746 481 7296 960523 ea80b busybox_old
952768 481 7288 960537 ea819 busybox_unstripped
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'networking/udhcp/signalpipe.c')
-rw-r--r-- | networking/udhcp/signalpipe.c | 31 |
1 files changed, 22 insertions, 9 deletions
diff --git a/networking/udhcp/signalpipe.c b/networking/udhcp/signalpipe.c index 2ff78f0f2..81d1fc01a 100644 --- a/networking/udhcp/signalpipe.c +++ b/networking/udhcp/signalpipe.c | |||
@@ -20,14 +20,14 @@ | |||
20 | */ | 20 | */ |
21 | #include "common.h" | 21 | #include "common.h" |
22 | 22 | ||
23 | /* Global variable: we access it from signal handler */ | 23 | #define READ_FD 3 |
24 | static struct fd_pair signal_pipe; | 24 | #define WRITE_FD 4 |
25 | 25 | ||
26 | static void signal_handler(int sig) | 26 | static void signal_handler(int sig) |
27 | { | 27 | { |
28 | int sv = errno; | 28 | int sv = errno; |
29 | unsigned char ch = sig; /* use char, avoid dealing with partial writes */ | 29 | unsigned char ch = sig; /* use char, avoid dealing with partial writes */ |
30 | if (write(signal_pipe.wr, &ch, 1) != 1) | 30 | if (write(WRITE_FD, &ch, 1) != 1) |
31 | bb_perror_msg("can't send signal"); | 31 | bb_perror_msg("can't send signal"); |
32 | errno = sv; | 32 | errno = sv; |
33 | } | 33 | } |
@@ -36,12 +36,25 @@ static void signal_handler(int sig) | |||
36 | * and installs the signal handler */ | 36 | * and installs the signal handler */ |
37 | void FAST_FUNC udhcp_sp_setup(void) | 37 | void FAST_FUNC udhcp_sp_setup(void) |
38 | { | 38 | { |
39 | struct fd_pair signal_pipe; | ||
40 | |||
41 | /* All callers also want this, so... */ | ||
42 | bb_sanitize_stdio(); | ||
43 | |||
39 | /* was socketpair, but it needs AF_UNIX in kernel */ | 44 | /* was socketpair, but it needs AF_UNIX in kernel */ |
40 | xpiped_pair(signal_pipe); | 45 | xpiped_pair(signal_pipe); |
41 | close_on_exec_on(signal_pipe.rd); | 46 | |
42 | close_on_exec_on(signal_pipe.wr); | 47 | /* usually we get fds 3 and 4, but if we get higher ones... */ |
43 | ndelay_on(signal_pipe.rd); | 48 | if (signal_pipe.rd != READ_FD) |
44 | ndelay_on(signal_pipe.wr); | 49 | xmove_fd(signal_pipe.rd, READ_FD); |
50 | if (signal_pipe.wr != WRITE_FD) | ||
51 | xmove_fd(signal_pipe.wr, WRITE_FD); | ||
52 | |||
53 | close_on_exec_on(READ_FD); | ||
54 | close_on_exec_on(WRITE_FD); | ||
55 | ndelay_on(READ_FD); | ||
56 | ndelay_on(WRITE_FD); | ||
57 | |||
45 | bb_signals(0 | 58 | bb_signals(0 |
46 | + (1 << SIGUSR1) | 59 | + (1 << SIGUSR1) |
47 | + (1 << SIGUSR2) | 60 | + (1 << SIGUSR2) |
@@ -54,7 +67,7 @@ void FAST_FUNC udhcp_sp_setup(void) | |||
54 | */ | 67 | */ |
55 | void FAST_FUNC udhcp_sp_fd_set(struct pollfd pfds[2], int extra_fd) | 68 | void FAST_FUNC udhcp_sp_fd_set(struct pollfd pfds[2], int extra_fd) |
56 | { | 69 | { |
57 | pfds[0].fd = signal_pipe.rd; | 70 | pfds[0].fd = READ_FD; |
58 | pfds[0].events = POLLIN; | 71 | pfds[0].events = POLLIN; |
59 | pfds[1].fd = -1; | 72 | pfds[1].fd = -1; |
60 | if (extra_fd >= 0) { | 73 | if (extra_fd >= 0) { |
@@ -74,7 +87,7 @@ int FAST_FUNC udhcp_sp_read(void) | |||
74 | unsigned char sig; | 87 | unsigned char sig; |
75 | 88 | ||
76 | /* Can't block here, fd is in nonblocking mode */ | 89 | /* Can't block here, fd is in nonblocking mode */ |
77 | if (safe_read(signal_pipe.rd, &sig, 1) != 1) | 90 | if (safe_read(READ_FD, &sig, 1) != 1) |
78 | return 0; | 91 | return 0; |
79 | 92 | ||
80 | return sig; | 93 | return sig; |