libpwdgrp/pwd_grp.c: allocate local storage on first call, not in bss. -1k bss
function old new delta get_S - 31 +31 bb_internal_getpwnam 38 44 +6 bb_internal_getgrnam 38 44 +6 bb_internal_getgrgid 38 44 +6 ptr_to_statics - 4 +4 static.resultbuf 88 - -88 static.buffer 1024 - -1024 ------------------------------------------------------------------------------ (add/remove: 2/2 grow/shrink: 3/0 up/down: 53/-1112) Total: -1059 bytes
This commit is contained in:
parent
7679145cfa
commit
2c91efb7c2
@ -52,6 +52,66 @@ static int bb__parsegrent(void *gr, char *line);
|
|||||||
static int bb__parsespent(void *sp, char *line);
|
static int bb__parsespent(void *sp, char *line);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**********************************************************************/
|
||||||
|
/* We avoid having big global data. */
|
||||||
|
|
||||||
|
struct statics {
|
||||||
|
/* Smaller things first */
|
||||||
|
struct passwd getpwuid_resultbuf;
|
||||||
|
struct group getgrgid_resultbuf;
|
||||||
|
struct passwd getpwnam_resultbuf;
|
||||||
|
struct group getgrnam_resultbuf;
|
||||||
|
|
||||||
|
char getpwuid_buffer[PWD_BUFFER_SIZE];
|
||||||
|
char getgrgid_buffer[GRP_BUFFER_SIZE];
|
||||||
|
char getpwnam_buffer[PWD_BUFFER_SIZE];
|
||||||
|
char getgrnam_buffer[GRP_BUFFER_SIZE];
|
||||||
|
#if 0
|
||||||
|
struct passwd fgetpwent_resultbuf;
|
||||||
|
struct group fgetgrent_resultbuf;
|
||||||
|
struct spwd fgetspent_resultbuf;
|
||||||
|
char fgetpwent_buffer[PWD_BUFFER_SIZE];
|
||||||
|
char fgetgrent_buffer[GRP_BUFFER_SIZE];
|
||||||
|
char fgetspent_buffer[PWD_BUFFER_SIZE];
|
||||||
|
#endif
|
||||||
|
#if 0 //ENABLE_USE_BB_SHADOW
|
||||||
|
struct spwd getspuid_resultbuf;
|
||||||
|
struct spwd getspnam_resultbuf;
|
||||||
|
char getspuid_buffer[PWD_BUFFER_SIZE];
|
||||||
|
char getspnam_buffer[PWD_BUFFER_SIZE];
|
||||||
|
#endif
|
||||||
|
// Not converted - too small to bother
|
||||||
|
//pthread_mutex_t mylock = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
//FILE *pwf /*= NULL*/;
|
||||||
|
//FILE *grf /*= NULL*/;
|
||||||
|
//FILE *spf /*= NULL*/;
|
||||||
|
#if 0
|
||||||
|
struct passwd getpwent_pwd;
|
||||||
|
struct group getgrent_gr;
|
||||||
|
char getpwent_line_buff[PWD_BUFFER_SIZE];
|
||||||
|
char getgrent_line_buff[GRP_BUFFER_SIZE];
|
||||||
|
#endif
|
||||||
|
#if 0 //ENABLE_USE_BB_SHADOW
|
||||||
|
struct spwd getspent_spwd;
|
||||||
|
struct spwd sgetspent_spwd;
|
||||||
|
char getspent_line_buff[PWD_BUFFER_SIZE];
|
||||||
|
char sgetspent_line_buff[PWD_BUFFER_SIZE];
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct statics *ptr_to_statics;
|
||||||
|
|
||||||
|
static struct statics *get_S(void)
|
||||||
|
{
|
||||||
|
if (!ptr_to_statics)
|
||||||
|
ptr_to_statics = xzalloc(sizeof(*ptr_to_statics));
|
||||||
|
return ptr_to_statics;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Always use in this order, get_S() must be called first */
|
||||||
|
#define RESULTBUF(name) &((S = get_S())->name##_resultbuf)
|
||||||
|
#define BUFFER(name) (S->name##_buffer)
|
||||||
|
|
||||||
/**********************************************************************/
|
/**********************************************************************/
|
||||||
/* For the various fget??ent_r funcs, return
|
/* For the various fget??ent_r funcs, return
|
||||||
*
|
*
|
||||||
@ -127,21 +187,23 @@ int fgetspent_r(FILE *__restrict stream, struct spwd *__restrict resultbuf,
|
|||||||
#if 0
|
#if 0
|
||||||
struct passwd *fgetpwent(FILE *stream)
|
struct passwd *fgetpwent(FILE *stream)
|
||||||
{
|
{
|
||||||
static char buffer[PWD_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct passwd resultbuf;
|
struct passwd *resultbuf = RESULTBUF(fgetpwent);
|
||||||
|
char *buffer = BUFFER(fgetpwent);
|
||||||
struct passwd *result;
|
struct passwd *result;
|
||||||
|
|
||||||
fgetpwent_r(stream, &resultbuf, buffer, sizeof(buffer), &result);
|
fgetpwent_r(stream, resultbuf, buffer, sizeof(BUFFER(fgetpwent)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct group *fgetgrent(FILE *stream)
|
struct group *fgetgrent(FILE *stream)
|
||||||
{
|
{
|
||||||
static char buffer[GRP_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct group resultbuf;
|
struct group *resultbuf = RESULTBUF(fgetgrent);
|
||||||
|
char *buffer = BUFFER(fgetgrent);
|
||||||
struct group *result;
|
struct group *result;
|
||||||
|
|
||||||
fgetgrent_r(stream, &resultbuf, buffer, sizeof(buffer), &result);
|
fgetgrent_r(stream, resultbuf, buffer, sizeof(BUFFER(fgetgrent)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -150,11 +212,12 @@ struct group *fgetgrent(FILE *stream)
|
|||||||
#if 0
|
#if 0
|
||||||
struct spwd *fgetspent(FILE *stream)
|
struct spwd *fgetspent(FILE *stream)
|
||||||
{
|
{
|
||||||
static char buffer[PWD_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct spwd resultbuf;
|
struct spwd *resultbuf = RESULTBUF(fgetspent);
|
||||||
|
char *buffer = BUFFER(fgetspent);
|
||||||
struct spwd *result;
|
struct spwd *result;
|
||||||
|
|
||||||
fgetspent_r(stream, &resultbuf, buffer, sizeof(buffer), &result);
|
fgetspent_r(stream, resultbuf, buffer, sizeof(BUFFER(fgetspent)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -239,22 +302,24 @@ int sgetspent_r(const char *string, struct spwd *result_buf,
|
|||||||
/* This one has many users */
|
/* This one has many users */
|
||||||
struct passwd *getpwuid(uid_t uid)
|
struct passwd *getpwuid(uid_t uid)
|
||||||
{
|
{
|
||||||
static char buffer[PWD_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct passwd resultbuf;
|
struct passwd *resultbuf = RESULTBUF(getpwuid);
|
||||||
|
char *buffer = BUFFER(getpwuid);
|
||||||
struct passwd *result;
|
struct passwd *result;
|
||||||
|
|
||||||
getpwuid_r(uid, &resultbuf, buffer, sizeof(buffer), &result);
|
getpwuid_r(uid, resultbuf, buffer, sizeof(BUFFER(getpwuid)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This one has many users */
|
/* This one has many users */
|
||||||
struct group *getgrgid(gid_t gid)
|
struct group *getgrgid(gid_t gid)
|
||||||
{
|
{
|
||||||
static char buffer[GRP_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct group resultbuf;
|
struct group *resultbuf = RESULTBUF(getgrgid);
|
||||||
|
char *buffer = BUFFER(getgrgid);
|
||||||
struct group *result;
|
struct group *result;
|
||||||
|
|
||||||
getgrgid_r(gid, &resultbuf, buffer, sizeof(buffer), &result);
|
getgrgid_r(gid, resultbuf, buffer, sizeof(BUFFER(getgrgid)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -284,11 +349,12 @@ int getspuid_r(uid_t uid, struct spwd *__restrict resultbuf,
|
|||||||
* Why it was added, I do not know. */
|
* Why it was added, I do not know. */
|
||||||
struct spwd *getspuid(uid_t uid)
|
struct spwd *getspuid(uid_t uid)
|
||||||
{
|
{
|
||||||
static char buffer[PWD_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct spwd resultbuf;
|
struct spwd *resultbuf = RESULTBUF(getspuid);
|
||||||
|
char *buffer = BUFFER(getspuid);
|
||||||
struct spwd *result;
|
struct spwd *result;
|
||||||
|
|
||||||
getspuid_r(uid, &resultbuf, buffer, sizeof(buffer), &result);
|
getspuid_r(uid, resultbuf, buffer, sizeof(BUFFER(getspuid)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -296,33 +362,36 @@ struct spwd *getspuid(uid_t uid)
|
|||||||
/* This one has many users */
|
/* This one has many users */
|
||||||
struct passwd *getpwnam(const char *name)
|
struct passwd *getpwnam(const char *name)
|
||||||
{
|
{
|
||||||
static char buffer[PWD_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct passwd resultbuf;
|
struct passwd *resultbuf = RESULTBUF(getpwnam);
|
||||||
|
char *buffer = BUFFER(getpwnam);
|
||||||
struct passwd *result;
|
struct passwd *result;
|
||||||
|
|
||||||
getpwnam_r(name, &resultbuf, buffer, sizeof(buffer), &result);
|
getpwnam_r(name, resultbuf, buffer, sizeof(BUFFER(getpwnam)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This one has many users */
|
/* This one has many users */
|
||||||
struct group *getgrnam(const char *name)
|
struct group *getgrnam(const char *name)
|
||||||
{
|
{
|
||||||
static char buffer[GRP_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct group resultbuf;
|
struct group *resultbuf = RESULTBUF(getgrnam);
|
||||||
|
char *buffer = BUFFER(getgrnam);
|
||||||
struct group *result;
|
struct group *result;
|
||||||
|
|
||||||
getgrnam_r(name, &resultbuf, buffer, sizeof(buffer), &result);
|
getgrnam_r(name, resultbuf, buffer, sizeof(BUFFER(getgrnam)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0 //ENABLE_USE_BB_SHADOW
|
#if 0 //ENABLE_USE_BB_SHADOW
|
||||||
struct spwd *getspnam(const char *name)
|
struct spwd *getspnam(const char *name)
|
||||||
{
|
{
|
||||||
static char buffer[PWD_BUFFER_SIZE];
|
struct statics *S;
|
||||||
static struct spwd resultbuf;
|
struct spwd *resultbuf = RESULTBUF(getspnam);
|
||||||
|
char *buffer = BUFFER(getspnam);
|
||||||
struct spwd *result;
|
struct spwd *result;
|
||||||
|
|
||||||
getspnam_r(name, &resultbuf, buffer, sizeof(buffer), &result);
|
getspnam_r(name, resultbuf, buffer, sizeof(BUFFER(getspnam)), &result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user