openbsd-continues-20021009
[openafs.git] / src / afs / afs_prototypes.h
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 #ifndef _AFS_PROTOTYPES_H_
11 #define _AFS_PROTOTYPES_H_
12
13 /* afs_analyze.c */
14 extern void afs_FinalizeReq(struct vrequest *areq);
15 extern int afs_Analyze(register struct conn *aconn, afs_int32 acode,
16     struct VenusFid *afid, register struct vrequest *areq, int op,
17     afs_int32 locktype, struct cell *cellp);
18 extern int afs_CheckCode(afs_int32 acode, struct vrequest *areq, int where);
19 extern void afs_CopyError(register struct vrequest *afrom, register struct vrequest *ato);
20
21
22 /* afs_axscache.c */
23 extern afs_rwlock_t afs_xaxs;
24 extern struct axscache *afs_SlowFindAxs(struct axscache **cachep, afs_int32 id);
25 extern struct axscache *axs_Alloc(void);
26 extern void afs_RemoveAxs(struct axscache **headp, struct axscache *axsp);
27 extern void afs_FreeAllAxs(struct axscache **headp);
28
29 /* afs_buffer.c */
30 extern void DInit (int abuffers);
31 extern char *DRead(register afs_inode_t *fid, register int page);
32 extern void DRelease (register struct buffer *bp, int flag);
33 extern int DVOffset (register void *ap);
34 extern void DZap (afs_inode_t *fid);
35 extern void DFlush (void);
36 extern char *DNew (register afs_inode_t *fid, register int page);
37 extern void shutdown_bufferpackage(void);
38
39 /* afs_call.c */
40 extern int afs_cold_shutdown;
41 extern afs_int32 afs_setTime;
42 extern char afs_rootVolumeName[64];
43 extern void afs_shutdown(void);
44 extern void afs_FlushCBs(void);
45 extern struct afs_icl_set *afs_icl_allSets;
46 extern int afs_icl_CreateLog(char *name, afs_int32 logSize, struct afs_icl_log **outLogpp);
47 extern int afs_icl_CreateLogWithFlags(char *name, afs_int32 logSize, afs_uint32 flags, 
48         struct afs_icl_log **outLogpp);
49 extern int afs_icl_CopyOut(register struct afs_icl_log *logp, afs_int32 *bufferp, 
50         afs_int32 *bufSizep, afs_uint32 *cookiep, afs_int32 *flagsp);
51 extern int afs_icl_GetLogParms(struct afs_icl_log *logp, afs_int32 *maxSizep, 
52         afs_int32 *curSizep);
53 extern int afs_icl_LogHold(register struct afs_icl_log *logp);
54 extern int afs_icl_LogHoldNL(register struct afs_icl_log *logp);
55 extern int afs_icl_LogUse(register struct afs_icl_log *logp);
56 extern int afs_icl_LogFreeUse(register struct afs_icl_log *logp);
57 extern int afs_icl_LogSetSize(register struct afs_icl_log *logp, afs_int32 logSize);
58 extern int afs_icl_ZapLog(register struct afs_icl_log *logp);
59 extern int afs_icl_LogRele(register struct afs_icl_log *logp);
60 extern int afs_icl_LogReleNL(register struct afs_icl_log *logp);
61 extern int afs_icl_ZeroLog(register struct afs_icl_log *logp);
62 extern int afs_icl_LogFree(register struct afs_icl_log *logp);
63 extern struct afs_icl_log *afs_icl_FindLog(char *name);
64 extern int afs_icl_EnumerateLogs(int (*aproc)(), char *arock);
65 extern int afs_icl_CreateSet(char *name, struct afs_icl_log *baseLogp, 
66         struct afs_icl_log *fatalLogp, struct afs_icl_set **outSetpp);
67 extern int afs_icl_CreateSetWithFlags(char *name, struct afs_icl_log *baseLogp, 
68         struct afs_icl_log *fatalLogp, afs_uint32 flags, struct afs_icl_set **outSetpp);
69 extern int afs_icl_SetEnable(struct afs_icl_set *setp, afs_int32 eventID, int setValue);
70 extern int afs_icl_GetEnable(struct afs_icl_set *setp, afs_int32 eventID, 
71         int *getValuep);
72 extern int afs_icl_ZeroSet(struct afs_icl_set *setp);
73 extern int afs_icl_EnumerateSets(int (*aproc)(), char *arock);
74 extern int afs_icl_AddLogToSet(struct afs_icl_set *setp, struct afs_icl_log *newlogp);
75 extern int afs_icl_SetSetStat(struct afs_icl_set *setp, int op);
76 extern int afs_icl_SetHold(register struct afs_icl_set *setp);
77 extern int afs_icl_ZapSet(register struct afs_icl_set *setp);
78 extern int afs_icl_SetRele(register struct afs_icl_set *setp);
79 extern int afs_icl_SetFree(register struct afs_icl_set *setp);
80 extern struct afs_icl_set *afs_icl_FindSet(char *name);
81
82 extern int afs_icl_Event4(register struct afs_icl_set *setp, afs_int32 eventID, 
83         afs_int32 lAndT, long p1, long p2, long p3, long p4);
84 extern int afs_icl_Event3(register struct afs_icl_set *setp, afs_int32 eventID, 
85         afs_int32 lAndT, long p1, long p2, long p3);
86 extern int afs_icl_Event2(register struct afs_icl_set *setp, afs_int32 eventID, 
87         afs_int32 lAndT, long p1, long p2);
88 extern int afs_icl_Event1(register struct afs_icl_set *setp, afs_int32 eventID, 
89         afs_int32 lAndT, long p1);
90 extern int afs_icl_Event0(register struct afs_icl_set *setp, afs_int32 eventID, 
91         afs_int32 lAndT);
92 extern int afs_icl_AppendRecord(register struct afs_icl_log *logp, afs_int32 op, 
93         afs_int32 types, long p1, long p2, long p3, long p4);
94
95 extern int afs_CheckInit(void);
96 extern void afs_shutdown(void);
97 extern void shutdown_afstest(void);
98 extern void afs_shutdown_BKG(void);
99
100
101 /* afs_callback.c */
102 extern afs_int32 afs_allCBs;
103 extern afs_int32 afs_oddCBs;
104 extern afs_int32 afs_evenCBs;
105 extern afs_int32 afs_allZaps;
106 extern afs_int32 afs_oddZaps;
107 extern afs_int32 afs_evenZaps;
108 extern afs_int32 afs_connectBacks;
109 extern unsigned long lastCallBack_vnode;
110 extern unsigned int lastCallBack_dv;
111 extern osi_timeval_t lastCallBack_time;
112 extern struct interfaceAddr afs_cb_interface;
113
114 extern int afs_RXCallBackServer(void);
115 extern int SRXAFSCB_GetCE(struct rx_call *a_call, afs_int32 a_index, struct AFSDBCacheEntry *a_result);
116 extern int SRXAFSCB_GetCE64(struct rx_call *a_call, afs_int32 a_index, struct AFSDBCacheEntry64 *a_result);
117 extern int SRXAFSCB_GetLock (struct rx_call *a_call, afs_int32 a_index, struct AFSDBLock *a_result);
118 extern int SRXAFSCB_CallBack(struct rx_call *a_call, register struct AFSCBFids *a_fids, struct AFSCBs *a_callbacks);
119 extern int SRXAFSCB_Probe(struct rx_call *a_call);
120 extern int SRXAFSCB_InitCallBackState(struct rx_call *a_call);
121 extern int SRXAFSCB_XStatsVersion(struct rx_call *a_call, afs_int32 *a_versionP);
122 extern int SRXAFSCB_GetXStats(struct rx_call *a_call, afs_int32 a_clientVersionNum,
123         afs_int32 a_collectionNumber, afs_int32 *a_srvVersionNumP,
124         afs_int32 *a_timeP, AFSCB_CollData *a_dataP);
125 extern int afs_RXCallBackServer(void);
126 extern int shutdown_CB(void) ;
127 extern int SRXAFSCB_InitCallBackState2(struct rx_call *a_call, struct interfaceAddr *addr);
128 extern int SRXAFSCB_WhoAreYou(struct rx_call *a_call, struct interfaceAddr *addr);
129 extern int SRXAFSCB_InitCallBackState3(struct rx_call *a_call, afsUUID *a_uuid);
130 extern int SRXAFSCB_ProbeUuid(struct rx_call *a_call, afsUUID *a_uuid);
131 extern int SRXAFSCB_GetServerPrefs(struct rx_call *a_call, afs_int32 a_index,
132         afs_int32 *a_srvr_addr, afs_int32 *a_srvr_rank);
133 extern int SRXAFSCB_GetCellServDB(struct rx_call *a_call, afs_int32 a_index,
134     char **a_name, serverList *a_hosts);
135 extern int SRXAFSCB_GetLocalCell(struct rx_call *a_call, char **a_name);
136 extern int SRXAFSCB_GetCacheConfig(struct rx_call *a_call, afs_uint32 callerVersion,
137         afs_uint32 *serverVersion, afs_uint32 *configCount, cacheConfig *config);
138 extern int SRXAFSCB_FetchData(struct rx_call *rxcall, struct AFSFid *Fid, afs_int32 Fd,
139         afs_int64 Position, afs_int64 Length, afs_int64 *TotalLength);
140 extern int SRXAFSCB_StoreData(struct rx_call *rxcall, struct AFSFid *Fid, afs_int32 Fd,
141         afs_int64 Position, afs_int64 Length, afs_int64 *TotalLength);
142
143
144 /* afs_cbqueue.c */
145 extern afs_rwlock_t afs_xcbhash;
146 extern void afs_QueueCallback(struct vcache *avc, unsigned int atime, struct volume *avp);
147 extern void afs_CheckCallbacks(unsigned int secs);
148 extern void afs_FlushCBs(void);
149 extern void afs_FlushServerCBs(struct server *srvp);
150 extern int afs_BumpBase(void);
151 extern void afs_InitCBQueue(int doLockInit);
152 extern void afs_DequeueCallback(struct vcache *avc);
153
154 /* afs_cell.c */
155 extern afs_rwlock_t afs_xcell;
156 extern void afs_CellInit(void);
157 extern void shutdown_cell(void);
158 extern int afs_cellname_init(ino_t inode, int lookupcode);
159 extern int afs_cellname_write();
160 extern afs_int32 afs_NewCell(char *acellName, afs_int32 *acellHosts,
161         int aflags, char *linkedcname, u_short fsport, u_short vlport,
162         int timeout);
163 extern afs_int32 afs_SetPrimaryCell(char *acellName);
164 extern struct cell *afs_GetCell(afs_int32 acell, afs_int32 locktype);
165 extern struct cell *afs_GetCellStale(afs_int32 acell, afs_int32 locktype);
166 extern struct cell *afs_GetCellByIndex(afs_int32 cellidx, afs_int32 locktype);
167 extern struct cell *afs_GetCellByName(char *acellName, afs_int32 locktype);
168 extern struct cell *afs_GetPrimaryCell(afs_int32 locktype);
169 extern int afs_IsPrimaryCellNum(afs_int32 cellnum);
170 extern int afs_IsPrimaryCell(struct cell *cell);
171 extern void *afs_TraverseCells(void *(*cb)(struct cell *, void *), void *arg);
172 extern int afs_CellOrAliasExists(char *aname);
173 extern int afs_CellNumValid(afs_int32 cellnum);
174 extern afs_int32 afs_NewCellAlias(char *alias, char *cell);
175 extern struct cell_alias *afs_GetCellAlias(int index);
176 extern int afs_AFSDBHandler(char *acellName, int acellNameLen,
177         afs_int32 *kernelMsg);
178 extern void afs_LookupAFSDB(char *acellName);
179 extern void afs_StopAFSDB(void);
180 extern void afs_RemoveCellEntry(struct server *srvp);
181
182 /* afs_chunk.c */
183 extern afs_int32 afs_FirstCSize;
184 extern afs_int32 afs_OtherCSize;
185 extern afs_int32 afs_LogChunk;
186
187 /* afs_cell.c */
188 extern struct cell *afs_GetRealCellByIndex(register afs_int32 cellindex,
189                                            afs_int32 locktype,
190                                            afs_int32 refresh);
191
192 /* afs_conn.c */
193 extern afs_int32 cryptall;
194 extern afs_rwlock_t afs_xinterface;
195 extern afs_rwlock_t afs_xconn;
196 extern struct conn *afs_Conn(register struct VenusFid *afid,
197         register struct vrequest *areq, afs_int32 locktype);
198 extern struct conn *afs_ConnBySA(struct srvAddr *sap, unsigned short aport,
199                           afs_int32 acell, struct unixuser *tu,
200                           int force_if_down, afs_int32 create, afs_int32 locktype);
201 extern struct conn *afs_ConnByMHosts(struct server *ahosts[], unsigned short aport,
202         afs_int32 acell, register struct vrequest *areq, afs_int32 locktype);
203 extern struct conn *afs_ConnByHost(struct server *aserver, unsigned short aport, 
204         afs_int32 acell, struct vrequest *areq, int aforce, afs_int32 locktype);
205 extern void afs_PutConn(register struct conn *ac, afs_int32 locktype);
206 extern void ForceNewConnections(struct srvAddr *sap);
207
208
209 /* afs_daemons.c */
210 extern afs_lock_t afs_xbrs;
211 extern short afs_brsWaiters;
212 extern short afs_brsDaemons;
213 extern struct brequest afs_brs[NBRS];
214 extern struct afs_osi_WaitHandle AFS_WaitHandler, AFS_CSWaitHandler;
215 extern afs_int32 afs_gcpags;
216 extern afs_int32 afs_gcpags_procsize;
217 extern afs_int32 afs_CheckServerDaemonStarted;
218 extern afs_int32 PROBE_INTERVAL;
219
220 extern void afs_Daemon(void);
221 extern struct brequest *afs_BQueue(register short aopcode, register struct vcache *avc, 
222         afs_int32 dontwait, afs_int32 ause, struct AFS_UCRED *acred, 
223         afs_size_t asparm0, afs_size_t asparm1, void *apparm0);
224 extern void afs_CheckServerDaemon(void);
225 extern int afs_CheckRootVolume (void);
226 extern void afs_BRelease(register struct brequest *ab);
227 extern int afs_BBusy(void);
228 extern int afs_BioDaemon (afs_int32 nbiods);
229 extern void afs_BackgroundDaemon(void);
230 extern void shutdown_daemons(void);
231 extern int afs_sgidaemon(void);
232
233
234 /* afs_dcache.c */
235 extern u_int afs_min_cache;
236 extern afs_int32 *afs_dvhashTbl;
237 extern afs_int32 afs_dhashsize;
238 extern afs_rwlock_t afs_xdcache;
239 extern afs_size_t afs_vmMappingEnd;
240 extern afs_int32 afs_blocksUsed;
241 extern afs_int32 afs_blocksDiscarded;
242 extern int afs_WaitForCacheDrain;
243 extern int cacheDiskType;
244 extern unsigned char *afs_indexFlags;
245 extern struct afs_cacheOps *afs_cacheType;
246 extern ino_t cacheInode;
247 extern struct osi_file *afs_cacheInodep;
248 extern void afs_dcacheInit(int afiles, int ablocks, int aDentries, int achunk,
249                            int aflags);
250 extern int afs_PutDCache(register struct dcache *adc);
251 extern void afs_FlushDCache(register struct dcache *adc);
252 extern void shutdown_dcache(void);
253 extern void afs_CacheTruncateDaemon(void);
254 extern afs_int32 afs_fsfragsize;
255 extern struct dcache *afs_MemGetDSlot(register afs_int32 aslot, register struct dcache *tmpdc);
256 extern struct dcache *afs_GetDCache(register struct vcache *avc, afs_size_t abyte, 
257         register struct vrequest *areq, afs_size_t *aoffset, afs_size_t *alen, 
258         int aflags);
259 extern struct dcache *afs_FindDCache(register struct vcache *avc, afs_size_t abyte);
260 extern void afs_StoreWarn(register afs_int32 acode, afs_int32 avolume, register afs_int32 aflags);
261 extern void afs_MaybeWakeupTruncateDaemon(void);
262 extern void afs_CacheTruncateDaemon(void);
263 extern void afs_AdjustSize(register struct dcache *adc, register afs_int32 newSize);
264 extern int afs_HashOutDCache(struct dcache *adc);
265 extern int afs_MaybeFreeDiscardedDCache(void);
266 extern int afs_RefDCache(struct dcache *adc);
267 extern void afs_TryToSmush(register struct vcache *avc, struct AFS_UCRED *acred,
268         int sync);
269 extern void updateV2DC(int lockVc, struct vcache *v, struct dcache *d, int src);
270 extern void afs_WriteThroughDSlots(void);
271 extern struct dcache *afs_UFSGetDSlot(register afs_int32 aslot, register struct dcache *tmpdc);
272 extern int afs_WriteDCache(register struct dcache *adc, int atime);
273 extern int afs_wakeup(register struct vcache *avc);
274 extern int afs_InitCacheFile(char *afile, ino_t ainode);
275
276
277 /* afs_dynroot.c */
278 extern int afs_IsDynrootFid(struct VenusFid *fid);
279 extern void afs_GetDynrootFid(struct VenusFid *fid);
280 extern int afs_IsDynroot(struct vcache *avc);
281 extern void afs_DynrootInvalidate(void);
282 extern void afs_GetDynroot(char **dynrootDir, int *dynrootLen,
283         struct AFSFetchStatus *status);
284 extern void afs_PutDynroot(void);
285 extern int afs_DynrootNewVnode(struct vcache *avc,
286         struct AFSFetchStatus *status);
287 extern int afs_SetDynrootEnable(int enable);
288 extern int afs_GetDynrootEnable(void);
289 extern int afs_DynrootVOPRemove(struct vcache *avc, struct AFS_UCRED *acred,
290         char *aname);
291 extern int afs_DynrootVOPSymlink(struct vcache *avc, struct AFS_UCRED *acred, 
292         char *aname, char *atargetName);
293
294 /* afs_exporter.c */
295 extern struct afs_exporter *root_exported;
296 extern struct afs_exporter *exporter_find(int type);
297
298 /* afs_init.c */
299 extern struct cm_initparams cm_initParams;
300 extern int afs_resourceinit_flag;
301 extern afs_rwlock_t afs_puttofileLock;
302 extern char *afs_sysname;
303 extern char *afs_sysnamelist[MAXNUMSYSNAMES];
304 extern int afs_sysnamecount;
305 extern afs_int32 cacheInfoModTime;
306 extern int afs_CacheInit(afs_int32 astatSize, afs_int32 afiles, afs_int32 
307         ablocks, afs_int32 aDentries, afs_int32 aVolumes, afs_int32 achunk, 
308         afs_int32 aflags, afs_int32 ninodes, afs_int32 nusers);
309 extern void afs_ComputeCacheParms(void);
310 extern int afs_InitCacheInfo(register char *afile);
311 extern int afs_ResourceInit(int preallocs);
312 extern void shutdown_cache(void);
313 extern void shutdown_vnodeops(void);
314 extern void shutdown_AFS(void);
315
316 /* afs_lock.c */
317 extern void Lock_Init(register struct afs_lock *lock);
318 extern void ObtainLock(register struct afs_lock *lock, int how, 
319         unsigned int src_indicator);
320 extern void ReleaseLock(register struct afs_lock *lock, int how);
321 extern int Afs_Lock_Trace(int op, struct afs_lock *alock, int type, char *file, int line);
322 extern void Afs_Lock_Obtain(register struct afs_lock *lock, int how);
323 extern void Afs_Lock_ReleaseR(register struct afs_lock *lock);
324 extern void Afs_Lock_ReleaseW(register struct afs_lock *lock);
325 extern void afs_osi_SleepR(register char *addr, register struct afs_lock *alock);
326 extern void afs_osi_SleepW(register char *addr, register struct afs_lock *alock);
327 extern void afs_osi_SleepS(register char *addr, register struct afs_lock *alock);
328 #ifndef AFS_NOBOZO_LOCK
329 extern void afs_BozonLock(struct afs_bozoLock *alock, struct vcache *avc);
330 extern void afs_BozonUnlock(struct afs_bozoLock *alock, struct vcache *avc);
331 extern void afs_BozonInit(struct afs_bozoLock *alock, struct vcache *avc);
332 extern int afs_CheckBozonLock(struct afs_bozoLock *alock);
333 extern int afs_CheckBozonLockBlocking(struct afs_bozoLock *alock);
334 #endif
335
336
337
338
339 /* afs_mariner.c */
340 extern afs_int32 afs_mariner;
341 extern afs_int32 afs_marinerHost;
342 extern struct rx_service *afs_server;
343 extern int afs_AddMarinerName(register char *aname, register struct vcache *avc);
344 extern char *afs_GetMariner(register struct vcache *avc);
345 extern void afs_MarinerLogFetch(register struct vcache *avc, register afs_int32 off,
346         register afs_int32 bytes, register afs_int32 idx);
347 extern void afs_MarinerLog(register char *astring, register struct vcache *avc);
348 extern void shutdown_mariner(void);
349
350
351 /* afs_memcache.c */
352 extern void *afs_MemCacheOpen(ino_t blkno);
353 extern int afs_InitMemCache(int size, int blkSize, int flags);
354 extern int afs_MemCacheClose(char *file);
355 extern void *afs_MemCacheOpen(ino_t blkno);
356 extern int afs_MemReadBlk(register struct memCacheEntry *mceP, int offset, char *dest, int size);
357 extern int afs_MemReadvBlk(register struct memCacheEntry *mceP, int offset, struct iovec *iov, int nio, int size);
358 extern int afs_MemReadUIO(ino_t blkno, struct uio *uioP);
359 extern int afs_MemWriteBlk(register struct memCacheEntry *mceP, int offset, char *src, int size);
360 extern int afs_MemWritevBlk(register struct memCacheEntry *mceP, int offset, struct iovec *iov, int nio, int size);
361 extern int afs_MemWriteUIO(ino_t blkno, struct uio *uioP);
362 extern int afs_MemCacheTruncate(register struct memCacheEntry *mceP, int size);
363 extern int afs_MemCacheStoreProc(register struct rx_call *acall, register struct memCacheEntry *mceP, 
364         register afs_int32 alen, struct vcache *avc, int *shouldWake, afs_size_t *abytesToXferP, 
365         afs_size_t *abytesXferredP, afs_int32 length);
366 extern int afs_MemCacheFetchProc(register struct rx_call *acall, register struct memCacheEntry *mceP, 
367         afs_size_t abase, struct dcache *adc, struct vcache *avc, afs_size_t *abytesToXferP, 
368         afs_size_t *abytesXferredP, afs_int32 lengthFound);
369 extern void shutdown_memcache(void);
370
371
372 /* afs_nfsclnt.c */
373 extern struct afs_exporter *afs_nfsexported;
374 extern struct afs_exporter *afs_nfsexporter;
375
376 /* afs_osi.c */
377 extern afs_lock_t afs_ftf;
378 extern void afs_osi_Invisible(void);
379 extern void afs_osi_RxkRegister(void);
380 extern void afs_osi_MaskSignals(void);
381 extern void afs_osi_UnmaskRxkSignals(void);
382 extern void *afs_osi_Alloc(size_t x);
383 extern void *afs_osi_Alloc_NoSleep(size_t x);
384 extern void afs_osi_Free(void *x, size_t asize);
385 extern void afs_osi_FreeStr(char *x);
386 extern void osi_Init(void);
387 extern int osi_Active(register struct vcache *avc);
388 extern void osi_FlushPages(register struct vcache *avc, struct AFS_UCRED *credp);
389 extern void osi_FlushText_really(register struct vcache *vp);
390 extern void afs_osi_MaskSignals(void);
391 extern void afs_osi_UnmaskRxkSignals(void);
392 extern void afs_osi_RxkRegister(void);
393 extern void afs_osi_Invisible(void);
394 extern int osi_VMDirty_p(struct vcache *avc);
395 #ifndef UKERNEL
396 extern void osi_ReleaseVM(struct vcache *avc, struct AFS_UCRED *acred);
397 #endif
398 extern void shutdown_osi(void);
399 extern int afs_osi_suser(void *credp);
400 extern void afs_osi_TraverseProcTable(void);
401 #if defined(KERNEL) && !defined(UKERNEL) && defined(AFS_PROC)
402 extern const struct AFS_UCRED *afs_osi_proc2cred(AFS_PROC *pr);
403 #endif
404
405 /* afs_osi_pag.c */
406 extern afs_uint32 genpag(void);
407 extern afs_uint32 getpag(void);
408 #if defined(AFS_OSF_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
409 extern int AddPag(struct proc *p, afs_int32 aval, struct AFS_UCRED **credpp);
410 #else
411 extern int AddPag(afs_int32 aval, struct AFS_UCRED **credpp);
412 #endif
413 extern int afs_InitReq(register struct vrequest *av, struct AFS_UCRED *acred);
414 extern afs_uint32 afs_get_pag_from_groups(gid_t g0a, gid_t g1a);
415 extern void afs_get_groups_from_pag(afs_uint32 pag, gid_t *g0p, gid_t *g1p);
416 extern afs_int32 PagInCred(const struct AFS_UCRED *cred);
417
418 /* afs_osi_alloc.c */
419 extern afs_int32 afs_preallocs;
420 extern afs_lock_t osi_fsplock;
421 extern afs_lock_t osi_flplock;
422 extern void osi_FreeLargeSpace(void *adata);
423 extern void osi_FreeMediumSpace(void *adata);
424 extern void osi_FreeSmallSpace(void *adata);
425 extern void *osi_AllocLargeSpace(size_t size);
426 extern void *osi_AllocMediumSpace(size_t size);
427 extern void *osi_AllocSmallSpace(size_t size);
428 #ifndef osi_AllocSmall
429 extern char *osi_AllocSmall(register afs_int32 size, register afs_int32 morespace);
430 #endif
431
432
433
434 /* ARCH/osi_misc.c */
435 extern void osi_iput(struct inode *ip);
436 extern void afs_osi_SetTime(osi_timeval_t *atv);
437
438 /* LINUX/osi_misc.c */
439 #if AFS_LINUX24_ENV
440 extern int osi_lookupname(char *aname, uio_seg_t seg, int followlink,
441                vnode_t **dirvpp, struct dentry **dpp);
442 extern int osi_InitCacheInfo(char *aname);
443 extern int osi_rdwr(int rw, struct osi_file *file, caddr_t addrp, size_t asize,
444              size_t *resid);
445 extern int osi_file_uio_rdwr(struct osi_file *osifile, uio_t *uiop, int rw);
446 extern void setup_uio(uio_t *uiop, struct iovec *iovecp, char *buf,
447                              afs_offs_t pos, int count, uio_flag_t flag,
448                              uio_seg_t seg);
449 extern int uiomove(char *dp, int length, uio_flag_t rw, uio_t *uiop);
450 extern void osi_linux_free_inode_pages(void);
451 extern void osi_clear_inode(struct inode *ip);
452 extern void check_bad_parent(struct dentry *dp);
453 #endif
454 extern void osi_linux_mask(void);
455 extern void osi_linux_unmask(void);
456 extern void osi_linux_rxkreg(void);
457
458
459 /* ARCH/osi_sleep.c */
460 extern void afs_osi_InitWaitHandle(struct afs_osi_WaitHandle *achandle);
461 extern void afs_osi_CancelWait(struct afs_osi_WaitHandle *achandle);
462 extern int afs_osi_Wait(afs_int32 ams, struct afs_osi_WaitHandle *ahandle, int aintok);
463 #ifndef afs_osi_Wakeup
464 extern int afs_osi_Wakeup(void *event);
465 #endif
466 #ifndef afs_osi_Sleep
467 extern void afs_osi_Sleep(void *event);
468 #endif
469 #ifndef afs_osi_SleepSig
470 extern int afs_osi_SleepSig(void *event);
471 #endif
472
473 /* ARCH/osi_file.c */
474 extern int afs_osicred_initialized;
475 #if defined(AFS_SUN57_64BIT_ENV) || defined(AFS_SGI62_ENV)
476 extern void *osi_UFSOpen(ino_t ainode);
477 #else
478 extern void *osi_UFSOpen(afs_int32 ainode);
479 #endif
480 extern int afs_osi_Stat(register struct osi_file *afile, register struct osi_stat *astat);
481 extern int osi_UFSClose(register struct osi_file *afile);
482 extern int osi_UFSTruncate(register struct osi_file *afile, afs_int32 asize);
483 extern void osi_DisableAtimes(struct vnode *avp);
484 extern int afs_osi_Read(register struct osi_file *afile, int offset, void *aptr, afs_int32 asize);
485 extern int afs_osi_Write(register struct osi_file *afile, afs_int32 offset, void *aptr, afs_int32 asize);
486 extern int afs_osi_MapStrategy(int (*aproc)(), register struct buf *bp);
487 extern void shutdown_osifile(void);
488
489
490 /* ARCH/osi_vm.c */
491 extern int osi_VM_FlushVCache(struct vcache *avc, int *slept);
492 extern void osi_VM_StoreAllSegments(struct vcache *avc);
493 extern void osi_VM_TryToSmush(struct vcache *avc, struct AFS_UCRED *acred, 
494         int sync);
495 extern void osi_VM_FlushPages(struct vcache *avc, struct AFS_UCRED *credp);
496 extern void osi_VM_Truncate(struct vcache *avc, int alen, struct AFS_UCRED *acred);
497 extern void osi_VM_TryReclaim(struct vcache *avc, int *slept);
498 extern void osi_VM_NukePages(struct vnode *vp, off_t offset, off_t size);
499 extern int osi_VM_Setup(struct vcache *avc, int force);
500
501 #ifdef AFS_SUN5_ENV
502 extern int osi_VM_GetDownD(struct vcache *avc, struct dcache *adc);
503 extern void osi_VM_PreTruncate(struct vcache *avc, int alen, struct AFS_UCRED *acred);
504 #endif
505
506
507 /* ARCH/osi_vnodeops.c */
508 extern struct vnodeops Afs_vnodeops;
509 #if defined(AFS_OSF_ENV)
510 #if defined(AFS_OSF30_ENV)
511 extern int max_vnodes;                  /* number of total system vnodes */
512 #else
513 extern int nvnode;                      /* number of total system vnodes */
514 extern int numvnodes;                   /* number vnodes in use now */ 
515 #endif 
516 #ifdef AFS_DUX40_ENV
517 extern struct vfs_ubcops afs_ubcops;
518 #endif
519 #endif
520
521 /* afs_osifile.c */
522
523 /* afs_osi_pag.c */
524 extern afs_uint32 pag_epoch;
525 extern afs_uint32 pagCounter;
526
527 /* OS/osi_vfsops.c */
528 #if defined(AFS_OSF_ENV) || defined(AFS_XBSD_ENV) || defined(AFS_DARWIN_ENV)
529 extern struct mount *afs_globalVFS;
530 #else
531 extern struct vfs *afs_globalVFS;
532 #endif
533 extern struct vcache *afs_globalVp;
534 #ifdef AFS_LINUX20_ENV
535 extern void vcache2inode(struct vcache *avc);
536 #endif
537
538 /* afs_pioctl.c */
539 extern struct VenusFid afs_rootFid;
540 extern afs_int32 afs_waitForever;
541 extern short afs_waitForeverCount;
542 extern afs_int32 afs_showflags;
543 extern int afs_defaultAsynchrony;
544
545 /* afs_segments.c */
546 extern int afs_StoreMini(register struct vcache *avc, struct vrequest *areq);
547 extern int afs_StoreAllSegments(register struct vcache *avc, struct vrequest *areq,
548         int sync);
549 extern int afs_InvalidateAllSegments(struct vcache *avc);
550 extern int afs_TruncateAllSegments(register struct vcache *avc, afs_size_t alen,
551         struct vrequest *areq, struct AFS_UCRED *acred);
552
553 /* afs_server.c */
554 extern afs_rwlock_t afs_xsrvAddr;
555 extern afs_rwlock_t afs_xserver;
556 extern afs_rwlock_t afs_icl_lock;
557 extern struct srvAddr *afs_srvAddrs[NSERVERS];
558 extern struct server *afs_servers[NSERVERS];
559 extern int afs_totalServers;
560 extern struct server *afs_setTimeHost;
561 extern struct server *afs_FindServer (afs_int32 aserver, ushort aport,
562                                      afsUUID *uuidp, afs_int32 locktype);
563 extern struct server *afs_GetServer(afs_uint32 *aserver, afs_int32 nservers,
564                                     afs_int32 acell, u_short aport,
565                                     afs_int32 locktype, afsUUID *uuidp,
566                                     afs_int32 addr_uniquifier);
567 extern void afs_MarkServerUpOrDown(struct srvAddr *sa, int a_isDown);
568 extern void afs_ServerDown(struct srvAddr *sa);
569 extern void afs_CountServers(void);
570 extern void afs_CheckServers(int adown, struct cell *acellp);
571 extern unsigned int afs_random(void);
572 extern int afs_randomMod15(void);
573 extern int afs_randomMod127(void);
574 extern void afs_SortOneServer(struct server *asp);
575 extern void afs_SortServers(struct server *aservers[], int count);
576 extern void afs_FlushServer(struct server *srvp);
577 extern void afs_RemoveSrvAddr(struct srvAddr *sap);
578 extern void afs_ActivateServer(struct srvAddr *sap);
579 #ifdef AFS_USERSPACE_IP_ADDR
580 extern int afsi_SetServerIPRank(struct srvAddr *sa, afs_int32 addr, afs_uint32 subnetmask);
581 #else
582 #if (!defined(AFS_SUN5_ENV)) && defined(USEIFADDR)
583 void afsi_SetServerIPRank(struct srvAddr *sa, struct in_ifaddr *ifa);
584 #endif
585 #endif
586
587
588
589 /* afs_osidnlc.c */
590 extern int osi_dnlc_enter(struct vcache *adp, char *aname, struct vcache *avc, afs_hyper_t *avno);
591 extern struct vcache *osi_dnlc_lookup(struct vcache *adp, char *aname, int locktype);
592 extern int osi_dnlc_remove(struct vcache *adp, char *aname, struct vcache *avc );
593 extern int osi_dnlc_purgedp(struct vcache *adp);
594 extern int osi_dnlc_purgevp(struct vcache *avc);
595 extern int osi_dnlc_purge(void);
596 extern int osi_dnlc_purgevol(struct VenusFid *fidp);
597 extern int osi_dnlc_init(void);
598 extern int osi_dnlc_shutdown(void);
599
600
601 /* afs_stat.c */
602 extern struct afs_CMStats afs_cmstats;
603 extern struct afs_stats_CMPerf afs_stats_cmperf;
604 extern struct afs_stats_CMFullPerf afs_stats_cmfullperf;
605 extern afs_int32 afs_stats_XferSumBytes[AFS_STATS_NUM_FS_XFER_OPS];
606 extern void afs_InitStats(void);
607 extern void afs_GetCMStat(char **ptr, unsigned *size);
608 #ifndef AFS_NOSTATS
609 extern void afs_AddToMean(struct afs_MeanStats *oldMean, afs_int32 newValue);
610 #endif
611
612
613 /* UKERNEL/afs_usrops.c */
614 #ifdef UKERNEL
615 extern void uafs_Shutdown(void);
616 extern void osi_ReleaseVM(struct vcache *avc, int len, struct usr_ucred *credp);
617 extern int osi_GetTime(struct timeval *tv);
618 #endif
619
620
621
622
623 /* afs_user.c */
624 extern afs_rwlock_t afs_xuser;
625 extern struct unixuser *afs_users[NUSERS];
626 extern struct unixuser *afs_FindUser(afs_int32 auid, afs_int32 acell, afs_int32 locktype);
627 extern struct unixuser *afs_GetUser(register afs_int32 auid, 
628         afs_int32 acell, afs_int32 locktype);
629 #if AFS_GCPAGS
630 extern afs_int32 afs_GCPAGs(afs_int32 *ReleasedCount);
631 extern void afs_GCPAGs_perproc_func(AFS_PROC *pproc);
632 #endif /* AFS_GCPAGS */
633 extern void afs_ComputePAGStats(void);
634 extern void afs_PutUser(register struct unixuser *au, afs_int32 locktype);
635 extern void afs_GCUserData(int aforce);
636 extern void afs_CheckTokenCache(void);
637 extern void afs_ResetAccessCache(afs_int32 uid, int alock);
638 extern void afs_ResetUserConns (register struct unixuser *auser);
639 extern void afs_SetPrimary(register struct unixuser *au, register int aflag);
640
641
642 /* afs_util.c */
643 extern char *afs_cv2string(char *ttp, afs_uint32 aval);
644 extern int afs_strcasecmp(char *s1, char *s2);
645 extern char *afs_strdup(char *s);
646 extern char *afs_strchr(char *s, int c);
647 extern void print_internet_address(char *preamble, struct srvAddr *sa,
648                             char *postamble, int flag);
649 extern afs_int32 afs_data_pointer_to_int32(const void *p);
650
651 #if 0 /* problems - need to change to varargs, right now is incorrect usage
652         throughout code */
653 extern void afs_warn(char *a, long b, long c, long d, long e, long f, long g, 
654         long h, long i, long j);
655 extern void afs_warnuser(char *a, long b, long c, long d, long e, long f,
656         long g, long h, long i, long j);
657 #else
658 extern void afs_warn();
659 extern void afs_warnuser();
660 #endif
661 extern void afs_CheckLocks(void);
662 extern int afs_badop(void);
663 extern int afs_noop(void);
664 extern afs_int32 afs_data_pointer_to_int32(const void *p);
665
666
667
668 /* afs_vcache.c */
669 extern afs_int32 afs_maxvcount;
670 extern afs_int32 afs_vcount;
671 extern int afsvnumbers;
672 extern afs_rwlock_t afs_xvcache;
673 extern afs_lock_t afs_xvcb;
674 extern struct vcache *freeVCList;
675 extern struct vcache *Initial_freeVCList;
676 extern struct afs_q VLRU;
677 extern afs_int32 vcachegen;
678 extern unsigned int afs_paniconwarn;
679 extern struct vcache *afs_vhashT[VCSIZE];
680 extern afs_int32 afs_bulkStatsLost;
681 extern int afs_norefpanic;
682
683 void afs_vcacheInit(int astatSize);
684 extern struct vcache *afs_FindVCache(struct VenusFid *afid, afs_int32 *retry, afs_int32 flag);
685 extern afs_int32 afs_FetchStatus(struct vcache *avc, struct VenusFid *afid,
686                              struct vrequest *areq,
687                              struct AFSFetchStatus *Outsp);
688
689 extern afs_int32 afs_FlushVCBs(afs_int32 lockit);
690 extern void afs_InactiveVCache(struct vcache *avc, struct AFS_UCRED *acred);
691 extern struct vcache *afs_LookupVCache(struct VenusFid *afid, struct vrequest *areq,
692                                        afs_int32 *cached, struct vcache *adp, char *aname);
693 extern int afs_FlushVCache(struct vcache *avc, int *slept);
694 extern struct vcache *afs_GetRootVCache(struct VenusFid *afid,
695                                         struct vrequest *areq, afs_int32 *cached,
696                                         struct volume *tvolp);
697 extern struct vcache *afs_NewVCache(struct VenusFid *afid,
698                                     struct server *serverp);
699 extern int afs_VerifyVCache2(struct vcache *avc, struct vrequest *areq);
700 extern struct vcache *afs_GetVCache(register struct VenusFid *afid, struct vrequest *areq, 
701         afs_int32 *cached, struct vcache *avc);
702 extern void afs_PutVCache(register struct vcache *avc);
703 extern void afs_ProcessFS(register struct vcache *avc, register struct AFSFetchStatus *astat, 
704         struct vrequest *areq);
705 extern struct afs_cbr *afs_AllocCBR(void);
706 extern int afs_FreeCBR(register struct afs_cbr *asp);
707 extern int afs_RemoveVCB(register struct VenusFid *afid);
708 extern void afs_FlushActiveVcaches(register afs_int32 doflocks);
709 extern int afs_WriteVCache(register struct vcache *avc, 
710         register struct AFSStoreStatus *astatus, struct vrequest *areq);
711 extern int afs_RemoteLookup(register struct VenusFid *afid, struct vrequest *areq,
712         char *name, struct VenusFid *nfid, struct AFSFetchStatus *OutStatusp,
713         struct AFSCallBack *CallBackp, struct server **serverp, struct AFSVolSync *tsyncp);
714 extern afs_int32 afs_NFSFindVCache(struct vcache **avcp, struct VenusFid *afid);
715 extern void afs_vcacheInit(int astatSize);
716 extern void shutdown_vcache(void);
717
718
719 /* VNOPS/afs_vnop_access.c */
720 extern afs_int32 afs_GetAccessBits(register struct vcache *avc, register afs_int32 arights, 
721         register struct vrequest *areq);
722 extern int afs_AccessOK(struct vcache *avc, afs_int32 arights, struct vrequest *areq, 
723         afs_int32 check_mode_bits);
724 #if defined(AFS_SUN5_ENV) || (defined(AFS_SGI_ENV) && !defined(AFS_SGI65_ENV))
725 extern int afs_access(OSI_VC_DECL(avc), register afs_int32 amode, int flags, struct AFS_UCRED *acred);
726 #else
727 extern int afs_access(OSI_VC_DECL(avc), register afs_int32 amode, struct AFS_UCRED *acred);
728 #endif
729 extern int afs_getRights(OSI_VC_DECL(avc), register afs_int32 arights, struct AFS_UCRED *acred);
730
731 /* VNOPS/afs_vnop_attrs.c */
732 extern int afs_CopyOutAttrs(register struct vcache *avc, register struct vattr *attrs);
733 #if     defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
734 extern int afs_getattr(OSI_VC_DECL(avc), struct vattr *attrs, int flags, struct AFS_UCRED *acred);
735 #else
736 extern int afs_getattr(OSI_VC_DECL(avc), struct vattr *attrs, struct AFS_UCRED *acred);
737 #endif
738 extern int afs_VAttrToAS(register struct vcache *avc, register struct vattr *av, 
739         register struct AFSStoreStatus *as);
740 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
741 extern int afs_setattr(OSI_VC_DECL(avc), register struct vattr *attrs, int flags, struct AFS_UCRED *acred);
742 #else
743 extern int afs_setattr(OSI_VC_DECL(avc), register struct vattr *attrs, struct AFS_UCRED *acred);
744 #endif
745
746 /* VNOPS/afs_vnop_create.c */
747 #ifdef  AFS_OSF_ENV
748 extern int afs_create(struct nameidata *ndp, struct vattr *attrs);
749 #else   /* AFS_OSF_ENV */
750 #ifdef AFS_SGI64_ENV
751 extern int afs_create(OSI_VC_DECL(adp), char *aname, struct vattr *attrs, int flags, 
752         int amode, struct vcache **avcp, struct AFS_UCRED *acred);
753 #else /* AFS_SGI64_ENV */
754 extern int afs_create(OSI_VC_DECL(adp), char *aname, struct vattr *attrs, enum vcexcl aexcl,
755         int amode, struct vcache **avcp, struct AFS_UCRED *acred);
756 #endif /* AFS_SGI64_ENV */
757 #endif /* AFS_OSF_ENV */
758 extern int afs_LocalHero(register struct vcache *avc, register struct dcache *adc, 
759         register AFSFetchStatus *astat, register int aincr);
760
761
762 /* VNOPS/afs_vnop_flock.c */
763 extern void lockIdSet(struct AFS_FLOCK *flock, struct SimpleLocks *slp, int clid);
764 extern int HandleFlock(register struct vcache *avc, int acom,
765         struct vrequest *areq, pid_t clid, int onlymine);
766
767
768
769 /* VNOPS/afs_vnop_lookup.c */
770 extern char *afs_strcat(register char *s1, register char *s2);
771 extern char *afs_index(register char *a, register char c);
772 extern int EvalMountPoint(register struct vcache *avc, struct vcache *advc,
773         struct volume **avolpp, register struct vrequest *areq);
774 extern void afs_InitFakeStat(struct afs_fakestat_state *state);
775 extern int afs_EvalFakeStat(struct vcache **avcp, struct afs_fakestat_state *state, 
776         struct vrequest *areq);
777 extern int afs_TryEvalFakeStat(struct vcache **avcp, struct afs_fakestat_state *state, 
778         struct vrequest *areq);
779 extern void afs_PutFakeStat(struct afs_fakestat_state *state);
780 extern int afs_ENameOK(register char *aname);
781 extern int afs_getsysname(register struct vrequest *areq, register struct vcache *adp, 
782         register char *bufp);
783 extern int Check_AtSys(register struct vcache *avc, const char *aname, 
784         struct sysname_info *state, struct vrequest *areq);
785 extern int Next_AtSys(register struct vcache *avc, struct vrequest *areq, 
786         struct sysname_info *state);
787 extern int afs_DoBulkStat(struct vcache *adp, long dirCookie, struct vrequest *areqp);
788
789
790
791 /* VNOPS/afs_vnop_read.c */
792 extern afs_int32 maxIHint;
793 extern afs_int32 nihints;
794 extern afs_int32 usedihint;
795 extern int afs_MemRead(register struct vcache *avc, struct uio *auio, struct AFS_UCRED *acred, 
796         daddr_t albn, struct buf **abpp, int noLock);
797
798
799 /* VNOPS/afs_vnop_readdir.c */
800 extern int afs_rd_stash_i;
801
802 /* VNOPS/afs_vnop_remove.c */
803 extern int afsremove(register struct vcache *adp, register struct dcache *tdc, 
804         register struct vcache *tvc, char *aname, struct AFS_UCRED *acred, 
805         struct vrequest *treqp);
806 extern int afs_remunlink(register struct vcache *avc, register int doit);
807
808
809 /* VNOPS/afs_vnop_symlink.c */
810 extern int afs_MemHandleLink(register struct vcache *avc, struct vrequest *areq);
811
812 /* VNOPS/afs_vnop_flock.c */
813 extern afs_int32 lastWarnTime;
814
815 /* VNOPS/afs_vnop_write.c */
816 extern int afs_MemWrite(register struct vcache *avc, struct uio *auio, int aio, 
817         struct AFS_UCRED *acred, int noLock);
818 extern int afs_StoreOnLastReference(register struct vcache *avc, register struct vrequest *treq);
819 extern int afs_UFSWrite(register struct vcache *avc, struct uio *auio,
820         int aio, struct AFS_UCRED *acred, int noLock);
821 extern int afs_DoPartialWrite(register struct vcache *avc, struct vrequest *areq);
822 extern int afs_closex(register struct file *afd);
823
824
825 /* afs_volume.c */
826 extern afs_int32 afs_FVIndex;
827 extern afs_int32 afs_volCounter;
828 extern afs_rwlock_t afs_xvolume;
829 extern struct volume *afs_volumes[NVOLS];
830 extern ino_t volumeInode;
831 extern struct volume *afs_FindVolume(struct VenusFid *afid, afs_int32 locktype);
832 extern struct volume *afs_freeVolList;
833 extern afs_int32 fvTable[NFENTRIES];
834 extern void InstallVolumeEntry(struct volume *av, struct vldbentry *ve,
835                                int acell);
836 extern void InstallNVolumeEntry(struct volume *av, struct nvldbentry *ve,
837                          int acell);
838 extern void InstallUVolumeEntry(struct volume *av, struct uvldbentry *ve,
839                          int acell, struct cell *tcell, struct vrequest *areq);
840 extern void afs_ResetVolumeInfo(struct volume *tv);
841 extern struct volume *afs_MemGetVolSlot(void);
842 extern void afs_ResetVolumes(struct server *srvp);
843 extern struct volume *afs_GetVolume(struct VenusFid *afid, struct vrequest *areq, 
844         afs_int32 locktype);
845 extern struct volume *afs_GetVolumeByName(register char *aname, afs_int32 acell, 
846         int agood, struct vrequest *areq, afs_int32 locktype);
847
848 extern struct volume *afs_UFSGetVolSlot(void);
849 extern void afs_CheckVolumeNames(int flags);
850
851
852 /* Prototypes for generated files that aren't really in src/afs/ */
853
854 /* afs_uuid.c */
855 extern afs_int32 afs_uuid_equal(afsUUID *u1, afsUUID *u2);
856 extern afs_int32 afs_uuid_is_nil(afsUUID *u1);
857 extern void afs_htonuuid(afsUUID *uuidp);
858 extern void afs_ntohuuid(afsUUID *uuidp);
859 extern afs_int32 afs_uuid_create (afsUUID *uuid);
860 extern u_short afs_uuid_hash (afsUUID *uuid);
861
862
863 /* MISC PROTOTYPES - THESE SHOULD NOT BE HERE */
864 /* MOVE THEM TO APPROPRIATE LOCATIONS */
865 extern afs_int32 RXAFSCB_ExecuteRequest(struct rx_call *acall);
866 extern afs_int32 RXSTATS_ExecuteRequest(struct rx_call *acall);
867
868
869
870 #if defined(AFS_SUN5_ENV) || defined(AFS_LINUX20_ENV) || defined(AFS_AIX_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_FBSD_ENV)
871 #include "../afs/osi_prototypes.h"
872 #endif
873
874 #endif /* _AFS_PROTOTYPES_H_ */