2008-03-04 02:54:09 +01:00
|
|
|
/* Copyright (c) 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, 2007, 2008
|
2004-08-26 20:35:05 +02:00
|
|
|
Free Software Foundation, Inc.
|
1998-01-31 09:39:55 +01:00
|
|
|
This file is part of the GNU C Library.
|
1999-06-11 22:58:21 +02:00
|
|
|
Contributed by Thorsten Kukuk <kukuk@suse.de>, 1998.
|
1998-01-31 09:39:55 +01:00
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
2001-07-06 06:58:11 +02:00
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2.1 of the License, or (at your option) any later version.
|
1998-01-31 09:39:55 +01:00
|
|
|
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
2001-07-06 06:58:11 +02:00
|
|
|
Lesser General Public License for more details.
|
1998-01-31 09:39:55 +01:00
|
|
|
|
2001-07-06 06:58:11 +02:00
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
License along with the GNU C Library; if not, write to the Free
|
|
|
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
|
|
02111-1307 USA. */
|
1998-01-31 09:39:55 +01:00
|
|
|
|
|
|
|
#ifndef _NSCD_H
|
1998-10-18 17:16:22 +02:00
|
|
|
#define _NSCD_H 1
|
|
|
|
|
|
|
|
#include <pthread.h>
|
2004-08-26 20:35:05 +02:00
|
|
|
#include <stdbool.h>
|
1998-10-18 17:16:22 +02:00
|
|
|
#include <time.h>
|
|
|
|
#include <sys/uio.h>
|
1998-01-31 09:39:55 +01:00
|
|
|
|
1998-10-19 00:02:47 +02:00
|
|
|
/* The declarations for the request and response types are in the file
|
|
|
|
"nscd-client.h", which should contain everything needed by client
|
|
|
|
functions. */
|
|
|
|
#include "nscd-client.h"
|
1998-10-18 17:16:22 +02:00
|
|
|
|
1998-01-31 09:39:55 +01:00
|
|
|
|
1998-10-18 17:16:22 +02:00
|
|
|
/* Handle databases. */
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
pwddb,
|
|
|
|
grpdb,
|
|
|
|
hstdb,
|
2007-01-14 06:26:04 +01:00
|
|
|
servdb,
|
1998-10-18 17:16:22 +02:00
|
|
|
lastdb
|
|
|
|
} dbtype;
|
1998-01-31 09:39:55 +01:00
|
|
|
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
/* Default limit on the number of times a value gets reloaded without
|
|
|
|
being used in the meantime. NSCD does not throw a value out as
|
|
|
|
soon as it times out. It tries to reload the value from the
|
|
|
|
server. Only if the value has not been used for so many rounds it
|
|
|
|
is removed. */
|
|
|
|
#define DEFAULT_RELOAD_LIMIT 5
|
|
|
|
|
|
|
|
|
2004-10-03 21:33:48 +02:00
|
|
|
/* Time before restarting the process in paranoia mode. */
|
|
|
|
#define RESTART_INTERVAL (60 * 60)
|
|
|
|
|
|
|
|
|
2007-11-23 07:37:58 +01:00
|
|
|
/* Stack size for worker threads. */
|
|
|
|
#define NSCD_THREAD_STACKSIZE 1024 * 1024 * (sizeof (void *) / 4)
|
|
|
|
|
2007-11-25 22:08:01 +01:00
|
|
|
/* Maximum size of stack frames we allow the thread to use. We use
|
|
|
|
80% of the thread stack size. */
|
|
|
|
#define MAX_STACK_USE ((8 * NSCD_THREAD_STACKSIZE) / 10)
|
|
|
|
|
2007-11-23 07:37:58 +01:00
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
/* Structure describing dynamic part of one database. */
|
|
|
|
struct database_dyn
|
1998-10-18 17:16:22 +02:00
|
|
|
{
|
|
|
|
pthread_rwlock_t lock;
|
2007-11-06 01:45:40 +01:00
|
|
|
pthread_cond_t prune_cond;
|
|
|
|
pthread_mutex_t prune_lock;
|
2008-12-09 06:24:37 +01:00
|
|
|
pthread_mutex_t prune_run_lock;
|
2007-11-06 01:45:40 +01:00
|
|
|
time_t wakeup_time;
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
int enabled;
|
|
|
|
int check_file;
|
2008-06-13 00:40:27 +02:00
|
|
|
int inotify_descr;
|
|
|
|
int clear_cache;
|
2004-08-26 20:35:05 +02:00
|
|
|
int persistent;
|
2004-09-08 17:46:42 +02:00
|
|
|
int shared;
|
2006-04-26 19:32:10 +02:00
|
|
|
int propagate;
|
2007-01-14 06:26:04 +01:00
|
|
|
int reset_res;
|
|
|
|
const char filename[16];
|
2004-08-26 20:35:05 +02:00
|
|
|
const char *db_filename;
|
1998-10-18 17:16:22 +02:00
|
|
|
time_t file_mtime;
|
2004-08-26 20:35:05 +02:00
|
|
|
size_t suggested_module;
|
2006-04-30 18:39:16 +02:00
|
|
|
size_t max_db_size;
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
unsigned long int postimeout; /* In seconds. */
|
|
|
|
unsigned long int negtimeout; /* In seconds. */
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
int wr_fd; /* Writable file descriptor. */
|
|
|
|
int ro_fd; /* Unwritable file descriptor. */
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
const struct iovec *disabled_iov;
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
struct database_pers_head *head;
|
|
|
|
char *data;
|
|
|
|
size_t memsize;
|
|
|
|
pthread_mutex_t memlock;
|
|
|
|
bool mmap_used;
|
|
|
|
bool last_alloc_failed;
|
|
|
|
};
|
2003-04-26 06:15:50 +02:00
|
|
|
|
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
/* Paths of the file for the persistent storage. */
|
2004-10-15 23:20:11 +02:00
|
|
|
#define _PATH_NSCD_PASSWD_DB "/var/db/nscd/passwd"
|
|
|
|
#define _PATH_NSCD_GROUP_DB "/var/db/nscd/group"
|
|
|
|
#define _PATH_NSCD_HOSTS_DB "/var/db/nscd/hosts"
|
2007-01-14 06:26:04 +01:00
|
|
|
#define _PATH_NSCD_SERVICES_DB "/var/db/nscd/services"
|
2004-10-15 23:20:11 +02:00
|
|
|
|
|
|
|
/* Path used when not using persistent storage. */
|
|
|
|
#define _PATH_NSCD_XYZ_DB_TMP "/var/run/nscd/dbXXXXXX"
|
1998-10-18 17:16:22 +02:00
|
|
|
|
* posix/bits/unistd.h (confstr, getgroups, ttyname_r, gethostname,
getdomainname): Add __NTH.
* stdlib/bits/stdlib.h (ptsname_r, wctomb, mbstowcs, wcstombs):
Likewise.
(realpath): Likewise. Use __const instead of const. Add __restrict
keywords.
* socket/bits/socket2.h (recvfrom): Add __restrict keyword to __buf.
* wcsmbs/bits/wchar2.h (wmemcpy, wmemmove, wmempcpy, wmemset,
wcscpy, wcpcpy, wcsncpy, wcpncpy, wcscat, wcsncat, vswprintf, wcrtomb,
mbsrtowcs, wcsrtombs, mbsnrtowcs, wcsnrtombs): Add __NTH.
* string/bits/string3.h (__memset_ichk): Likewise.
(__memcpy_ichk, __memmove_ichk, __mempcpy_ichk, __strcpy_ichk,
__stpcpy_ichk, __strncpy_ichk, stpncpy, __strcat_ichk,
__strncat_ichk): Likewise. Use __const instead of const.
(__stpncpy_chk): Use __const instead of const.
(__stpncpy_alias): Use __REDIRECT_NTH instead of __REDIRECT.
2005-08-08 Ulrich Drepper <drepper@redhat.com>
Jakub Jelinek <jakub@redhat.com>
* nscd/mem.c (BLOCK_ALIGN_LOG, BLOCK_ALIGN, BLOCK_ALIGN_M1): Move
definitions to...
* nscd/nscd.h (BLOCK_ALIGN_LOG, BLOCK_ALIGN, BLOCK_ALIGN_M1): ...here.
* nscd/connections.c (usekey): New enum.
(check_use, verify_persistent_db): New functions.
(nscd_init): If persistent database is corrupted, unlink it and
recreate rather than falling back to non-persistent database.
Call verify_persistent_db. Avoid overflows in total computation.
2005-08-08 Ulrich Drepper <drepper@redhat.com>
* iconvdata/utf-16.c (PREPARE_LOOP): Minor cleanups to make code
better readable. Avoid passing var to loop function, it's not
necessary at all.
2005-08-08 21:04:11 +02:00
|
|
|
/* Maximum alignment requirement we will encounter. */
|
|
|
|
#define BLOCK_ALIGN_LOG 3
|
|
|
|
#define BLOCK_ALIGN (1 << BLOCK_ALIGN_LOG)
|
|
|
|
#define BLOCK_ALIGN_M1 (BLOCK_ALIGN - 1)
|
|
|
|
|
2005-08-24 01:21:53 +02:00
|
|
|
/* Default value for the maximum size of the database files. */
|
|
|
|
#define DEFAULT_MAX_DB_SIZE (32 * 1024 * 1024)
|
|
|
|
|
|
|
|
/* Number of bytes of data we initially reserve for each hash table bucket. */
|
|
|
|
#define DEFAULT_DATASIZE_PER_BUCKET 1024
|
|
|
|
|
2008-03-04 02:54:09 +01:00
|
|
|
/* Default module of hash table. */
|
|
|
|
#define DEFAULT_SUGGESTED_MODULE 211
|
|
|
|
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2007-11-06 01:45:40 +01:00
|
|
|
/* Number of seconds between two cache pruning runs if we do not have
|
|
|
|
better information when it is really needed. */
|
|
|
|
#define CACHE_PRUNE_INTERVAL 15
|
|
|
|
|
|
|
|
|
1998-10-18 17:16:22 +02:00
|
|
|
/* Global variables. */
|
2008-04-22 17:53:59 +02:00
|
|
|
extern struct database_dyn dbs[lastdb] attribute_hidden;
|
2007-01-14 06:26:04 +01:00
|
|
|
extern const char *const dbnames[lastdb];
|
|
|
|
extern const char *const serv2str[LASTREQ];
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
extern const struct iovec pwd_iov_disabled;
|
|
|
|
extern const struct iovec grp_iov_disabled;
|
|
|
|
extern const struct iovec hst_iov_disabled;
|
2007-01-14 06:26:04 +01:00
|
|
|
extern const struct iovec serv_iov_disabled;
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
|
2004-10-03 23:11:37 +02:00
|
|
|
/* Initial number of threads to run. */
|
1998-10-18 17:16:22 +02:00
|
|
|
extern int nthreads;
|
2004-10-03 23:11:37 +02:00
|
|
|
/* Maximum number of threads to use. */
|
|
|
|
extern int max_nthreads;
|
1998-10-18 17:16:22 +02:00
|
|
|
|
2003-05-04 09:00:44 +02:00
|
|
|
/* User name to run server processes as. */
|
2000-04-30 08:52:59 +02:00
|
|
|
extern const char *server_user;
|
|
|
|
|
2003-05-04 09:00:44 +02:00
|
|
|
/* Name and UID of user who is allowed to request statistics. */
|
|
|
|
extern const char *stat_user;
|
|
|
|
extern uid_t stat_uid;
|
|
|
|
|
2003-04-26 06:15:50 +02:00
|
|
|
/* Time the server was started. */
|
|
|
|
extern time_t start_time;
|
|
|
|
|
2003-04-28 05:40:26 +02:00
|
|
|
/* Number of times clients had to wait. */
|
|
|
|
extern unsigned long int client_queued;
|
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
/* Maximum needed alignment. */
|
|
|
|
extern const size_t block_align;
|
|
|
|
|
|
|
|
/* Number of times a value is reloaded without being used. UINT_MAX
|
|
|
|
means unlimited. */
|
|
|
|
extern unsigned int reload_count;
|
|
|
|
|
2004-09-11 01:56:29 +02:00
|
|
|
/* Pagesize minus one. */
|
|
|
|
extern uintptr_t pagesize_m1;
|
|
|
|
|
2004-10-03 21:33:48 +02:00
|
|
|
/* Nonzero if paranoia mode is enabled. */
|
|
|
|
extern int paranoia;
|
|
|
|
/* Time after which the process restarts. */
|
|
|
|
extern time_t restart_time;
|
|
|
|
/* How much time between restarts. */
|
|
|
|
extern time_t restart_interval;
|
|
|
|
/* Old current working directory. */
|
|
|
|
extern const char *oldcwd;
|
|
|
|
/* Old user and group ID. */
|
|
|
|
extern uid_t old_uid;
|
|
|
|
extern gid_t old_gid;
|
|
|
|
|
|
|
|
|
2008-04-19 18:42:41 +02:00
|
|
|
/* Memory allocation in flight. Each thread can have a limited number
|
|
|
|
of allocation in flight. No need to create dynamic data
|
|
|
|
structures. We use fixed indices. */
|
|
|
|
enum in_flight
|
|
|
|
{
|
|
|
|
IDX_result_data = 0,
|
|
|
|
/* Keep the IDX_record_data entry last at all times. */
|
|
|
|
IDX_record_data = 1,
|
|
|
|
IDX_last
|
|
|
|
};
|
|
|
|
extern __thread struct mem_in_flight
|
|
|
|
{
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
int dbidx;
|
|
|
|
nscd_ssize_t blocklen;
|
2008-05-18 05:57:19 +02:00
|
|
|
nscd_ssize_t blockoff;
|
2008-04-19 18:42:41 +02:00
|
|
|
} block[IDX_last];
|
|
|
|
|
|
|
|
struct mem_in_flight *next;
|
2008-04-22 17:53:59 +02:00
|
|
|
} mem_in_flight attribute_tls_model_ie;
|
2008-04-19 18:42:41 +02:00
|
|
|
/* Global list of the mem_in_flight variables of all the threads. */
|
|
|
|
extern struct mem_in_flight *mem_in_flight_list;
|
|
|
|
|
|
|
|
|
1998-10-18 17:16:22 +02:00
|
|
|
/* Prototypes for global functions. */
|
|
|
|
|
|
|
|
/* nscd.c */
|
2000-11-20 18:40:29 +01:00
|
|
|
extern void termination_handler (int signum) __attribute__ ((__noreturn__));
|
1998-10-18 17:16:22 +02:00
|
|
|
extern int nscd_open_socket (void);
|
|
|
|
|
|
|
|
/* connections.c */
|
2003-05-04 09:00:44 +02:00
|
|
|
extern void nscd_init (void);
|
1998-10-18 17:16:22 +02:00
|
|
|
extern void close_sockets (void);
|
2001-04-23 08:04:16 +02:00
|
|
|
extern void start_threads (void) __attribute__ ((__noreturn__));
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
/* nscd_conf.c */
|
2004-08-26 20:35:05 +02:00
|
|
|
extern int nscd_parse_file (const char *fname,
|
|
|
|
struct database_dyn dbs[lastdb]);
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
/* nscd_stat.c */
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void send_stats (int fd, struct database_dyn dbs[lastdb]);
|
2000-11-20 18:40:29 +01:00
|
|
|
extern int receive_print_stats (void) __attribute__ ((__noreturn__));
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
/* cache.c */
|
2004-08-26 20:35:05 +02:00
|
|
|
extern struct datahead *cache_search (request_type, void *key, size_t len,
|
|
|
|
struct database_dyn *table,
|
|
|
|
uid_t owner);
|
|
|
|
extern int cache_add (int type, const void *key, size_t len,
|
|
|
|
struct datahead *packet, bool first,
|
2008-05-18 23:54:43 +02:00
|
|
|
struct database_dyn *table, uid_t owner,
|
|
|
|
bool prune_wakeup);
|
2007-11-06 01:45:40 +01:00
|
|
|
extern time_t prune_cache (struct database_dyn *table, time_t now, int fd);
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
/* pwdcache.c */
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void addpwbyname (struct database_dyn *db, int fd, request_header *req,
|
1999-06-11 22:58:21 +02:00
|
|
|
void *key, uid_t uid);
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void addpwbyuid (struct database_dyn *db, int fd, request_header *req,
|
1999-06-11 22:58:21 +02:00
|
|
|
void *key, uid_t uid);
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void readdpwbyname (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
extern void readdpwbyuid (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
/* grpcache.c */
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void addgrbyname (struct database_dyn *db, int fd, request_header *req,
|
1999-06-11 22:58:21 +02:00
|
|
|
void *key, uid_t uid);
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void addgrbygid (struct database_dyn *db, int fd, request_header *req,
|
1999-06-11 22:58:21 +02:00
|
|
|
void *key, uid_t uid);
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void readdgrbyname (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
extern void readdgrbygid (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
1998-10-18 17:16:22 +02:00
|
|
|
|
|
|
|
/* hstcache.c */
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void addhstbyname (struct database_dyn *db, int fd, request_header *req,
|
1999-06-11 22:58:21 +02:00
|
|
|
void *key, uid_t uid);
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void addhstbyaddr (struct database_dyn *db, int fd, request_header *req,
|
1999-06-11 22:58:21 +02:00
|
|
|
void *key, uid_t uid);
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void addhstbynamev6 (struct database_dyn *db, int fd,
|
|
|
|
request_header *req, void *key, uid_t uid);
|
|
|
|
extern void addhstbyaddrv6 (struct database_dyn *db, int fd,
|
|
|
|
request_header *req, void *key, uid_t uid);
|
|
|
|
extern void readdhstbyname (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
extern void readdhstbyaddr (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
extern void readdhstbynamev6 (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
extern void readdhstbyaddrv6 (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
|
2004-09-15 10:25:49 +02:00
|
|
|
/* aicache.c */
|
|
|
|
extern void addhstai (struct database_dyn *db, int fd, request_header *req,
|
|
|
|
void *key, uid_t uid);
|
|
|
|
extern void readdhstai (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
2004-08-26 20:35:05 +02:00
|
|
|
|
2004-09-30 09:15:40 +02:00
|
|
|
|
|
|
|
/* initgrcache.c */
|
|
|
|
extern void addinitgroups (struct database_dyn *db, int fd,
|
|
|
|
request_header *req, void *key, uid_t uid);
|
|
|
|
extern void readdinitgroups (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
|
2007-01-14 06:26:04 +01:00
|
|
|
/* servicecache.c */
|
|
|
|
extern void addservbyname (struct database_dyn *db, int fd,
|
|
|
|
request_header *req, void *key, uid_t uid);
|
|
|
|
extern void readdservbyname (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
extern void addservbyport (struct database_dyn *db, int fd,
|
|
|
|
request_header *req, void *key, uid_t uid);
|
|
|
|
extern void readdservbyport (struct database_dyn *db, struct hashentry *he,
|
|
|
|
struct datahead *dh);
|
|
|
|
|
2004-08-26 20:35:05 +02:00
|
|
|
/* mem.c */
|
2008-04-19 18:42:41 +02:00
|
|
|
extern void *mempool_alloc (struct database_dyn *db, size_t len,
|
|
|
|
enum in_flight idx);
|
2004-08-26 20:35:05 +02:00
|
|
|
extern void gc (struct database_dyn *db);
|
1998-10-19 00:02:47 +02:00
|
|
|
|
2004-09-08 19:56:46 +02:00
|
|
|
|
|
|
|
/* nscd_setup_thread.c */
|
2007-11-06 01:45:40 +01:00
|
|
|
extern int setup_thread (struct database_dyn *db);
|
2004-09-08 19:56:46 +02:00
|
|
|
|
2005-08-24 01:21:53 +02:00
|
|
|
|
|
|
|
/* Special version of TEMP_FAILURE_RETRY for functions returning error
|
|
|
|
values. */
|
|
|
|
#define TEMP_FAILURE_RETRY_VAL(expression) \
|
|
|
|
(__extension__ \
|
|
|
|
({ long int __result; \
|
|
|
|
do __result = (long int) (expression); \
|
|
|
|
while (__result == EINTR); \
|
|
|
|
__result; }))
|
|
|
|
|
1998-10-18 17:16:22 +02:00
|
|
|
#endif /* nscd.h */
|