xref: /titanic_44/usr/src/cmd/fs.d/cachefs/cfsd/cfsd_cache.c (revision 14ea4bb737263733ad80a36b4f73f681c30a6b45)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License, Version 1.0 only
6  * (the "License").  You may not use this file except in compliance
7  * with the License.
8  *
9  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10  * or http://www.opensolaris.org/os/licensing.
11  * See the License for the specific language governing permissions
12  * and limitations under the License.
13  *
14  * When distributing Covered Code, include this CDDL HEADER in each
15  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16  * If applicable, add the following below this CDDL HEADER, with the
17  * fields enclosed by brackets "[]" replaced with your own identifying
18  * information: Portions Copyright [yyyy] [name of copyright owner]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright (c) 1994-2001 by Sun Microsystems, Inc.
24  * All rights reserved.
25  */
26 
27 #pragma ident	"%Z%%M%	%I%	%E% SMI"
28 
29 /*
30  * Methods of the cfsd_cache class.
31  */
32 
33 #include <stdio.h>
34 #include <stdlib.h>
35 #include <string.h>
36 #include <thread.h>
37 #include <synch.h>
38 #include <locale.h>
39 #include <sys/utsname.h>
40 #include <sys/stat.h>
41 #include <mdbug/mdbug.h>
42 #include <sys/fs/cachefs_fs.h>
43 #include <sys/fs/cachefs_dlog.h>
44 #include <sys/fs/cachefs_ioctl.h>
45 #include "cfsd.h"
46 #include "cfsd_kmod.h"
47 #include "cfsd_maptbl.h"
48 #include "cfsd_logfile.h"
49 #include "cfsd_fscache.h"
50 #include "cfsd_cache.h"
51 
52 /*
53  * -----------------------------------------------------------------
54  *			cfsd_cache_create
55  *
56  * Description:
57  * Arguments:
58  * Returns:
59  * Preconditions:
60  */
61 
62 cfsd_cache_object_t *
63 cfsd_cache_create(void)
64 {
65 	cfsd_cache_object_t *cache_object_p;
66 	int xx;
67 
68 	dbug_enter("cfsd_cache_create");
69 
70 	cache_object_p = cfsd_calloc(sizeof (cfsd_cache_object_t));
71 	strlcpy(cache_object_p->i_cachedir, gettext("unknown"),
72 	    sizeof (cache_object_p->i_cachedir));
73 	cache_object_p->i_refcnt = 0;
74 	cache_object_p->i_nextfscacheid = 0;
75 	cache_object_p->i_cacheid = 0;
76 	cache_object_p->i_modify = 1;
77 	cache_object_p->i_fscachelist = NULL;
78 	cache_object_p->i_fscachecount = 0;
79 
80 	/* initialize the locking mutex */
81 	xx = mutex_init(&cache_object_p->i_lock, USYNC_THREAD, NULL);
82 
83 	dbug_assert(xx == 0);
84 	dbug_leave("cfsd_cache_create");
85 	return (cache_object_p);
86 }
87 
88 /*
89  * -----------------------------------------------------------------
90  *			cfsd_cache_destroy
91  *
92  * Description:
93  * Arguments:
94  * Returns:
95  * Preconditions:
96  */
97 
98 
99 void
100 cfsd_cache_destroy(cfsd_cache_object_t *cache_object_p)
101 {
102 
103 	cfsd_fscache_object_t *fscache_object_p;
104 	cfsd_fscache_object_t *tmp_fscache_object_p;
105 	int xx;
106 
107 	dbug_enter("cfsd_cache_destroy");
108 
109 	/* get rid of any fscache objects */
110 	fscache_object_p = cache_object_p->i_fscachelist;
111 
112 	while (fscache_object_p != NULL) {
113 		tmp_fscache_object_p = fscache_object_p->i_next;
114 		cfsd_fscache_destroy(fscache_object_p);
115 		fscache_object_p = tmp_fscache_object_p;
116 	}
117 
118 	/* destroy the locking mutex */
119 	xx = mutex_destroy(&cache_object_p->i_lock);
120 	dbug_assert(xx == 0);
121 	cfsd_free(cache_object_p);
122 	dbug_leave("cfsd_cache_destroy");
123 }
124 
125 /*
126  * -----------------------------------------------------------------
127  *			cache_setup
128  *
129  * Description:
130  *	Performs setup for the cache.
131  * Arguments:
132  *	cachedirp
133  *	cacheid
134  * Returns:
135  * Preconditions:
136  *	precond(cachedirp)
137  */
138 
139 int
140 cache_setup(cfsd_cache_object_t *cache_object_p, const char *cachedirp,
141 	int cacheid)
142 {
143 
144 	/* XXX either need to prevent multiple calls to this or */
145 	/*  clean up here. */
146 
147 	int ret;
148 	struct stat64 sinfo;
149 	dbug_enter("cache_setup");
150 
151 	if ((stat64(cachedirp, &sinfo) == -1) ||
152 	    (!S_ISDIR(sinfo.st_mode)) ||
153 	    (*cachedirp != '/')) {
154 		dbug_print(("info", "%s is not a cache directory", cachedirp));
155 		ret = 0;
156 	} else {
157 		strlcpy(cache_object_p->i_cachedir, cachedirp,
158 		    sizeof (cache_object_p->i_cachedir));
159 		ret = 1;
160 	}
161 
162 	cache_object_p->i_cacheid = cacheid;
163 	cache_object_p->i_modify++;
164 
165 	dbug_leave("cache_setup");
166 	/* return result */
167 	return (ret);
168 }
169 /*
170  * -----------------------------------------------------------------
171  *			cache_lock
172  *
173  * Description:
174  * Arguments:
175  * Returns:
176  * Preconditions:
177  */
178 
179 void
180 cache_lock(cfsd_cache_object_t *cache_object_p)
181 {
182 	dbug_enter("cache_lock");
183 
184 	mutex_lock(&cache_object_p->i_lock);
185 	dbug_leave("cache_lock");
186 }
187 
188 /*
189  * -----------------------------------------------------------------
190  *			cache_unlock
191  *
192  * Description:
193  * Arguments:
194  * Returns:
195  * Preconditions:
196  */
197 
198 void
199 cache_unlock(cfsd_cache_object_t *cache_object_p)
200 {
201 	dbug_enter("cache_unlock");
202 
203 	mutex_unlock(&cache_object_p->i_lock);
204 	dbug_leave("cache_unlock");
205 }
206 /*
207  * -----------------------------------------------------------------
208  *			cache_fscachelist_at
209  *
210  * Description:
211  * Arguments:
212  *	index
213  * Returns:
214  *	Returns ...
215  * Preconditions:
216  */
217 
218 cfsd_fscache_object_t *
219 cache_fscachelist_at(cfsd_cache_object_t *cache_object_p, size_t index)
220 {
221 	cfsd_fscache_object_t *fscache_object_p;
222 	int i = 0;
223 
224 	dbug_enter("cache_fscachelist_at");
225 
226 	/* find the correct cache object */
227 	fscache_object_p = cache_object_p->i_fscachelist;
228 
229 	while ((fscache_object_p != NULL) && (i++ < index)) {
230 		fscache_object_p = fscache_object_p->i_next;
231 	}
232 
233 	dbug_leave("cache_fscachelist_at");
234 	return (fscache_object_p);
235 }
236 
237 /*
238  * -----------------------------------------------------------------
239  *			cache_fscachelist_add
240  *
241  * Description:
242  * Arguments:
243  *	cachep
244  * Returns:
245  * Preconditions:
246  *	precond(fscachep)
247  */
248 
249 void
250 cache_fscachelist_add(cfsd_cache_object_t *cache_object_p,
251 	cfsd_fscache_object_t *fscache_object_p)
252 {
253 	dbug_enter("cache_fscachelist_add");
254 
255 	dbug_precond(fscache_object_p);
256 
257 	fscache_object_p->i_next = cache_object_p->i_fscachelist;
258 	cache_object_p->i_fscachelist = fscache_object_p;
259 	cache_object_p->i_modify++;
260 	cache_object_p->i_fscachecount++;
261 	dbug_leave("cache_fscachelist_add");
262 }
263 
264 /*
265  * -----------------------------------------------------------------
266  *			cache_fscachelist_find
267  *
268  * Description:
269  * Arguments:
270  *	namep
271  * Returns:
272  *	Returns ...
273  * Preconditions:
274  *	precond(namep)
275  */
276 
277 cfsd_fscache_object_t *
278 cache_fscachelist_find(cfsd_cache_object_t *cache_object_p,
279 	const char *namep)
280 {
281 	cfsd_fscache_object_t *fscache_object_p;
282 
283 	dbug_enter("cache_fscachelist_find");
284 
285 	dbug_precond(namep);
286 
287 	/* see if the fscache exists */
288 	fscache_object_p = cache_object_p->i_fscachelist;
289 
290 	while ((fscache_object_p != NULL) &&
291 		strcmp(namep, fscache_object_p->i_name)) {
292 		fscache_object_p = fscache_object_p->i_next;
293 	}
294 
295 	dbug_leave("cache_fscachelist_find");
296 	return (fscache_object_p);
297 }
298