2 * Copyright 2000, International Business Machines Corporation and others.
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
10 #include <afsconfig.h>
11 #include "afs/param.h"
13 #include "afs/sysincludes.h" /*Standard vendor system headers */
14 #include "afsincludes.h" /*AFS-based standard headers */
17 osi_TryEvictVCache(struct vcache *avc, int *slept, int defersleep)
20 /* we can't control whether we sleep */
21 if (!VREFCOUNT_GT(avc,0)
22 && avc->opens == 0 && (avc->f.states & CUnlinkedDel) == 0) {
23 code = afs_FlushVCache(avc, slept);
30 extern char *makesname();
36 char name[METER_NAMSZ];
38 avc = afs_osi_Alloc(sizeof(struct vcache));
40 memset(avc, 0, sizeof(struct vcache));
41 avc->v.v_number = ++afsvnumbers;
42 avc->vc_rwlockid = OSI_NO_LOCKID;
43 initnsema(&avc->vc_rwlock, 1,
44 makesname(name, "vrw", avc->v.v_number));
46 initnsema(&avc->v.v_sync, 0,
47 makesname(name, "vsy", avc->v.v_number));
50 initnlock(&avc->v.v_lock,
51 makesname(name, "vlk", avc->v.v_number));
57 osi_PrePopulateVCache(struct vcache *avc)
60 memset(&(avc->f), 0, sizeof(struct fvcache));
64 osi_AttachVnode(struct vcache *avc, int seq)
69 osi_PostPopulateVCache(struct vcache *avc)
71 memset(&(avc->vc_bhv_desc), 0, sizeof(avc->vc_bhv_desc));
72 bhv_desc_init(&(avc->vc_bhv_desc), avc, avc, &Afs_vnodeops);
74 #if defined(AFS_SGI65_ENV)
75 vn_bhv_head_init(&(avc->v.v_bh), "afsvp");
76 vn_bhv_insert_initial(&(avc->v.v_bh), &(avc->vc_bhv_desc));
77 avc->v.v_mreg = avc->v.v_mregb = (struct pregion *)avc;
78 # if defined(VNODE_TRACING)
79 avc->v.v_trace = ktrace_alloc(VNODE_TRACE_SIZE, 0);
81 init_bitlock(&avc->v.v_pcacheflag, VNODE_PCACHE_LOCKBIT, "afs_pcache",
83 init_mutex(&avc->v.v_filocksem, MUTEX_DEFAULT, "afsvfl", (long)avc);
84 init_mutex(&avc->v.v_buf_lock, MUTEX_DEFAULT, "afsvnbuf", (long)avc);
86 bhv_head_init(&(avc->v.v_bh));
87 bhv_insert_initial(&(avc->v.v_bh), &(avc->vc_bhv_desc));
90 vnode_pcache_init(&avc->v);
92 #if defined(DEBUG) && defined(VNODE_INIT_BITLOCK)
93 /* Above define is never true execpt in SGI test kernels. */
94 init_bitlock(&avc->v.v_flag, VLOCK, "vnode", avc->v.v_number);
98 AFS_VN_INIT_BUF_LOCK(&(avc->v));
101 vSetVfsp(avc, afs_globalVFS);
104 VN_SET_DPAGES(&(avc->v), NULL);
105 osi_Assert((avc->v.v_flag & VINACT) == 0);
107 osi_Assert(VN_GET_PGCNT(&(avc->v)) == 0);
108 osi_Assert(avc->mapcnt == 0 && avc->vc_locktrips == 0);
109 osi_Assert(avc->vc_rwlockid == OSI_NO_LOCKID);
110 osi_Assert(avc->v.v_filocks == NULL);
111 # if !defined(AFS_SGI65_ENV)
112 osi_Assert(avc->v.v_filocksem == NULL);
114 osi_Assert(avc->cred == NULL);
115 # if defined(AFS_SGI64_ENV)
116 vnode_pcache_reinit(&avc->v);
117 avc->v.v_rdev = NODEV;
119 vn_initlist((struct vnlist *)&avc->v);
124 osi_vnhold(struct vcache *avc)
126 VN_HOLD(AFSTOV(avc));