mirror of
https://github.com/sheumann/hush.git
synced 2024-10-10 04:23:44 +00:00
inetd: make some fields smaller, move data out of data/bss sections
function old new delta inetd_main 2125 2160 +35 setup 640 645 +5 initring 48 53 +5 reapchild 169 173 +4 retry 92 93 +1 goaway 113 112 -1 inetd_setproctitle 175 173 -2 chargen_dg 229 227 -2 uid 4 - -4 ....................... Argv 4 - -4 rlim_ofile_cur 8 - -8 config 1610 1602 -8 rlim_ofile 16 - -16 getconfigent 1271 1241 -30 builtins 176 132 -44 ring 128 - -128 allsock 128 - -128 ------------------------------------------------------------------------------ (add/remove: 0/18 grow/shrink: 5/6 up/down: 50/-423) Total: -373 bytes text data bss dec hex filename 774144 1051 10708 785903 bfdef busybox_old 774108 1039 10380 785527 bfc77 busybox_unstripped $ size inetd.o inetd_orig.o text data bss dec hex filename 9027 0 0 9027 2343 inetd.o 9064 12 324 9400 24b8 inetd_orig.o
This commit is contained in:
parent
2a1d024333
commit
512a545f0d
@ -190,9 +190,6 @@ extern char **environ;
|
|||||||
|
|
||||||
/* Reserve some descriptors, 3 stdio + at least: 1 log, 1 conf. file */
|
/* Reserve some descriptors, 3 stdio + at least: 1 log, 1 conf. file */
|
||||||
#define FD_MARGIN 8
|
#define FD_MARGIN 8
|
||||||
static rlim_t rlim_ofile_cur = OPEN_MAX;
|
|
||||||
static struct rlimit rlim_ofile;
|
|
||||||
|
|
||||||
|
|
||||||
/* Check unsupporting builtin */
|
/* Check unsupporting builtin */
|
||||||
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_ECHO || \
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_ECHO || \
|
||||||
@ -209,11 +206,24 @@ static struct rlimit rlim_ofile;
|
|||||||
# define INETD_SETPROCTITLE
|
# define INETD_SETPROCTITLE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef struct servtab {
|
typedef int8_t socktype_t;
|
||||||
|
typedef int8_t family_t;
|
||||||
|
struct BUG_too_small {
|
||||||
|
char BUG_socktype_t_too_small[(0
|
||||||
|
| SOCK_STREAM
|
||||||
|
| SOCK_DGRAM
|
||||||
|
| SOCK_RDM
|
||||||
|
| SOCK_SEQPACKET
|
||||||
|
| SOCK_RAW) <= 127 ? 1 : -1];
|
||||||
|
char BUG_family_t_too_small[(0
|
||||||
|
| AF_INET
|
||||||
|
| AF_INET6
|
||||||
|
| AF_UNIX) <= 127 ? 1 : -1];
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct servtab_t {
|
||||||
char *se_hostaddr; /* host address to listen on */
|
char *se_hostaddr; /* host address to listen on */
|
||||||
char *se_service; /* name of service */
|
char *se_service; /* name of service */
|
||||||
int se_socktype; /* type of socket to use */
|
|
||||||
int se_family; /* address family */
|
|
||||||
char *se_proto; /* protocol used */
|
char *se_proto; /* protocol used */
|
||||||
#if ENABLE_FEATURE_INETD_RPC
|
#if ENABLE_FEATURE_INETD_RPC
|
||||||
int se_rpcprog; /* rpc program number */
|
int se_rpcprog; /* rpc program number */
|
||||||
@ -224,7 +234,9 @@ typedef struct servtab {
|
|||||||
#define isrpcservice(sep) 0
|
#define isrpcservice(sep) 0
|
||||||
#endif
|
#endif
|
||||||
pid_t se_wait; /* single threaded server */
|
pid_t se_wait; /* single threaded server */
|
||||||
short se_checked; /* looked at during merge */
|
socktype_t se_socktype; /* type of socket to use */
|
||||||
|
family_t se_family; /* address family */
|
||||||
|
smallint se_checked; /* looked at during merge */
|
||||||
char *se_user; /* user name to run as */
|
char *se_user; /* user name to run as */
|
||||||
char *se_group; /* group name to run as */
|
char *se_group; /* group name to run as */
|
||||||
#ifdef INETD_FEATURE_ENABLED
|
#ifdef INETD_FEATURE_ENABLED
|
||||||
@ -250,17 +262,16 @@ typedef struct servtab {
|
|||||||
int se_max; /* max # of instances of this service */
|
int se_max; /* max # of instances of this service */
|
||||||
int se_count; /* number started since se_time */
|
int se_count; /* number started since se_time */
|
||||||
struct timeval se_time; /* start of se_count */
|
struct timeval se_time; /* start of se_count */
|
||||||
struct servtab *se_next;
|
struct servtab_t *se_next;
|
||||||
} servtab_t;
|
} servtab_t;
|
||||||
|
|
||||||
static servtab_t *servtab;
|
|
||||||
|
|
||||||
#ifdef INETD_FEATURE_ENABLED
|
#ifdef INETD_FEATURE_ENABLED
|
||||||
struct builtin {
|
struct builtin {
|
||||||
const char *bi_service; /* internally provided service name */
|
const char *bi_service; /* internally provided service name */
|
||||||
int bi_socktype; /* type of socket supported */
|
socktype_t bi_socktype; /* type of socket supported */
|
||||||
short bi_fork; /* 1 if should fork before call */
|
uint8_t bi_fork; /* 1 if should fork before call */
|
||||||
short bi_wait; /* 1 if should wait for child */
|
// Commented since it is always 0
|
||||||
|
// uint8_t bi_wait; /* 1 if should wait for child */
|
||||||
void (*bi_fn) (int, servtab_t *);
|
void (*bi_fn) (int, servtab_t *);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -293,45 +304,90 @@ static void chargen_dg(int, servtab_t *);
|
|||||||
static const struct builtin builtins[] = {
|
static const struct builtin builtins[] = {
|
||||||
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_ECHO
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_ECHO
|
||||||
/* Echo received data */
|
/* Echo received data */
|
||||||
{"echo", SOCK_STREAM, 1, 0, echo_stream,},
|
{"echo", SOCK_STREAM, 1, echo_stream,},
|
||||||
{"echo", SOCK_DGRAM, 0, 0, echo_dg,},
|
{"echo", SOCK_DGRAM, 0, echo_dg,},
|
||||||
#endif
|
#endif
|
||||||
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_DISCARD
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_DISCARD
|
||||||
/* Internet /dev/null */
|
/* Internet /dev/null */
|
||||||
{"discard", SOCK_STREAM, 1, 0, discard_stream,},
|
{"discard", SOCK_STREAM, 1, discard_stream,},
|
||||||
{"discard", SOCK_DGRAM, 0, 0, discard_dg,},
|
{"discard", SOCK_DGRAM, 0, discard_dg,},
|
||||||
#endif
|
#endif
|
||||||
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_TIME
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_TIME
|
||||||
/* Return 32 bit time since 1900 */
|
/* Return 32 bit time since 1900 */
|
||||||
{"time", SOCK_STREAM, 0, 0, machtime_stream,},
|
{"time", SOCK_STREAM, 0, machtime_stream,},
|
||||||
{"time", SOCK_DGRAM, 0, 0, machtime_dg,},
|
{"time", SOCK_DGRAM, 0, machtime_dg,},
|
||||||
#endif
|
#endif
|
||||||
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_DAYTIME
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_DAYTIME
|
||||||
/* Return human-readable time */
|
/* Return human-readable time */
|
||||||
{"daytime", SOCK_STREAM, 0, 0, daytime_stream,},
|
{"daytime", SOCK_STREAM, 0, daytime_stream,},
|
||||||
{"daytime", SOCK_DGRAM, 0, 0, daytime_dg,},
|
{"daytime", SOCK_DGRAM, 0, daytime_dg,},
|
||||||
#endif
|
#endif
|
||||||
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_CHARGEN
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_CHARGEN
|
||||||
/* Familiar character generator */
|
/* Familiar character generator */
|
||||||
{"chargen", SOCK_STREAM, 1, 0, chargen_stream,},
|
{"chargen", SOCK_STREAM, 1, chargen_stream,},
|
||||||
{"chargen", SOCK_DGRAM, 0, 0, chargen_dg,},
|
{"chargen", SOCK_DGRAM, 0, chargen_dg,},
|
||||||
#endif
|
#endif
|
||||||
{NULL, 0, 0, 0, NULL}
|
{ /* zero filled */ }
|
||||||
};
|
};
|
||||||
#endif /* INETD_FEATURE_ENABLED */
|
#endif /* INETD_FEATURE_ENABLED */
|
||||||
|
|
||||||
static int global_queuelen = 128;
|
struct globals {
|
||||||
static int nsock, maxsock;
|
rlim_t rlim_ofile_cur;
|
||||||
static fd_set allsock;
|
struct rlimit rlim_ofile;
|
||||||
static int toomany;
|
servtab_t *servtab;
|
||||||
static int timingout;
|
int global_queuelen;
|
||||||
static struct servent *sp;
|
int nsock;
|
||||||
static uid_t uid;
|
int maxsock;
|
||||||
|
int toomany;
|
||||||
static const char *config_filename = "/etc/inetd.conf";
|
int timingout;
|
||||||
|
struct servent *sp;
|
||||||
static FILE *fconfig;
|
uid_t uid;
|
||||||
static char *defhost;
|
const char *config_filename;
|
||||||
|
FILE *fconfig;
|
||||||
|
char *defhost;
|
||||||
|
#ifdef INETD_SETPROCTITLE
|
||||||
|
char **Argv;
|
||||||
|
char *LastArg;
|
||||||
|
#endif
|
||||||
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_CHARGEN
|
||||||
|
char *endring;
|
||||||
|
char *ringpos;
|
||||||
|
char ring[128];
|
||||||
|
#endif
|
||||||
|
fd_set allsock;
|
||||||
|
/* Used only in nextline() */
|
||||||
|
char line[80]; /* at least 80, see LINE_SIZE */
|
||||||
|
};
|
||||||
|
#define G (*(struct globals*)&bb_common_bufsiz1)
|
||||||
|
enum { LINE_SIZE = COMMON_BUFSIZE - offsetof(struct globals, line) };
|
||||||
|
struct BUG_G_too_big {
|
||||||
|
char BUG_G_too_big[sizeof(G) <= COMMON_BUFSIZE ? 1 : -1];
|
||||||
|
};
|
||||||
|
#define rlim_ofile_cur (G.rlim_ofile_cur )
|
||||||
|
#define rlim_ofile (G.rlim_ofile )
|
||||||
|
#define servtab (G.servtab )
|
||||||
|
#define global_queuelen (G.global_queuelen)
|
||||||
|
#define nsock (G.nsock )
|
||||||
|
#define maxsock (G.maxsock )
|
||||||
|
#define toomany (G.toomany )
|
||||||
|
#define timingout (G.timingout )
|
||||||
|
#define sp (G.sp )
|
||||||
|
#define uid (G.uid )
|
||||||
|
#define config_filename (G.config_filename)
|
||||||
|
#define fconfig (G.fconfig )
|
||||||
|
#define defhost (G.defhost )
|
||||||
|
#define Argv (G.Argv )
|
||||||
|
#define LastArg (G.LastArg )
|
||||||
|
#define endring (G.endring )
|
||||||
|
#define ringpos (G.ringpos )
|
||||||
|
#define ring (G.ring )
|
||||||
|
#define allsock (G.allsock )
|
||||||
|
#define line (G.line )
|
||||||
|
#define INIT_G() do { \
|
||||||
|
rlim_ofile_cur = OPEN_MAX; \
|
||||||
|
global_queuelen = 128; \
|
||||||
|
config_filename = "/etc/inetd.conf"; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
/* xstrdup(NULL) returns NULL, but this one
|
/* xstrdup(NULL) returns NULL, but this one
|
||||||
* will return newly-allocated "" if called with NULL arg
|
* will return newly-allocated "" if called with NULL arg
|
||||||
@ -510,12 +566,10 @@ static void setup(servtab_t *sep)
|
|||||||
|
|
||||||
static char *nextline(void)
|
static char *nextline(void)
|
||||||
{
|
{
|
||||||
#define line bb_common_bufsiz1
|
|
||||||
|
|
||||||
char *cp;
|
char *cp;
|
||||||
FILE *fd = fconfig;
|
FILE *fd = fconfig;
|
||||||
|
|
||||||
if (fgets(line, sizeof(line), fd) == NULL)
|
if (fgets(line, LINE_SIZE, fd) == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
cp = strchr(line, '\n');
|
cp = strchr(line, '\n');
|
||||||
if (cp)
|
if (cp)
|
||||||
@ -740,15 +794,15 @@ static servtab_t *getconfigent(void)
|
|||||||
const struct builtin *bi;
|
const struct builtin *bi;
|
||||||
|
|
||||||
for (bi = builtins; bi->bi_service; bi++)
|
for (bi = builtins; bi->bi_service; bi++)
|
||||||
if (bi->bi_socktype == sep->se_socktype &&
|
if (bi->bi_socktype == sep->se_socktype
|
||||||
strcmp(bi->bi_service, sep->se_service) == 0)
|
&& strcmp(bi->bi_service, sep->se_service) == 0)
|
||||||
break;
|
break;
|
||||||
if (bi->bi_service == 0) {
|
if (bi->bi_service == 0) {
|
||||||
bb_error_msg("internal service %s unknown", sep->se_service);
|
bb_error_msg("internal service %s unknown", sep->se_service);
|
||||||
goto more;
|
goto more;
|
||||||
}
|
}
|
||||||
sep->se_bi = bi;
|
sep->se_bi = bi;
|
||||||
sep->se_wait = bi->bi_wait;
|
sep->se_wait = 0; /* = bi->bi_wait; - always 0 */
|
||||||
#else
|
#else
|
||||||
bb_perror_msg("internal service %s unknown", sep->se_service);
|
bb_perror_msg("internal service %s unknown", sep->se_service);
|
||||||
goto more;
|
goto more;
|
||||||
@ -792,21 +846,22 @@ static servtab_t *getconfigent(void)
|
|||||||
if (LONE_CHAR(nsep->se_hostaddr, '*'))
|
if (LONE_CHAR(nsep->se_hostaddr, '*'))
|
||||||
nsep->se_ctrladdr_in.sin_addr.s_addr = INADDR_ANY;
|
nsep->se_ctrladdr_in.sin_addr.s_addr = INADDR_ANY;
|
||||||
else if (!inet_aton(nsep->se_hostaddr, &nsep->se_ctrladdr_in.sin_addr)) {
|
else if (!inet_aton(nsep->se_hostaddr, &nsep->se_ctrladdr_in.sin_addr)) {
|
||||||
|
int i;
|
||||||
struct hostent *hp;
|
struct hostent *hp;
|
||||||
|
|
||||||
hp = gethostbyname(nsep->se_hostaddr);
|
hp = gethostbyname(nsep->se_hostaddr);
|
||||||
if (hp == 0) {
|
if (hp == NULL) {
|
||||||
bb_error_msg("%s: unknown host", nsep->se_hostaddr);
|
bb_error_msg("%s: unknown host", nsep->se_hostaddr);
|
||||||
nsep->se_checked = 0;
|
nsep->se_checked = 0;
|
||||||
goto skip;
|
goto skip;
|
||||||
} else if (hp->h_addrtype != AF_INET) {
|
}
|
||||||
|
if (hp->h_addrtype != AF_INET) {
|
||||||
bb_error_msg("%s: address isn't an Internet "
|
bb_error_msg("%s: address isn't an Internet "
|
||||||
"address", nsep->se_hostaddr);
|
"address", nsep->se_hostaddr);
|
||||||
nsep->se_checked = 0;
|
nsep->se_checked = 0;
|
||||||
goto skip;
|
goto skip;
|
||||||
} else {
|
}
|
||||||
int i = 1;
|
i = 1;
|
||||||
|
|
||||||
memmove(&nsep->se_ctrladdr_in.sin_addr,
|
memmove(&nsep->se_ctrladdr_in.sin_addr,
|
||||||
hp->h_addr_list[0], sizeof(struct in_addr));
|
hp->h_addr_list[0], sizeof(struct in_addr));
|
||||||
while (hp->h_addr_list[i] != NULL) {
|
while (hp->h_addr_list[i] != NULL) {
|
||||||
@ -824,7 +879,6 @@ static servtab_t *getconfigent(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
/* XXX BUG?: is this skip: label supposed to remain? */
|
/* XXX BUG?: is this skip: label supposed to remain? */
|
||||||
skip:
|
skip:
|
||||||
nsep = nsep->se_next;
|
nsep = nsep->se_next;
|
||||||
@ -1219,8 +1273,6 @@ static void goaway(int sig ATTRIBUTE_UNUSED)
|
|||||||
|
|
||||||
|
|
||||||
#ifdef INETD_SETPROCTITLE
|
#ifdef INETD_SETPROCTITLE
|
||||||
static char **Argv;
|
|
||||||
static char *LastArg;
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
inetd_setproctitle(char *a, int s)
|
inetd_setproctitle(char *a, int s)
|
||||||
@ -1262,10 +1314,14 @@ int inetd_main(int argc, char **argv)
|
|||||||
char buf[50];
|
char buf[50];
|
||||||
char *stoomany;
|
char *stoomany;
|
||||||
sigset_t omask, wait_mask;
|
sigset_t omask, wait_mask;
|
||||||
|
#ifdef INETD_SETPROCTITLE
|
||||||
|
char **envp;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
INIT_G();
|
||||||
|
|
||||||
#ifdef INETD_SETPROCTITLE
|
#ifdef INETD_SETPROCTITLE
|
||||||
char **envp = environ;
|
envp = environ;
|
||||||
|
|
||||||
Argv = argv;
|
Argv = argv;
|
||||||
if (envp == 0 || *envp == 0)
|
if (envp == 0 || *envp == 0)
|
||||||
envp = argv;
|
envp = argv;
|
||||||
@ -1600,8 +1656,6 @@ discard_dg(int s, servtab_t *sep ATTRIBUTE_UNUSED)
|
|||||||
|
|
||||||
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_CHARGEN
|
#if ENABLE_FEATURE_INETD_SUPPORT_BUILTIN_CHARGEN
|
||||||
#define LINESIZ 72
|
#define LINESIZ 72
|
||||||
static char ring[128];
|
|
||||||
static char *endring;
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
initring(void)
|
initring(void)
|
||||||
@ -1609,7 +1663,6 @@ initring(void)
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
endring = ring;
|
endring = ring;
|
||||||
|
|
||||||
for (i = 0; i <= 128; ++i)
|
for (i = 0; i <= 128; ++i)
|
||||||
if (isprint(i))
|
if (isprint(i))
|
||||||
*endring++ = i;
|
*endring++ = i;
|
||||||
@ -1657,14 +1710,13 @@ chargen_dg(int s, servtab_t *sep ATTRIBUTE_UNUSED)
|
|||||||
{
|
{
|
||||||
/* struct sockaddr_storage ss; */
|
/* struct sockaddr_storage ss; */
|
||||||
struct sockaddr sa;
|
struct sockaddr sa;
|
||||||
static char *rs;
|
|
||||||
int len;
|
int len;
|
||||||
char text[LINESIZ + 2];
|
char text[LINESIZ + 2];
|
||||||
socklen_t size;
|
socklen_t size;
|
||||||
|
|
||||||
if (endring == 0) {
|
if (!endring) {
|
||||||
initring();
|
initring();
|
||||||
rs = ring;
|
ringpos = ring;
|
||||||
}
|
}
|
||||||
|
|
||||||
size = sizeof(sa);
|
size = sizeof(sa);
|
||||||
@ -1673,14 +1725,15 @@ chargen_dg(int s, servtab_t *sep ATTRIBUTE_UNUSED)
|
|||||||
if (dg_badinput((struct sockaddr_in *) &sa))
|
if (dg_badinput((struct sockaddr_in *) &sa))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((len = endring - rs) >= LINESIZ)
|
len = endring - ringpos;
|
||||||
memmove(text, rs, LINESIZ);
|
if (len >= LINESIZ)
|
||||||
|
memmove(text, ringpos, LINESIZ);
|
||||||
else {
|
else {
|
||||||
memmove(text, rs, len);
|
memmove(text, ringpos, len);
|
||||||
memmove(text + len, ring, LINESIZ - len);
|
memmove(text + len, ring, LINESIZ - len);
|
||||||
}
|
}
|
||||||
if (++rs == endring)
|
if (++ringpos == endring)
|
||||||
rs = ring;
|
ringpos = ring;
|
||||||
text[LINESIZ] = '\r';
|
text[LINESIZ] = '\r';
|
||||||
text[LINESIZ + 1] = '\n';
|
text[LINESIZ + 1] = '\n';
|
||||||
(void) sendto(s, text, sizeof(text), 0, &sa, sizeof(sa));
|
(void) sendto(s, text, sizeof(text), 0, &sa, sizeof(sa));
|
||||||
|
Loading…
Reference in New Issue
Block a user