4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
22 * Copyright 2010 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
34 #include <sys/types.h>
35 #include <nfs/nfs_log.h>
36 #include "../lib/nfslog_config.h"
37 #include "buffer_list.h"
39 #define NFSLOGD_PIDFILE "/var/run/nfslogd.pid"
40 #define NFSLOG_OPTIONS_FILE "/etc/default/nfslogd"
42 #define MIN_PROCESSING_SIZE 512*1024 /* Minimum size buffer */
43 /* should reach before */
45 #define IDLE_TIME 300 /* Max time to wait w/o processing */
47 #define MAX_LOGS_PRESERVE 10 /* Number of log files to keep for */
49 #define MAPPING_UPDATE_INTERVAL (SECSPERDAY) /* frequency of updates to */
50 /* dbm records in seconds */
51 #define CYCLE_FREQUENCY 24 /* in hours */
52 #define PRUNE_TIMEOUT (SECSPERHOUR * 168)
53 #define NFSLOG_UMASK 0137 /* for creating tables and logs */
56 * RPC dispatch table for logging. Indexed by program, version, proc.
57 * Based on NFS dispatch table, but differs in that it does not xdr
58 * encode/decode arguments and results.
60 struct nfsl_proc_disp
{
61 void (*nfsl_dis_args
)(); /* prt elf nl args from rpc args */
62 void (*nfsl_dis_res
)(); /* prt elf nl res from rpc res */
63 char *procname
; /* string describing the proc */
66 struct nfsl_vers_disp
{
67 int nfsl_dis_nprocs
; /* number of procs */
68 struct nfsl_proc_disp
*nfsl_dis_proc_table
; /* proc array */
71 struct nfsl_prog_disp
{
72 rpcprog_t nfsl_dis_prog
; /* program number */
73 rpcvers_t nfsl_dis_versmin
; /* minimum version number */
74 int nfsl_dis_nvers
; /* number of version values */
75 struct nfsl_vers_disp
*nfsl_dis_vers_table
; /* versions array */
76 char *progname
; /* string describing the program */
79 struct nfsl_log_file
{
80 char *path
; /* pathname of file */
81 FILE *fp
; /* file pointer */
82 char *buf
; /* buffer where output queued before print */
83 int bufoffset
; /* current offset in (memory) buffer */
84 struct nfsl_log_file
*next
; /* next file in list */
85 struct nfsl_log_file
*prev
; /* next file in list */
89 * The following four structures are used for processing the buffer file.
98 * Simple struct for keeping track of the offset and length of
99 * records processed from the buffer file. This is used for the logic
100 * of rewriting the buffer header of that last record processed.
101 * Since records within the buffer file can be 'out of order' and nfslogd
102 * sorts those records, we need to keep track of what has been processed
103 * and where. This record keeping is then used to decide when to rewrite
104 * the buffer header and to decide the correct offset for that rewrite.
106 struct processed_records
{
107 struct processed_records
*next
;
108 struct processed_records
*prev
;
111 unsigned int num_recs
;
115 struct nfslog_buf
*next
;
116 struct nfslog_buf
*prev
;
117 char *bufpath
; /* buffer file name */
118 int fd
; /* buffer file fd */
119 flock_t fl
; /* buffer file lock */
120 uoff_t filesize
; /* file size */
121 intptr_t mmap_addr
; /* address of mmap */
122 uoff_t next_rec
; /* address of next record */
123 unsigned int last_rec_id
; /* last record id processed */
124 nfslog_buffer_header bh
; /* file buffer header */
125 struct nfslog_lr
*bh_lrp
;
127 struct nfslog_lr
*lrps
; /* raw records - not cooked */
128 /* Next fields used for tracking processed records from buf file */
129 uoff_t last_record_offset
; /* value last written to hdr */
130 struct processed_records
*prp
; /* list of processed chunks */
131 int num_pr_queued
; /* # of processed records */
135 struct nfslog_lr
*next
;
136 struct nfslog_lr
*prev
;
137 uoff_t f_offset
; /* offset for ondisk file */
138 intptr_t record
; /* mmap address of record */
139 unsigned int recsize
; /* size of this record */
140 caddr_t buffer
; /* used if mmap fails */
142 nfslog_request_record log_record
; /* decoded record */
143 bool_t (*xdrargs
)(); /* xdr function for FREE */
144 bool_t (*xdrres
)(); /* xdr function for FREE */
145 struct nfslog_buf
*lbp
;
149 * Following defines are used as a parameter to nfslog_open_trans()
150 * The bit mask passed to this function will determine which operations
151 * are placed in the log.
153 #define TRANSTOLOG_OPER_READ 0x00000001
154 #define TRANSTOLOG_OPER_WRITE 0x00000002
155 #define TRANSTOLOG_OPER_SETATTR 0x00000004
156 #define TRANSTOLOG_OPER_REMOVE 0x00000008
157 #define TRANSTOLOG_OPER_MKDIR 0x00000010
158 #define TRANSTOLOG_OPER_CREATE 0x00000020
159 #define TRANSTOLOG_OPER_RMDIR 0x00000040
160 #define TRANSTOLOG_OPER_RENAME 0x00000080
161 #define TRANSTOLOG_OPER_MKNOD 0x00000100
162 #define TRANSTOLOG_OPER_LINK 0x00000200
163 #define TRANSTOLOG_OPER_SYMLINK 0x00000400
164 #define TRANSTOLOG_OPER_READWRITE \
165 (TRANSTOLOG_OPER_READ | TRANSTOLOG_OPER_WRITE)
166 #define TRANSTOLOG_ALL ((uint32_t)~0)
169 extern boolean_t test
;
170 extern int max_logs_preserve
;
171 extern uint_t idle_time
;
172 extern boolean_t keep_running
;
173 extern boolean_t quick_cleaning
;
175 extern int cycle_log(char *, int);
176 extern int prune_dbs(char *);
177 extern int process_buffer(
178 struct buffer_ent
*, nfsl_config_t
**, int, int, int *);
179 extern struct nfslog_buf
*nfslog_open_buf(char *, int *);
180 extern void nfslog_close_buf(struct nfslog_buf
*, int);
181 extern struct nfslog_lr
*nfslog_get_logrecord(struct nfslog_buf
*);
182 extern void nfslog_free_logrecord(struct nfslog_lr
*, bool_t
);
184 extern int nfslog_process_fh_rec(struct nfslog_lr
*,
185 char *, char **, char **, bool_t
);
187 extern void *nfslog_open_elf_file(char *, nfslog_buffer_header
*, int *);
188 extern void nfslog_close_elf_file(void **);
189 extern int nfslog_process_elf_rec(void *, nfslog_request_record
*,
192 struct nfslog_trans_file
;
193 extern void *nfslog_open_trans_file(char *, uint32_t, uint32_t, int *);
195 extern void nfslog_process_trans_timeout(struct nfslog_trans_file
*,
197 extern int nfslog_process_trans_rec(void *,
198 nfslog_request_record
*, char *, char *, char *);
199 extern void nfslog_close_transactions(void **);
201 extern void nfslog_opaque_print_buf(void *, int, char *, int *, int);
206 #endif /* _NFSLOGD_H */