afs: Handle osi_NewVnode failures
[openafs.git] / src / afs / IRIX / 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, int defersleep)
18 {
19      int code;
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);
24         if (code == 0)
25             return 1;
26      }
27      return 0;
28 }
29
30 extern char *makesname();
31
32 struct vcache *
33 osi_NewVnode(void)
34 {
35     struct vcache *avc;
36     char name[METER_NAMSZ];
37
38     avc = afs_osi_Alloc(sizeof(struct vcache));
39     if (avc == NULL) {
40         return NULL;
41     }
42
43     memset(avc, 0, sizeof(struct vcache));
44     avc->v.v_number = ++afsvnumbers;
45     avc->vc_rwlockid = OSI_NO_LOCKID;
46     initnsema(&avc->vc_rwlock, 1,
47               makesname(name, "vrw", avc->v.v_number));
48 #ifndef AFS_SGI53_ENV
49     initnsema(&avc->v.v_sync, 0,
50               makesname(name, "vsy", avc->v.v_number));
51 #endif
52 #ifndef AFS_SGI62_ENV
53     initnlock(&avc->v.v_lock,
54               makesname(name, "vlk", avc->v.v_number));
55 #endif
56     return avc;
57 }
58
59 void
60 osi_PrePopulateVCache(struct vcache *avc)
61 {
62     avc->uncred = 0;
63     memset(&(avc->f), 0, sizeof(struct fvcache));
64 }
65
66 void
67 osi_AttachVnode(struct vcache *avc, int seq)
68 {
69 }
70
71 void
72 osi_PostPopulateVCache(struct vcache *avc)
73 {
74     memset(&(avc->vc_bhv_desc), 0, sizeof(avc->vc_bhv_desc));
75     bhv_desc_init(&(avc->vc_bhv_desc), avc, avc, &Afs_vnodeops);
76
77 #if defined(AFS_SGI65_ENV)
78     vn_bhv_head_init(&(avc->v.v_bh), "afsvp");
79     vn_bhv_insert_initial(&(avc->v.v_bh), &(avc->vc_bhv_desc));
80     avc->v.v_mreg = avc->v.v_mregb = (struct pregion *)avc;
81 # if defined(VNODE_TRACING)
82     avc->v.v_trace = ktrace_alloc(VNODE_TRACE_SIZE, 0);
83 # endif
84     init_bitlock(&avc->v.v_pcacheflag, VNODE_PCACHE_LOCKBIT, "afs_pcache",
85                  avc->v.v_number);
86     init_mutex(&avc->v.v_filocksem, MUTEX_DEFAULT, "afsvfl", (long)avc);
87     init_mutex(&avc->v.v_buf_lock, MUTEX_DEFAULT, "afsvnbuf", (long)avc);
88 #else
89     bhv_head_init(&(avc->v.v_bh));
90     bhv_insert_initial(&(avc->v.v_bh), &(avc->vc_bhv_desc));
91 #endif
92
93     vnode_pcache_init(&avc->v);
94
95 #if defined(DEBUG) && defined(VNODE_INIT_BITLOCK)
96     /* Above define is never true execpt in SGI test kernels. */
97     init_bitlock(&avc->v.v_flag, VLOCK, "vnode", avc->v.v_number);
98 #endif
99
100 #ifdef INTR_KTHREADS
101     AFS_VN_INIT_BUF_LOCK(&(avc->v));
102 #endif
103
104     vSetVfsp(avc, afs_globalVFS);
105     vSetType(avc, VREG);
106
107     VN_SET_DPAGES(&(avc->v), NULL);
108     osi_Assert((avc->v.v_flag & VINACT) == 0);
109     avc->v.v_flag = 0;
110     osi_Assert(VN_GET_PGCNT(&(avc->v)) == 0);
111     osi_Assert(avc->mapcnt == 0 && avc->vc_locktrips == 0);
112     osi_Assert(avc->vc_rwlockid == OSI_NO_LOCKID);
113     osi_Assert(avc->v.v_filocks == NULL);
114 # if !defined(AFS_SGI65_ENV)
115     osi_Assert(avc->v.v_filocksem == NULL);
116 # endif
117     osi_Assert(avc->cred == NULL);
118 # if defined(AFS_SGI64_ENV)
119     vnode_pcache_reinit(&avc->v);
120     avc->v.v_rdev = NODEV;
121 # endif
122     vn_initlist((struct vnlist *)&avc->v);
123     avc->lastr = 0;
124 }
125
126 int
127 osi_vnhold(struct vcache *avc)
128 {
129     VN_HOLD(AFSTOV(avc));
130     return 0;
131 }