1 /* Copyright (c) 1998, 1999, 2000, 2003, 2004, 2005, 2006, 2007, 2009, 2011
2 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
4 Contributed by Thorsten Kukuk <kukuk@suse.de>, 1998.
6 The GNU C Library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 The GNU C Library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with the GNU C Library; if not, write to the Free
18 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
21 /* This file defines everything that client code should need to
22 know to talk to the nscd daemon. */
24 #ifndef _NSCD_CLIENT_H
25 #define _NSCD_CLIENT_H 1
29 #include <sys/types.h>
31 #include <nscd-types.h>
35 /* Version number of the daemon interface */
36 #define NSCD_VERSION 2
38 /* Path of the file where the PID of the running system is stored. */
39 #define _PATH_NSCDPID "/var/run/nscd/nscd.pid"
41 /* Path for the Unix domain socket. */
42 #define _PATH_NSCDSOCKET "/var/run/nscd/socket"
44 /* Path for the configuration file. */
45 #define _PATH_NSCDCONF "/etc/nscd.conf"
47 /* Maximum allowed length for the key. */
48 #define MAXKEYLEN 1024
51 /* Available services. */
62 SHUTDOWN
, /* Shut the server down. */
63 GETSTAT
, /* Get the server statistic. */
64 INVALIDATE
, /* Invalidate one special cache. */
77 /* Header common to all requests */
80 int32_t version
; /* Version number of the daemon interface. */
81 request_type type
; /* Service requested. */
82 int32_t key_len
; /* Key length. */
86 /* Structure sent in reply to password query. Note that this struct is
87 sent also if the service is disabled or there is no record found. */
92 nscd_ssize_t pw_name_len
;
93 nscd_ssize_t pw_passwd_len
;
96 nscd_ssize_t pw_gecos_len
;
97 nscd_ssize_t pw_dir_len
;
98 nscd_ssize_t pw_shell_len
;
102 /* Structure sent in reply to group query. Note that this struct is
103 sent also if the service is disabled or there is no record found. */
108 nscd_ssize_t gr_name_len
;
109 nscd_ssize_t gr_passwd_len
;
111 nscd_ssize_t gr_mem_cnt
;
112 } gr_response_header
;
115 /* Structure sent in reply to host query. Note that this struct is
116 sent also if the service is disabled or there is no record found. */
121 nscd_ssize_t h_name_len
;
122 nscd_ssize_t h_aliases_cnt
;
125 nscd_ssize_t h_addr_list_cnt
;
127 } hst_response_header
;
130 /* Structure sent in reply to addrinfo query. Note that this struct is
131 sent also if the service is disabled or there is no record found. */
137 nscd_ssize_t addrslen
;
138 nscd_ssize_t canonlen
;
140 } ai_response_header
;
142 /* Structure filled in by __nscd_getai. */
143 struct nscd_ai_result
151 /* Structure sent in reply to initgroups query. Note that this struct is
152 sent also if the service is disabled or there is no record found. */
158 } initgr_response_header
;
161 /* Structure sent in reply to services query. Note that this struct is
162 sent also if the service is disabled or there is no record found. */
167 nscd_ssize_t s_name_len
;
168 nscd_ssize_t s_proto_len
;
169 nscd_ssize_t s_aliases_cnt
;
171 } serv_response_header
;
174 /* Type for offsets in data part of database. */
175 typedef uint32_t ref_t
;
176 /* Value for invalid/no reference. */
177 #define ENDREF UINT32_MAX
179 /* Timestamp type. */
180 typedef uint64_t nscd_time_t
;
182 /* Maximum timestamp. */
183 #define MAX_TIMEOUT_VALUE \
184 (sizeof (time_t) == sizeof (long int) ? LONG_MAX : INT_MAX)
186 /* Alignment requirement of the beginning of the data region. */
190 /* Head of record in data part of database. */
193 nscd_ssize_t allocsize
; /* Allocated Bytes. */
194 nscd_ssize_t recsize
; /* Size of the record. */
195 nscd_time_t timeout
; /* Time when this entry becomes invalid. */
196 uint8_t notfound
; /* Nonzero if data has not been found. */
197 uint8_t nreloads
; /* Reloads without use. */
198 uint8_t usable
; /* False if the entry must be ignored. */
199 uint8_t unused
; /* Unused. */
200 uint32_t ttl
; /* TTL value used. */
202 /* We need to have the following element aligned for the response
203 header data types and their use in the 'struct dataset' types
204 defined in the XXXcache.c files. */
207 pw_response_header pwdata
;
208 gr_response_header grdata
;
209 hst_response_header hstdata
;
210 ai_response_header aidata
;
211 initgr_response_header initgrdata
;
212 serv_response_header servdata
;
219 /* Structure for one hash table entry. */
222 request_type type
:8; /* Which type of dataset. */
223 bool first
; /* True if this was the original key. */
224 nscd_ssize_t len
; /* Length of key. */
225 ref_t key
; /* Pointer to key. */
226 int32_t owner
; /* If secure table, this is the owner. */
227 ref_t next
; /* Next entry in this hash bucket list. */
228 ref_t packet
; /* Records for the result. */
231 struct hashentry
*dellist
; /* Next record to be deleted. This can be a
232 pointer since only nscd uses this field. */
233 ref_t
*prevp
; /* Pointer to field containing forward
239 /* Current persistent database version. */
242 /* Maximum time allowed between updates of the timestamp. */
243 #define MAPPING_TIMEOUT (5 * 60)
246 /* Header of persistent database file. */
247 struct database_pers_head
251 volatile int32_t gc_cycle
;
252 volatile int32_t nscd_certainly_running
;
253 volatile nscd_time_t timestamp
;
256 nscd_ssize_t data_size
;
258 nscd_ssize_t first_free
; /* Offset of first free byte in data area. */
260 nscd_ssize_t nentries
;
261 nscd_ssize_t maxnentries
;
262 nscd_ssize_t maxnsearched
;
269 uint64_t rdlockdelayed
;
270 uint64_t wrlockdelayed
;
278 /* Mapped database record. */
279 struct mapped_database
281 const struct database_pers_head
*head
;
284 int counter
; /* > 0 indicates it is usable. */
287 #define NO_MAPPING ((struct mapped_database *) -1l)
289 struct locked_map_ptr
292 struct mapped_database
*mapped
;
294 #define libc_locked_map_ptr(class, name) class struct locked_map_ptr name
297 /* Open socket connection to nscd server. */
298 extern int __nscd_open_socket (const char *key
, size_t keylen
,
299 request_type type
, void *response
,
300 size_t responselen
) attribute_hidden
;
302 /* Get reference of mapping. */
303 extern struct mapped_database
*__nscd_get_map_ref (request_type type
,
305 volatile struct locked_map_ptr
*mapptr
,
308 /* Unmap database. */
309 extern void __nscd_unmap (struct mapped_database
*mapped
);
311 /* Drop reference of mapping. */
312 static inline int __nscd_drop_map_ref (struct mapped_database
*map
,
315 if (map
!= NO_MAPPING
)
317 int now_cycle
= map
->head
->gc_cycle
;
318 if (__builtin_expect (now_cycle
!= *gc_cycle
, 0))
320 /* We might have read inconsistent data. */
321 *gc_cycle
= now_cycle
;
325 if (atomic_decrement_val (&map
->counter
) == 0)
333 /* Search the mapped database. */
334 extern struct datahead
*__nscd_cache_search (request_type type
,
337 const struct mapped_database
*mapped
,
340 /* Wrappers around read, readv and write that only read/write less than LEN
341 bytes on error or EOF. */
342 extern ssize_t
__readall (int fd
, void *buf
, size_t len
)
344 extern ssize_t
__readvall (int fd
, const struct iovec
*iov
, int iovcnt
)
346 extern ssize_t
writeall (int fd
, const void *buf
, size_t len
)
348 extern ssize_t
sendfileall (int tofd
, int fromfd
, off_t off
, size_t len
)