Refactor afs_NewVCache
[openafs.git] / src / afs / SOLARIS / osi_vcache.c
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  *
5  * This software has been released under the terms of the IBM Public
6  * License.  For details, see the LICENSE file in the top-level source
7  * directory or online at http://www.openafs.org/dl/license10.html
8  */
9
10 #include <afsconfig.h>
11 #include "afs/param.h"
12
13 #include "afs/sysincludes.h"    /*Standard vendor system headers */
14 #include "afsincludes.h"        /*AFS-based standard headers */
15
16 int
17 osi_TryEvictVCache(struct vcache *avc, int *slept) {
18     int code;
19
20     if (!VREFCOUNT_GT(avc,0)
21          && avc->opens == 0 && (avc->f.states & CUnlinkedDel) == 0) {
22         code = afs_FlushVCache(avc, slept);
23         if (code == 0)
24             return 1;
25     }
26     return 0;
27 }
28
29 struct vcache *
30 osi_NewVnode(void) {
31     return (struct vcache *)afs_osi_Alloc(sizeof(struct vcache));
32 }
33
34 void
35 osi_PrePopulateVCache(struct vcache *avc) {
36     memset(avc, 0, sizeof(struct vcache));
37
38     AFS_RWLOCK_INIT(&avc->vlock, "vcache vlock");
39
40     rw_init(&avc->rwlock, "vcache rwlock", RW_DEFAULT, NULL);
41
42 #if defined(AFS_SUN55_ENV)
43     /* This is required if the kaio (kernel aynchronous io)
44      ** module is installed. Inside the kernel, the function
45      ** check_vp( common/os/aio.c) checks to see if the kernel has
46      ** to provide asynchronous io for this vnode. This
47      ** function extracts the device number by following the
48      ** v_data field of the vnode. If we do not set this field
49      ** then the system panics. The  value of the v_data field
50      ** is not really important for AFS vnodes because the kernel
51      ** does not do asynchronous io for regular files. Hence,
52      ** for the time being, we fill up the v_data field with the
53      ** vnode pointer itself. */
54     avc->v.v_data = (char *)avc;
55 #endif /* AFS_SUN55_ENV */
56
57 #if defined(AFS_BOZONLOCK_ENV)
58     afs_BozonInit(&avc->pvnLock, avc);
59 #endif
60 }
61
62 void
63 osi_AttachVnode(struct vcache *avc, int seq) { }
64
65 void
66 osi_PostPopulateVCache(struct vcache *avc) {
67     AFSTOV(avc)->v_op = afs_ops;
68     AFSTOV(avc)->v_vfsp = afs_globalVFS;
69     vSetType(avc, VREG);
70 }