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 #ifndef _AFS_PROTOTYPES_H_
11 #define _AFS_PROTOTYPES_H_
14 extern int afs_Analyze(register struct afs_conn *aconn, afs_int32 acode,
15 struct VenusFid *afid, register struct vrequest *areq,
16 int op, afs_int32 locktype, struct cell *cellp);
19 extern afs_rwlock_t afs_xaxs;
20 extern struct axscache *afs_SlowFindAxs(struct axscache **cachep,
22 extern struct axscache *axs_Alloc(void);
23 extern void afs_RemoveAxs(struct axscache **headp, struct axscache *axsp);
24 extern void afs_FreeAllAxs(struct axscache **headp);
27 extern void DInit(int abuffers);
28 extern void *DRead(register struct dcache * fid, register int page);
29 extern int DVOffset(register void *ap);
30 extern void DZap(struct dcache * fid);
31 extern void DFlush(void);
32 extern void DFlushDCache(struct dcache *);
33 extern void *DNew(register struct dcache * fid, register int page);
34 extern void shutdown_bufferpackage(void);
37 extern int afs_cold_shutdown;
38 extern afs_int32 afs_setTime;
39 extern char afs_rootVolumeName[64];
40 extern void afs_shutdown(void);
41 extern void afs_FlushCBs(void);
42 extern int afs_CheckInit(void);
43 extern void afs_shutdown(void);
44 extern void shutdown_afstest(void);
45 extern void afs_shutdown_BKG(void);
46 extern int afs_syscall_call(long parm, long parm2, long parm3,
47 long parm4, long parm5, long parm6);
48 #if defined(AFS_DARWIN100_ENV)
49 extern int afs_syscall64_call(user_addr_t parm, user_addr_t parm2,
50 user_addr_t parm3, user_addr_t parm4,
51 user_addr_t parm5, user_addr_t parm6);
56 extern afs_int32 afs_allCBs;
57 extern afs_int32 afs_oddCBs;
58 extern afs_int32 afs_evenCBs;
59 extern afs_int32 afs_allZaps;
60 extern afs_int32 afs_oddZaps;
61 extern afs_int32 afs_evenZaps;
62 extern afs_int32 afs_connectBacks;
63 extern unsigned long lastCallBack_vnode;
64 extern unsigned int lastCallBack_dv;
65 extern osi_timeval_t lastCallBack_time;
66 extern struct interfaceAddr afs_cb_interface;
68 extern int afs_RXCallBackServer(void);
69 extern int SRXAFSCB_GetCE(struct rx_call *a_call, afs_int32 a_index,
70 struct AFSDBCacheEntry *a_result);
71 extern int SRXAFSCB_GetCE64(struct rx_call *a_call, afs_int32 a_index,
72 struct AFSDBCacheEntry64 *a_result);
73 extern int SRXAFSCB_GetLock(struct rx_call *a_call, afs_int32 a_index,
74 struct AFSDBLock *a_result);
75 extern int SRXAFSCB_CallBack(struct rx_call *a_call,
76 register struct AFSCBFids *a_fids,
77 struct AFSCBs *a_callbacks);
78 extern int SRXAFSCB_Probe(struct rx_call *a_call);
79 extern int SRXAFSCB_InitCallBackState(struct rx_call *a_call);
80 extern int SRXAFSCB_XStatsVersion(struct rx_call *a_call,
81 afs_int32 * a_versionP);
82 extern int SRXAFSCB_GetXStats(struct rx_call *a_call,
83 afs_int32 a_clientVersionNum,
84 afs_int32 a_collectionNumber,
85 afs_int32 * a_srvVersionNumP,
86 afs_int32 * a_timeP, AFSCB_CollData * a_dataP);
87 extern int afs_RXCallBackServer(void);
88 extern int shutdown_CB(void);
89 extern int SRXAFSCB_InitCallBackState2(struct rx_call *a_call,
90 struct interfaceAddr *addr);
91 extern int SRXAFSCB_WhoAreYou(struct rx_call *a_call,
92 struct interfaceAddr *addr);
93 extern int SRXAFSCB_InitCallBackState3(struct rx_call *a_call,
95 extern int SRXAFSCB_ProbeUuid(struct rx_call *a_call, afsUUID * a_uuid);
96 extern int SRXAFSCB_GetServerPrefs(struct rx_call *a_call, afs_int32 a_index,
97 afs_int32 * a_srvr_addr,
98 afs_int32 * a_srvr_rank);
99 extern int SRXAFSCB_GetCellServDB(struct rx_call *a_call, afs_int32 a_index,
100 char **a_name, serverList * a_hosts);
101 extern int SRXAFSCB_GetLocalCell(struct rx_call *a_call, char **a_name);
102 extern int SRXAFSCB_GetCacheConfig(struct rx_call *a_call,
103 afs_uint32 callerVersion,
104 afs_uint32 * serverVersion,
105 afs_uint32 * configCount,
106 cacheConfig * config);
107 extern int SRXAFSCB_FetchData(struct rx_call *rxcall, struct AFSFid *Fid,
108 afs_int32 Fd, afs_int64 Position,
109 afs_int64 Length, afs_int64 * TotalLength);
110 extern int SRXAFSCB_StoreData(struct rx_call *rxcall, struct AFSFid *Fid,
111 afs_int32 Fd, afs_int64 Position,
112 afs_int64 Length, afs_int64 * TotalLength);
116 extern afs_rwlock_t afs_xcbhash;
117 extern void afs_QueueCallback(struct vcache *avc, unsigned int atime,
119 extern void afs_CheckCallbacks(unsigned int secs);
120 extern void afs_FlushCBs(void);
121 extern void afs_FlushServerCBs(struct server *srvp);
122 extern int afs_BumpBase(void);
123 extern void afs_InitCBQueue(int doLockInit);
124 extern void afs_DequeueCallback(struct vcache *avc);
127 extern afs_int32 afs_cellindex;
128 extern afs_rwlock_t afs_xcell;
130 extern afs_rwlock_t afsdb_client_lock;
131 extern afs_rwlock_t afsdb_req_lock;
133 extern struct afs_q CellLRU;
135 extern void afs_CellInit(void);
136 extern void shutdown_cell(void);
137 extern int afs_cellname_init(afs_dcache_id_t *inode, int lookupcode);
138 extern int afs_cellname_write(void);
139 extern afs_int32 afs_NewCell(char *acellName, afs_int32 * acellHosts,
140 int aflags, char *linkedcname, u_short fsport,
141 u_short vlport, int timeout);
142 extern afs_int32 afs_SetPrimaryCell(char *acellName);
143 extern struct cell *afs_GetCell(afs_int32 acell, afs_int32 locktype);
144 extern struct cell *afs_GetCellStale(afs_int32 acell, afs_int32 locktype);
145 extern struct cell *afs_GetCellByHandle(void *handle, afs_int32 locktype);
146 extern struct cell *afs_GetCellByIndex(afs_int32 cellidx, afs_int32 locktype);
147 extern struct cell *afs_GetCellByName(char *acellName, afs_int32 locktype);
148 extern struct cell *afs_GetPrimaryCell(afs_int32 locktype);
149 extern int afs_IsPrimaryCellNum(afs_int32 cellnum);
150 extern int afs_IsPrimaryCell(struct cell *cell);
151 extern void *afs_TraverseCells(void *(*cb) (struct cell *, void *),
153 extern int afs_CellOrAliasExists(char *aname);
154 extern int afs_CellNumValid(afs_int32 cellnum);
155 extern afs_int32 afs_NewCellAlias(char *alias, char *cell);
156 extern struct cell_alias *afs_GetCellAlias(int index);
157 extern void afs_PutCellAlias(struct cell_alias *a);
158 extern int afs_AFSDBHandler(char *acellName, int acellNameLen,
159 afs_int32 * kernelMsg);
160 extern void afs_LookupAFSDB(char *acellName);
161 extern void afs_StopAFSDB(void);
162 extern void afs_RemoveCellEntry(struct server *srvp);
165 extern afs_int32 afs_FirstCSize;
166 extern afs_int32 afs_OtherCSize;
167 extern afs_int32 afs_LogChunk;
170 extern struct cell *afs_GetRealCellByIndex(register afs_int32 cellindex,
175 extern afs_int32 cryptall;
176 extern afs_rwlock_t afs_xinterface;
177 extern afs_rwlock_t afs_xconn;
178 extern struct afs_conn *afs_Conn(register struct VenusFid *afid,
179 register struct vrequest *areq,
181 extern struct afs_conn *afs_ConnBySA(struct srvAddr *sap, unsigned short aport,
182 afs_int32 acell, struct unixuser *tu,
183 int force_if_down, afs_int32 create,
185 extern struct afs_conn *afs_ConnByMHosts(struct server *ahosts[],
186 unsigned short aport, afs_int32 acell,
187 register struct vrequest *areq,
189 extern struct afs_conn *afs_ConnByHost(struct server *aserver,
190 unsigned short aport, afs_int32 acell,
191 struct vrequest *areq, int aforce,
193 extern void afs_PutConn(register struct afs_conn *ac, afs_int32 locktype);
194 extern void ForceNewConnections(struct srvAddr *sap);
198 extern afs_lock_t afs_xbrs;
199 extern short afs_brsWaiters;
200 extern short afs_brsDaemons;
201 extern struct brequest afs_brs[NBRS];
202 extern struct afs_osi_WaitHandle AFS_WaitHandler, AFS_CSWaitHandler;
203 extern afs_int32 afs_gcpags;
204 extern afs_int32 afs_gcpags_procsize;
205 extern afs_int32 afs_CheckServerDaemonStarted;
206 extern afs_int32 afs_probe_interval;
207 extern afs_int32 afs_preCache;
209 extern void afs_Daemon(void);
210 extern struct brequest *afs_BQueue(register short aopcode,
211 register struct vcache *avc,
212 afs_int32 dontwait, afs_int32 ause,
214 afs_size_t asparm0, afs_size_t asparm1,
216 extern void afs_SetCheckServerNATmode(int isnat);
217 extern void afs_CheckServerDaemon(void);
218 extern int afs_CheckRootVolume(void);
219 extern void afs_BRelease(register struct brequest *ab);
220 extern int afs_BBusy(void);
221 extern int afs_BioDaemon(afs_int32 nbiods);
222 extern void afs_BackgroundDaemon(void);
223 extern void shutdown_daemons(void);
224 extern int afs_sgidaemon(void);
228 extern u_int afs_min_cache;
229 extern afs_int32 *afs_dvhashTbl;
230 extern afs_int32 afs_dhashsize;
231 extern afs_rwlock_t afs_xdcache;
232 extern afs_size_t afs_vmMappingEnd;
233 extern afs_int32 afs_blocksUsed;
234 extern afs_int32 afs_blocksDiscarded;
235 extern int afs_WaitForCacheDrain;
236 extern int cacheDiskType;
237 extern afs_uint32 afs_tpct1, afs_tpct2, splitdcache;
238 extern unsigned char *afs_indexFlags;
239 extern struct afs_cacheOps *afs_cacheType;
240 extern afs_dcache_id_t cacheInode;
241 extern struct osi_file *afs_cacheInodep;
242 extern void afs_dcacheInit(int afiles, int ablocks, int aDentries, int achunk,
244 extern int afs_PutDCache(register struct dcache *adc);
245 extern void afs_FlushDCache(register struct dcache *adc);
246 extern void shutdown_dcache(void);
247 extern void afs_CacheTruncateDaemon(void);
248 extern afs_int32 afs_fsfragsize;
249 extern struct dcache *afs_MemGetDSlot(register afs_int32 aslot,
250 register struct dcache *tmpdc);
251 extern struct dcache *afs_GetDCache(register struct vcache *avc,
253 register struct vrequest *areq,
254 afs_size_t * aoffset, afs_size_t * alen,
256 extern struct dcache *afs_FindDCache(register struct vcache *avc,
258 extern void afs_StoreWarn(register afs_int32 acode, afs_int32 avolume,
259 register afs_int32 aflags);
260 extern void afs_MaybeWakeupTruncateDaemon(void);
261 extern void afs_CacheTruncateDaemon(void);
262 extern void afs_AdjustSize(register struct dcache *adc,
263 register afs_int32 newSize);
264 extern int afs_HashOutDCache(struct dcache *adc, int zap);
265 extern int afs_MaybeFreeDiscardedDCache(void);
266 extern int afs_RefDCache(struct dcache *adc);
267 extern void afs_TryToSmush(register struct vcache *avc,
268 afs_ucred_t *acred, int sync);
269 extern void updateV2DC(int lockVc, struct vcache *v, struct dcache *d,
271 extern void afs_WriteThroughDSlots(void);
272 extern struct dcache *afs_UFSGetDSlot(register afs_int32 aslot,
273 register struct dcache *tmpdc);
274 extern int afs_WriteDCache(register struct dcache *adc, int atime);
275 extern int afs_wakeup(register struct vcache *avc);
276 extern int afs_InitCacheFile(char *afile, ino_t ainode);
277 extern int afs_DCacheMissingChunks(struct vcache *avc);
278 extern struct dcache *afs_ObtainDCacheForWriting(struct vcache *avc,
281 struct vrequest *areq,
283 extern void afs_PopulateDCache(struct vcache *avc, afs_size_t apos,
284 struct vrequest *areq);
286 /* afs_disconnected.c */
289 extern int afs_IsDynrootFid(struct VenusFid *fid);
290 extern int afs_IsDynrootMountFid(struct VenusFid *fid);
291 extern int afs_IsDynrootAnyFid(struct VenusFid *fid);
292 extern void afs_GetDynrootFid(struct VenusFid *fid);
293 extern void afs_GetDynrootMountFid(struct VenusFid *fid);
294 extern int afs_IsDynroot(struct vcache *avc);
295 extern int afs_IsDynrootMount(struct vcache *avc);
296 extern int afs_IsDynrootAny(struct vcache *avc);
297 extern void afs_DynrootInvalidate(void);
298 extern void afs_GetDynroot(char **dynrootDir, int *dynrootLen,
299 struct AFSFetchStatus *status);
300 extern void afs_GetDynrootMount(char **dynrootDir, int *dynrootLen,
301 struct AFSFetchStatus *status);
302 extern void afs_PutDynroot(void);
303 extern int afs_DynrootNewVnode(struct vcache *avc,
304 struct AFSFetchStatus *status);
305 extern int afs_InitDynroot(void);
306 extern int afs_SetDynrootEnable(int enable);
307 extern int afs_GetDynrootEnable(void);
308 extern int afs_DynrootVOPRemove(struct vcache *avc, afs_ucred_t *acred,
310 extern int afs_DynrootVOPSymlink(struct vcache *avc, afs_ucred_t *acred,
311 char *aname, char *atargetName);
314 extern void init_et_to_sys_error(void);
315 extern afs_int32 et_to_sys_error(afs_int32 in);
316 extern void afs_FinalizeReq(struct vrequest *areq);
317 extern int afs_CheckCode(afs_int32 acode, struct vrequest *areq, int where);
318 extern void afs_CopyError(register struct vrequest *afrom,
319 register struct vrequest *ato);
320 extern void init_sys_error_to_et(void);
323 extern struct afs_exporter *root_exported;
324 extern struct afs_exporter *exporter_find(int type);
325 extern void shutdown_exporter(void);
327 /* afs_fetchstore.c */
328 extern int afs_UFSCacheFetchProc(struct rx_call *, struct osi_file *,
329 afs_size_t, struct dcache *,
330 struct vcache *, afs_size_t *,
331 afs_size_t *, afs_int32);
333 extern int afs_UFSCacheStoreProc(struct rx_call *, struct osi_file *,
334 afs_int32, struct vcache *,
339 extern struct afs_icl_set *afs_icl_allSets;
340 extern int afs_icl_InitLogs(void);
341 extern int shutdown_icl(void);
342 extern int afs_icl_CreateLog(char *name, afs_int32 logSize,
343 struct afs_icl_log **outLogpp);
344 extern int afs_icl_CreateLogWithFlags(char *name, afs_int32 logSize,
346 struct afs_icl_log **outLogpp);
347 extern int afs_icl_CopyOut(register struct afs_icl_log *logp,
348 afs_int32 * bufferp, afs_int32 * bufSizep,
349 afs_uint32 * cookiep, afs_int32 * flagsp);
350 extern int afs_icl_GetLogParms(struct afs_icl_log *logp, afs_int32 * maxSizep,
351 afs_int32 * curSizep);
352 extern int afs_icl_LogHold(register struct afs_icl_log *logp);
353 extern int afs_icl_LogHoldNL(register struct afs_icl_log *logp);
354 extern int afs_icl_LogUse(register struct afs_icl_log *logp);
355 extern int afs_icl_LogFreeUse(register struct afs_icl_log *logp);
356 extern int afs_icl_LogSetSize(register struct afs_icl_log *logp,
358 extern int afs_icl_ZapLog(register struct afs_icl_log *logp);
359 extern int afs_icl_LogRele(register struct afs_icl_log *logp);
360 extern int afs_icl_LogReleNL(register struct afs_icl_log *logp);
361 extern int afs_icl_ZeroLog(register struct afs_icl_log *logp);
362 extern int afs_icl_LogFree(register struct afs_icl_log *logp);
363 extern struct afs_icl_log *afs_icl_FindLog(char *name);
365 afs_icl_EnumerateLogs(int (*aproc)
367 (char *name, char *arock, struct afs_icl_log * tp),
369 extern int afs_icl_CreateSet(char *name, struct afs_icl_log *baseLogp,
370 struct afs_icl_log *fatalLogp,
371 struct afs_icl_set **outSetpp);
372 extern int afs_icl_CreateSetWithFlags(char *name,
373 struct afs_icl_log *baseLogp,
374 struct afs_icl_log *fatalLogp,
376 struct afs_icl_set **outSetpp);
377 extern int afs_icl_SetEnable(struct afs_icl_set *setp, afs_int32 eventID,
379 extern int afs_icl_GetEnable(struct afs_icl_set *setp, afs_int32 eventID,
381 extern int afs_icl_ZeroSet(struct afs_icl_set *setp);
383 afs_icl_EnumerateSets(int (*aproc)
385 (char *name, char *arock, struct afs_icl_log * tp),
387 extern int afs_icl_AddLogToSet(struct afs_icl_set *setp,
388 struct afs_icl_log *newlogp);
389 extern int afs_icl_SetSetStat(struct afs_icl_set *setp, int op);
390 extern int afs_icl_SetHold(register struct afs_icl_set *setp);
391 extern int afs_icl_ZapSet(register struct afs_icl_set *setp);
392 extern int afs_icl_SetRele(register struct afs_icl_set *setp);
393 extern int afs_icl_SetFree(register struct afs_icl_set *setp);
394 extern struct afs_icl_set *afs_icl_FindSet(char *name);
396 extern int afs_icl_Event4(register struct afs_icl_set *setp,
397 afs_int32 eventID, afs_int32 lAndT, long p1,
398 long p2, long p3, long p4);
399 extern int afs_icl_Event3(register struct afs_icl_set *setp,
400 afs_int32 eventID, afs_int32 lAndT, long p1,
402 extern int afs_icl_Event2(register struct afs_icl_set *setp,
403 afs_int32 eventID, afs_int32 lAndT, long p1,
405 extern int afs_icl_Event1(register struct afs_icl_set *setp,
406 afs_int32 eventID, afs_int32 lAndT, long p1);
407 extern int afs_icl_Event0(register struct afs_icl_set *setp,
408 afs_int32 eventID, afs_int32 lAndT);
409 extern void afs_icl_AppendRecord(register struct afs_icl_log *logp,
410 afs_int32 op, afs_int32 types, long p1,
411 long p2, long p3, long p4);
412 extern int Afscall_icl(long opcode, long p1, long p2, long p3, long p4,
414 #ifdef AFS_DARWIN100_ENV
415 extern int Afscall64_icl(int opcode, user_addr_t p1, user_addr_t p2,
416 user_addr_t p3, user_addr_t p4, int *retval);
420 extern struct cm_initparams cm_initParams;
421 extern int afs_resourceinit_flag;
422 extern afs_rwlock_t afs_puttofileLock;
423 extern char *afs_sysname;
424 extern char *afs_sysnamelist[MAXNUMSYSNAMES];
425 extern int afs_sysnamecount;
426 extern int afs_sysnamegen;
427 extern afs_int32 cacheInfoModTime;
428 extern int afs_CacheInit(afs_int32 astatSize, afs_int32 afiles,
429 afs_int32 ablocks, afs_int32 aDentries,
430 afs_int32 aVolumes, afs_int32 achunk,
431 afs_int32 aflags, afs_int32 ninodes,
432 afs_int32 nusers, afs_int32 dynamic_vcaches);
433 extern void afs_ComputeCacheParms(void);
434 extern int afs_InitCacheInfo(register char *afile);
435 extern int afs_InitVolumeInfo(char *afile);
436 extern int afs_InitCellInfo(char *afile);
437 extern int afs_ResourceInit(int preallocs);
438 extern void shutdown_cache(void);
439 extern void shutdown_vnodeops(void);
440 extern void shutdown_AFS(void);
441 extern int afs_LookupInodeByPath(char *filename, afs_ufs_dcache_id_t *inode,
442 struct vnode **fvpp);
445 extern void Lock_Init(register struct afs_lock *lock);
446 extern void ObtainLock(register struct afs_lock *lock, int how,
447 unsigned int src_indicator);
448 extern void ReleaseLock(register struct afs_lock *lock, int how);
449 extern int Afs_Lock_Trace(int op, struct afs_lock *alock, int type,
450 char *file, int line);
451 extern void Afs_Lock_Obtain(register struct afs_lock *lock, int how);
452 extern void Afs_Lock_ReleaseR(register struct afs_lock *lock);
453 extern void Afs_Lock_ReleaseW(register struct afs_lock *lock);
454 extern void afs_osi_SleepR(register char *addr,
455 register struct afs_lock *alock);
456 extern void afs_osi_SleepW(register char *addr,
457 register struct afs_lock *alock);
458 extern void afs_osi_SleepS(register char *addr,
459 register struct afs_lock *alock);
460 #ifndef AFS_NOBOZO_LOCK
461 extern void afs_BozonLock(struct afs_bozoLock *alock, struct vcache *avc);
462 extern void afs_BozonUnlock(struct afs_bozoLock *alock, struct vcache *avc);
463 extern void afs_BozonInit(struct afs_bozoLock *alock, struct vcache *avc);
464 extern int afs_CheckBozonLock(struct afs_bozoLock *alock);
465 extern int afs_CheckBozonLockBlocking(struct afs_bozoLock *alock);
472 extern afs_int32 afs_mariner;
473 extern afs_int32 afs_marinerHost;
474 extern struct rx_service *afs_server;
475 extern int afs_AddMarinerName(register char *aname,
476 register struct vcache *avc);
477 extern char *afs_GetMariner(register struct vcache *avc);
478 extern void afs_MarinerLogFetch(register struct vcache *avc,
479 register afs_int32 off,
480 register afs_int32 bytes,
481 register afs_int32 idx);
482 extern void afs_MarinerLog(register char *astring,
483 register struct vcache *avc);
484 extern void shutdown_mariner(void);
486 /* afs_fetchstore.c */
487 extern int afs_CacheStoreVCache(struct dcache **dcList, struct vcache *avc,
488 struct vrequest *areq,
489 int sync, unsigned int minj,
490 unsigned int high, unsigned int moredata,
492 afs_size_t *amaxStoredLength);
493 extern int afs_CacheFetchProc(struct afs_conn *tc, struct osi_file *fP,
494 afs_size_t abase, struct dcache *adc,
495 struct vcache *avc, afs_int32 size,
496 struct afs_FetchOutput *tsmall);
499 extern int afs_InitMemCache(int blkCount, int blkSize, int flags);
500 extern int afs_MemCacheClose(struct osi_file *file);
501 extern void *afs_MemCacheOpen(afs_dcache_id_t *ainode);
502 extern int afs_MemReadBlk(register struct osi_file *fP, int offset,
503 void *dest, int size);
504 extern int afs_MemReadvBlk(register struct memCacheEntry *mceP, int offset,
505 struct iovec *iov, int nio, int size);
506 extern int afs_MemReadUIO(afs_dcache_id_t *ainode, struct uio *uioP);
507 extern int afs_MemWriteBlk(register struct osi_file *fP, int offset,
508 void *src, int size);
509 extern int afs_MemWritevBlk(register struct memCacheEntry *mceP, int offset,
510 struct iovec *iov, int nio, int size);
511 extern int afs_MemWriteUIO(afs_dcache_id_t *ainode, struct uio *uioP);
512 extern int afs_MemCacheTruncate(register struct osi_file *fP,
514 extern void shutdown_memcache(void);
518 extern struct afs_exporter *afs_nfsexported;
519 extern struct afs_exporter *afs_nfsexporter;
520 extern void afs_nfsclient_init(void);
521 extern int afs_nfsclient_reqhandler(struct afs_exporter *exporter,
523 afs_int32 host, afs_int32 *pagparam,
524 struct afs_exporter **outexporter);
525 extern void shutdown_nfsclnt(void);
528 extern afs_lock_t afs_ftf;
529 extern void afs_osi_Invisible(void);
530 extern void afs_osi_Visible(void);
531 extern void afs_osi_RxkRegister(void);
532 extern void afs_osi_MaskSignals(void);
533 extern void afs_osi_UnmaskRxkSignals(void);
534 extern void afs_osi_MaskUserLoop(void);
535 extern void osi_Init(void);
536 extern void afs_osi_MaskSignals(void);
537 extern void afs_osi_UnmaskRxkSignals(void);
538 extern void afs_osi_RxkRegister(void);
539 extern void afs_osi_Invisible(void);
540 extern void shutdown_osi(void);
541 extern void shutdown_osinet(void);
542 extern int afs_osi_suser(void *credp);
543 extern void afs_osi_TraverseProcTable(void);
544 #if defined(KERNEL) && !defined(UKERNEL)
545 extern const afs_ucred_t *afs_osi_proc2cred(afs_proc_t * pr);
548 /* afs_osi_alloc.c */
550 extern afs_lock_t osi_fsplock;
551 extern afs_lock_t osi_flplock;
553 extern void *afs_osi_Alloc_debug(size_t x, char *func, int line);
554 #ifndef afs_osi_Alloc_NoSleep
555 extern void *afs_osi_Alloc_NoSleep(size_t x);
558 extern void afs_osi_Free(void *x, size_t asize);
560 #if !defined(AFS_OBSD44_ENV)
561 extern void afs_osi_FreeStr(char *x);
563 extern void osi_FreeLargeSpace(void *adata);
564 extern void osi_FreeSmallSpace(void *adata);
565 extern void *osi_AllocLargeSpace(size_t size);
566 extern void *osi_AllocSmallSpace(size_t size);
567 extern void shutdown_osinet(void);
570 #if defined(AFS_SUN5_ENV)
571 extern int afs_setpag(afs_ucred_t **credpp);
572 #elif defined(AFS_OSF_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
573 extern int afs_setpag(afs_proc_t *p, void *args, int *retval);
575 extern int afs_setpag(void);
578 extern afs_uint32 genpag(void);
579 extern afs_uint32 getpag(void);
580 #if defined(AFS_OSF_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
581 extern int AddPag(afs_proc_t *p, afs_int32 aval, afs_ucred_t **credpp);
583 extern int AddPag(afs_int32 aval, afs_ucred_t **credpp);
585 extern int afs_InitReq(register struct vrequest *av, afs_ucred_t *acred);
587 extern afs_uint32 afs_get_pag_from_groups(gid_t g0a, gid_t g1a);
589 #ifdef AFS_LINUX26_ONEGROUP_ENV
590 extern afs_uint32 afs_get_pag_from_groups(struct group_info *gi);
593 extern void afs_get_groups_from_pag(afs_uint32 pag, gid_t * g0p, gid_t * g1p);
594 extern afs_int32 PagInCred(afs_ucred_t *cred);
597 extern int afsio_copy(struct uio *ainuio, struct uio *aoutuio,
598 struct iovec *aoutvec);
599 extern int afsio_trim(struct uio *auio, afs_int32 asize);
600 extern int afsio_skip(struct uio *auio, afs_int32 asize);
603 extern int osi_Active(register struct vcache *avc);
604 extern void osi_FlushPages(register struct vcache *avc,
606 extern void osi_FlushText_really(register struct vcache *vp);
607 extern int osi_VMDirty_p(struct vcache *avc);
609 extern void osi_ReleaseVM(struct vcache *avc, afs_ucred_t *acred);
614 /* ARCH/osi_misc.c */
615 extern void afs_osi_SetTime(osi_timeval_t * atv);
617 /* LINUX/osi_misc.c */
618 #ifdef AFS_LINUX20_ENV
619 #ifdef AFS_LINUX24_ENV
620 extern int osi_lookupname(char *aname, uio_seg_t seg, int followlink,
621 struct dentry **dpp);
622 extern int osi_InitCacheInfo(char *aname);
623 extern int osi_rdwr(struct osi_file *osifile, uio_t * uiop, int rw);
624 extern void setup_uio(uio_t * uiop, struct iovec *iovecp, const char *buf,
625 afs_offs_t pos, int count, uio_flag_t flag,
627 extern int uiomove(char *dp, int length, uio_flag_t rw, uio_t * uiop);
628 extern void osi_linux_free_inode_pages(void);
630 extern void osi_linux_mask(void);
631 extern void osi_linux_unmask(void);
632 extern int setpag(cred_t ** cr, afs_uint32 pagvalue, afs_uint32 * newpag,
637 /* ARCH/osi_sleep.c */
638 extern void afs_osi_InitWaitHandle(struct afs_osi_WaitHandle *achandle);
639 extern void afs_osi_CancelWait(struct afs_osi_WaitHandle *achandle);
640 extern int afs_osi_Wait(afs_int32 ams, struct afs_osi_WaitHandle *ahandle,
642 #ifndef afs_osi_Wakeup
643 extern int afs_osi_Wakeup(void *event);
645 #ifndef afs_osi_Sleep
646 extern void afs_osi_Sleep(void *event);
648 #ifndef afs_osi_SleepSig
649 extern int afs_osi_SleepSig(void *event);
653 /* ARCH/osi_inode.c */
655 extern int afs_syscall_icreate(dev_t, long, long, long, long, long,
656 rval_t *, afs_ucred_t *);
657 extern int afs_syscall_iopen(dev_t, int, int, rval_t *, afs_ucred_t *);
658 extern int afs_syscall_iincdec(dev_t, int, int, int, rval_t *,
660 #elif defined(AFS_SGI65_ENV)
661 extern int afs_syscall_icreate(afs_uint32, afs_uint32, afs_uint32, afs_uint32, afs_uint32, afs_uint32, rval_t *);
662 extern int afs_syscall_iopen(int, ino_t, int, rval_t *);
663 extern int afs_syscall_iincdec(int, int, int, int);
664 #elif defined(AFS_OSF_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
665 extern int afs_syscall_icreate(long, long, long, long, long, long, long*);
666 extern int afs_syscall_iopen(int dev, int inode, int usrmod, long *retval);
667 extern int afs_syscall_iincdec(int dev, int inode, int inode_p1, int amount);
669 extern int afs_syscall_icreate(long, long, long, long, long, long);
670 extern int afs_syscall_iopen(int, int, int);
671 extern int afs_syscall_iincdec(int, int, int, int);
674 /* ARCH/osi_file.c */
675 extern int afs_osicred_initialized;
676 extern void *osi_UFSOpen(afs_dcache_id_t *ainode);
677 #if defined(AFS_LINUX22_ENV)
678 extern void osi_get_fh(struct dentry *dp, afs_ufs_dcache_id_t *ainode);
680 extern int afs_osi_Stat(register struct osi_file *afile,
681 register struct osi_stat *astat);
682 extern int osi_UFSClose(register struct osi_file *afile);
683 extern int osi_UFSTruncate(register struct osi_file *afile, afs_int32 asize);
684 extern void osi_DisableAtimes(struct vnode *avp);
685 extern int afs_osi_Read(register struct osi_file *afile, int offset,
686 void *aptr, afs_int32 asize);
687 extern int afs_osi_Write(register struct osi_file *afile, afs_int32 offset,
688 void *aptr, afs_int32 asize);
689 extern int afs_osi_MapStrategy(int (*aproc) (struct buf * bp),
690 register struct buf *bp);
691 extern void shutdown_osifile(void);
694 /* ARCH/osi_groups.c */
696 extern int usr_setpag(afs_ucred_t **cred, afs_uint32 pagvalue,
697 afs_uint32 * newpag, int change_parent);
699 # if defined AFS_XBSD_ENV
700 # if !defined(AFS_DFBSD_ENV)
701 extern int setpag(afs_proc_t *proc, struct ucred **cred, afs_uint32 pagvalue,
702 afs_uint32 * newpag, int change_parent);
709 extern int osi_VM_FlushVCache(struct vcache *avc, int *slept);
710 extern void osi_VM_StoreAllSegments(struct vcache *avc);
711 extern void osi_VM_TryToSmush(struct vcache *avc, afs_ucred_t *acred,
713 extern void osi_VM_FlushPages(struct vcache *avc, afs_ucred_t *credp);
714 extern void osi_VM_Truncate(struct vcache *avc, int alen,
716 extern void osi_VM_TryReclaim(struct vcache *avc, int *slept);
717 extern void osi_VM_NukePages(struct vnode *vp, off_t offset, off_t size);
718 extern int osi_VM_Setup(struct vcache *avc, int force);
721 extern int osi_VM_GetDownD(struct vcache *avc, struct dcache *adc);
722 extern void osi_VM_PreTruncate(struct vcache *avc, int alen,
727 /* ARCH/osi_vnodeops.c */
728 extern struct vnodeops Afs_vnodeops;
729 #if defined(AFS_OSF_ENV)
730 #if defined(AFS_OSF30_ENV)
731 extern int max_vnodes; /* number of total system vnodes */
733 extern int nvnode; /* number of total system vnodes */
734 extern int numvnodes; /* number vnodes in use now */
737 extern struct vfs_ubcops afs_ubcops;
740 extern int afs_inactive(struct vcache *avc, afs_ucred_t *acred);
745 extern afs_uint32 pag_epoch;
746 extern afs_uint32 pagCounter;
748 /* OS/osi_vfsops.c */
749 #if defined(AFS_OSF_ENV) || defined(AFS_XBSD_ENV) || defined(AFS_DARWIN_ENV)
750 extern struct mount *afs_globalVFS;
752 extern struct vfs *afs_globalVFS;
754 extern struct vcache *afs_globalVp;
755 #ifdef AFS_LINUX20_ENV
756 extern void vcache2inode(struct vcache *avc);
757 extern void vcache2fakeinode(struct vcache *rootvp, struct vcache *mpvp);
761 extern int afs_mount(struct vfs *afsp, char *path, void *data);
762 extern int afs_root(OSI_VFS_DECL(afsp), struct vnode **avpp);
763 extern int afs_unmount(struct vfs *afsp);
767 extern afs_int32 afs_nfs_server_addr;
768 extern void afspag_Init(afs_int32 nfs_server_addr);
769 extern void afspag_Shutdown(void);
772 extern afs_rwlock_t afs_xpagcell;
773 extern afs_rwlock_t afs_xpagsys;
774 extern int afspag_PUnlog(char *ain, afs_int32 ainSize,
775 afs_ucred_t **acred);
776 extern int afspag_PSetTokens(char *ain, afs_int32 ainSize,
777 afs_ucred_t **acred);
778 extern int afspag_PSetSysName(char *ain, afs_int32 ainSize,
779 afs_ucred_t **acred);
782 extern struct VenusFid afs_rootFid;
783 extern afs_int32 afs_waitForever;
784 extern short afs_waitForeverCount;
785 extern afs_int32 afs_showflags;
786 extern int afs_defaultAsynchrony;
787 #if defined(AFS_DARWIN100_ENV)
788 extern int afs_syscall64_pioctl(user_addr_t path, unsigned int com,
789 user_addr_t cmarg, int follow, \
793 extern int afs_syscall_pioctl(char *path, unsigned int com, caddr_t cmarg,
794 int follow, rval_t *rvp, afs_ucred_t *credp);
795 #elif defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
796 extern int afs_syscall_pioctl(char *path, unsigned int com, caddr_t cmarg,
797 int follow, afs_ucred_t *credp);
799 extern int afs_syscall_pioctl(char *path, unsigned int com, caddr_t cmarg,
802 extern int HandleIoctl(register struct vcache *avc, register afs_int32 acom,
803 struct afs_ioctl *adata);
807 extern int afs_StoreMini(register struct vcache *avc, struct vrequest *areq);
808 extern int afs_StoreAllSegments(register struct vcache *avc,
809 struct vrequest *areq, int sync);
810 extern int afs_InvalidateAllSegments(struct vcache *avc);
811 extern int afs_ExtendSegments(struct vcache *avc,
812 afs_size_t alen, struct vrequest *areq);
813 extern int afs_TruncateAllSegments(register struct vcache *avc,
814 afs_size_t alen, struct vrequest *areq,
818 extern afs_rwlock_t afs_xsrvAddr;
819 extern afs_rwlock_t afs_xserver;
820 extern afs_rwlock_t afs_icl_lock;
821 extern struct srvAddr *afs_srvAddrs[NSERVERS];
822 extern struct server *afs_servers[NSERVERS];
823 extern int afs_totalServers;
824 extern struct server *afs_setTimeHost;
825 extern struct server *afs_FindServer(afs_int32 aserver, afs_uint16 aport,
826 afsUUID * uuidp, afs_int32 locktype);
827 extern struct server *afs_GetServer(afs_uint32 * aserver, afs_int32 nservers,
828 afs_int32 acell, u_short aport,
829 afs_int32 locktype, afsUUID * uuidp,
830 afs_int32 addr_uniquifier);
831 extern void ForceAllNewConnections(void);
832 extern void afs_MarkServerUpOrDown(struct srvAddr *sa, int a_isDown);
833 extern afs_int32 afs_ServerDown(struct srvAddr *sa);
834 extern void afs_CountServers(void);
835 extern void afs_CheckServers(int adown, struct cell *acellp);
836 extern unsigned int afs_random(void);
837 extern int afs_randomMod15(void);
838 extern int afs_randomMod127(void);
839 extern void afs_SortOneServer(struct server *asp);
840 extern void afs_SortServers(struct server *aservers[], int count);
841 extern void afs_FlushServer(struct server *srvp);
842 extern void afs_RemoveSrvAddr(struct srvAddr *sap);
843 extern void afs_ActivateServer(struct srvAddr *sap);
844 #ifdef AFS_USERSPACE_IP_ADDR
845 extern void afsi_SetServerIPRank(struct srvAddr *sa, afs_int32 addr,
846 afs_uint32 subnetmask);
848 #if (!defined(AFS_SUN5_ENV)) && defined(USEIFADDR)
849 void afsi_SetServerIPRank(struct srvAddr *sa, struct in_ifaddr *ifa);
852 extern int afs_HaveCallBacksFrom(struct server *aserver);
853 extern void shutdown_server(void);
854 extern void afs_RemoveAllConns(void);
855 extern void afs_MarkAllServersUp(void);
858 extern int osi_dnlc_enter(struct vcache *adp, char *aname, struct vcache *avc,
860 extern struct vcache *osi_dnlc_lookup(struct vcache *adp, char *aname,
862 extern int osi_dnlc_remove(struct vcache *adp, char *aname,
864 extern int osi_dnlc_purgedp(struct vcache *adp);
865 extern int osi_dnlc_purgevp(struct vcache *avc);
866 extern int osi_dnlc_purge(void);
867 extern int osi_dnlc_purgevol(struct VenusFid *fidp);
868 extern int osi_dnlc_init(void);
869 extern int osi_dnlc_shutdown(void);
872 extern void afspag_SetPrimaryCell(char *acell);
875 extern struct afs_CMStats afs_cmstats;
876 extern struct afs_stats_CMPerf afs_stats_cmperf;
877 extern struct afs_stats_CMFullPerf afs_stats_cmfullperf;
878 extern afs_int32 afs_stats_XferSumBytes[AFS_STATS_NUM_FS_XFER_OPS];
879 extern void afs_InitStats(void);
880 extern void afs_GetCMStat(char **ptr, unsigned *size);
882 extern void afs_AddToMean(struct afs_MeanStats *oldMean, afs_int32 newValue);
886 #ifdef AFS_DARWIN100_ENV
887 extern int copyin_afs_ioctl(user_addr_t cmarg, struct afs_ioctl *dst);
889 extern int copyin_afs_ioctl(caddr_t cmarg, struct afs_ioctl *dst);
892 extern int Afs_syscall(void);
895 /* UKERNEL/afs_usrops.c */
897 extern void uafs_Shutdown(void);
898 extern void osi_ReleaseVM(struct vcache *avc, int len,
900 extern int osi_GetTime(struct timeval *tv);
901 extern int iodone(struct usr_buf *bp);
902 extern int usr_ioctl(void);
903 extern int lookupname(char *fnamep, int segflg, int followlink,
904 struct usr_vnode **compvpp);
905 extern int usr_uiomove(char *kbuf, int n, int rw, struct usr_uio *uio);
906 extern int afs_osi_VOP_RDWR(struct usr_vnode *vnodeP, struct usr_uio *uioP,
907 int rw, int flags, afs_ucred_t *credP);
912 extern afs_rwlock_t afs_xuser;
913 extern struct unixuser *afs_users[NUSERS];
914 extern struct unixuser *afs_FindUser(afs_int32 auid, afs_int32 acell,
916 extern struct unixuser *afs_GetUser(register afs_int32 auid, afs_int32 acell,
919 extern afs_int32 afs_GCPAGs(afs_int32 * ReleasedCount);
920 extern void afs_GCPAGs_perproc_func(afs_proc_t * pproc);
921 #endif /* AFS_GCPAGS */
922 extern void afs_ComputePAGStats(void);
923 extern void afs_PutUser(register struct unixuser *au, afs_int32 locktype);
924 extern void afs_GCUserData(int aforce);
925 extern void afs_CheckTokenCache(void);
926 extern void afs_ResetAccessCache(afs_int32 uid, int alock);
927 extern void afs_ResetUserConns(register struct unixuser *auser);
928 extern void afs_SetPrimary(register struct unixuser *au, register int aflag);
932 extern afs_int32 afs_calc_inum (afs_int32 volume, afs_int32 vnode);
933 #ifndef afs_cv2string
934 extern char *afs_cv2string(char *ttp, afs_uint32 aval);
936 #ifndef afs_strcasecmp
937 extern int afs_strcasecmp(char *s1, char *s2);
940 extern char *afs_strcat(char *s1, char *s2);
942 #ifdef AFS_OBSD34_ENV
943 extern char *afs_strcpy(char *s1, char *s2);
946 extern char *afs_strchr(char *s, int c);
949 extern char *afs_strrchr(char *s, int c);
951 extern char *afs_strdup(char *s);
952 extern void print_internet_address(char *preamble, struct srvAddr *sa,
953 char *postamble, int flag);
954 extern afs_int32 afs_data_pointer_to_int32(const void *p);
956 extern void afs_CheckLocks(void);
957 extern int afs_badop(void);
958 extern int afs_noop(void);
959 extern afs_int32 afs_data_pointer_to_int32(const void *p);
964 /* AIX doesn't have usable va_args support in its kernel */
965 extern void afs_warn();
966 extern void afs_warnuser();
968 extern void afs_warn(char *fmt, ...);
969 extern void afs_warnuser(char *fmt, ...);
973 extern int afs_ShakeLooseVCaches(afs_int32 anumber);
974 extern afs_int32 afs_maxvcount;
975 extern afs_int32 afs_vcount;
976 extern int afsvnumbers;
977 extern afs_rwlock_t afs_xvreclaim;
978 extern afs_rwlock_t afs_xvcache;
979 extern afs_rwlock_t afs_xvcdirty;
980 extern afs_lock_t afs_xvcb;
981 extern struct afs_q VLRU;
982 extern afs_int32 vcachegen;
983 extern unsigned int afs_paniconwarn;
984 extern struct afs_q afs_vhashTV[VCSIZE];
985 extern afs_int32 afs_bulkStatsLost;
986 extern int afs_norefpanic;
987 extern struct vcache *ReclaimedVCList;
988 extern ino_t vcacheMetaInode;
989 extern struct osi_file *afs_vcacheMetaInodep;
991 extern void afs_FlushReclaimedVcaches(void);
992 void afs_vcacheInit(int astatSize);
993 extern struct vcache *afs_FindVCache(struct VenusFid *afid, afs_int32 * retry,
995 extern afs_int32 afs_FetchStatus(struct vcache *avc, struct VenusFid *afid,
996 struct vrequest *areq,
997 struct AFSFetchStatus *Outsp);
999 extern afs_int32 afs_FlushVCBs(afs_int32 lockit);
1000 extern void afs_InactiveVCache(struct vcache *avc, afs_ucred_t *acred);
1001 extern struct vcache *afs_LookupVCache(struct VenusFid *afid,
1002 struct vrequest *areq,
1003 afs_int32 * cached, struct vcache *adp,
1005 extern int afs_FlushVCache(struct vcache *avc, int *slept);
1006 extern struct vcache *afs_GetRootVCache(struct VenusFid *afid,
1007 struct vrequest *areq,
1009 struct volume *tvolp);
1010 extern struct vcache *afs_NewVCache(struct VenusFid *afid,
1011 struct server *serverp);
1012 extern int afs_VerifyVCache2(struct vcache *avc, struct vrequest *areq);
1013 extern struct vcache *afs_GetVCache(register struct VenusFid *afid,
1014 struct vrequest *areq, afs_int32 * cached,
1015 struct vcache *avc);
1016 extern void afs_PutVCache(register struct vcache *avc);
1017 extern void afs_ProcessFS(register struct vcache *avc,
1018 register struct AFSFetchStatus *astat,
1019 struct vrequest *areq);
1020 extern struct afs_cbr *afs_AllocCBR(void);
1021 extern int afs_FreeCBR(register struct afs_cbr *asp);
1022 extern void afs_RemoveVCB(register struct VenusFid *afid);
1023 extern void afs_FlushActiveVcaches(register afs_int32 doflocks);
1024 extern int afs_WriteVCache(register struct vcache *avc,
1025 register struct AFSStoreStatus *astatus,
1026 struct vrequest *areq);
1027 extern int afs_RemoteLookup(register struct VenusFid *afid,
1028 struct vrequest *areq, char *name,
1029 struct VenusFid *nfid,
1030 struct AFSFetchStatus *OutStatusp,
1031 struct AFSCallBack *CallBackp,
1032 struct server **serverp,
1033 struct AFSVolSync *tsyncp);
1034 extern void afs_ResetVCache(struct vcache *, afs_ucred_t *);
1035 extern afs_int32 afs_NFSFindVCache(struct vcache **avcp,
1036 struct VenusFid *afid);
1037 extern void afs_vcacheInit(int astatSize);
1038 extern void shutdown_vcache(void);
1039 extern void afs_DisconGiveUpCallbacks(void);
1040 extern void afs_ClearAllStatdFlag(void);
1042 /* VNOPS/afs_vnop_access.c */
1043 extern afs_int32 afs_GetAccessBits(register struct vcache *avc,
1044 register afs_int32 arights,
1045 register struct vrequest *areq);
1046 extern int afs_AccessOK(struct vcache *avc, afs_int32 arights,
1047 struct vrequest *areq, afs_int32 check_mode_bits);
1048 #if defined(AFS_SUN5_ENV) || (defined(AFS_SGI_ENV) && !defined(AFS_SGI65_ENV))
1049 extern int afs_access(OSI_VC_DECL(avc), register afs_int32 amode, int flags,
1050 afs_ucred_t *acred);
1052 extern int afs_access(OSI_VC_DECL(avc), register afs_int32 amode,
1053 afs_ucred_t *acred);
1055 extern int afs_getRights(OSI_VC_DECL(avc), register afs_int32 arights,
1056 afs_ucred_t *acred);
1058 /* VNOPS/afs_vnop_attrs.c */
1059 extern int afs_CopyOutAttrs(register struct vcache *avc,
1060 register struct vattr *attrs);
1061 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1062 extern int afs_getattr(OSI_VC_DECL(avc), struct vattr *attrs, int flags,
1063 afs_ucred_t *acred);
1065 extern int afs_getattr(OSI_VC_DECL(avc), struct vattr *attrs,
1066 afs_ucred_t *acred);
1068 extern int afs_VAttrToAS(register struct vcache *avc,
1069 register struct vattr *av,
1070 register struct AFSStoreStatus *as);
1071 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1072 extern int afs_setattr(OSI_VC_DECL(avc), register struct vattr *attrs,
1073 int flags, afs_ucred_t *acred);
1075 extern int afs_setattr(OSI_VC_DECL(avc), register struct vattr *attrs,
1076 afs_ucred_t *acred);
1079 /* VNOPS/afs_vnop_create.c */
1081 extern int afs_create(struct nameidata *ndp, struct vattr *attrs);
1082 #else /* AFS_OSF_ENV */
1083 #ifdef AFS_SGI64_ENV
1084 extern int afs_create(OSI_VC_DECL(adp), char *aname, struct vattr *attrs,
1085 int flags, int amode, struct vcache **avcp,
1086 afs_ucred_t *acred);
1087 #else /* AFS_SGI64_ENV */
1088 extern int afs_create(OSI_VC_DECL(adp), char *aname, struct vattr *attrs,
1089 enum vcexcl aexcl, int amode, struct vcache **avcp,
1090 afs_ucred_t *acred);
1091 #endif /* AFS_SGI64_ENV */
1092 #endif /* AFS_OSF_ENV */
1093 extern int afs_LocalHero(register struct vcache *avc,
1094 register struct dcache *adc,
1095 register AFSFetchStatus * astat, register int aincr);
1097 /* VNOPS/afs_vnop_dirops.c */
1099 extern int afs_mkdir(OSI_VC_DECL(adp), char *aname, struct vattr *attrs,
1100 register struct vcache **avcp, afs_ucred_t *acred);
1101 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1102 extern int afs_rmdir(OSI_VC_DECL(adp), char *aname, struct vnode *cdirp,
1103 afs_ucred_t *acred);
1105 extern int afs_rmdir(OSI_VC_DECL(adp), char *aname, afs_ucred_t *acred);
1109 /* VNOPS/afs_vnop_fid.c */
1110 #if !defined(AFS_ATHENA_ENV)
1111 #ifdef AFS_AIX41_ENV
1112 int afs_fid(OSI_VC_DECL(avc), struct fid *fidpp, struct ucred *credp);
1113 #elif defined(AFS_OSF_ENV) || defined(AFS_SUN54_ENV)
1114 int afs_fid(OSI_VC_DECL(avc), struct fid *fidpp);
1116 int afs_fid(OSI_VC_DECL(avc), struct fid **fidpp);
1117 #endif /* AFS_AIX41_ENV */
1120 /* VNOPS/afs_vnop_flock.c */
1121 extern afs_int32 lastWarnTime;
1123 extern void lockIdSet(struct AFS_FLOCK *flock, struct SimpleLocks *slp,
1125 extern int HandleFlock(register struct vcache *avc, int acom,
1126 struct vrequest *areq, pid_t clid, int onlymine);
1129 extern int afs_lockctl(struct vcache * avc, struct eflock * af, int flag,
1130 afs_ucred_t * acred, pid_t clid, off_t offset);
1131 #elif defined(AFS_SGI_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
1132 extern int afs_lockctl(struct vcache * avc, struct AFS_FLOCK * af, int acmd,
1133 afs_ucred_t * acred, pid_t clid);
1135 extern int afs_lockctl(struct vcache * avc, struct AFS_FLOCK * af, int acmd,
1136 afs_ucred_t * acred);
1139 /* VNOPS/afs_vnop_link.c */
1140 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1141 extern int afs_link(OSI_VC_DECL(adp), struct vcache *avc, char *aname,
1142 afs_ucred_t *acred);
1144 extern int afs_link(struct vcache *avc, OSI_VC_DECL(adp), char *aname,
1145 afs_ucred_t *acred);
1148 /* VNOPS/afs_vnop_lookup.c */
1149 extern int EvalMountPoint(register struct vcache *avc, struct vcache *advc,
1150 struct volume **avolpp,
1151 register struct vrequest *areq);
1152 extern void afs_InitFakeStat(struct afs_fakestat_state *state);
1153 extern int afs_EvalFakeStat(struct vcache **avcp,
1154 struct afs_fakestat_state *state,
1155 struct vrequest *areq);
1156 extern int afs_TryEvalFakeStat(struct vcache **avcp,
1157 struct afs_fakestat_state *state,
1158 struct vrequest *areq);
1159 extern void afs_PutFakeStat(struct afs_fakestat_state *state);
1160 extern int afs_ENameOK(register char *aname);
1161 extern void Check_AtSys(register struct vcache *avc, const char *aname,
1162 struct sysname_info *state, struct vrequest *areq);
1163 extern int Next_AtSys(register struct vcache *avc, struct vrequest *areq,
1164 struct sysname_info *state);
1165 extern int afs_DoBulkStat(struct vcache *adp, long dirCookie,
1166 struct vrequest *areqp);
1168 extern int afs_lookup(OSI_VC_DECL(adp), char *aname, struct vcache **avcp,
1169 afs_ucred_t *acred, int opflag, int wantparent);
1170 #elif defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1171 extern int afs_lookup(OSI_VC_DECL(adp), char *aname, struct vcache **avcp,
1172 struct pathname *pnp, int flags, struct vnode *rdir,
1173 afs_ucred_t *acred);
1174 #elif defined(UKERNEL)
1175 extern int afs_lookup(OSI_VC_DECL(adp), char *aname, struct vcache **avcp,
1176 afs_ucred_t *acred, int flags);
1178 extern int afs_lookup(OSI_VC_DECL(adp), char *aname, struct vcache **avcp,
1179 afs_ucred_t *acred);
1182 /* VNOPS/afs_vnop_open.c */
1183 #ifdef AFS_SGI64_ENV
1184 extern int afs_open(bhv_desc_t * bhv, struct vcache **avcp, afs_int32 aflags,
1185 afs_ucred_t *acred);
1187 extern int afs_open(struct vcache **avcp, afs_int32 aflags,
1188 afs_ucred_t *acred);
1192 /* VNOPS/afs_vnop_read.c */
1193 extern afs_int32 maxIHint;
1194 extern afs_int32 nihints;
1195 extern afs_int32 usedihint;
1196 extern int afs_MemRead(register struct vcache *avc, struct uio *auio,
1197 afs_ucred_t *acred, daddr_t albn,
1198 struct buf **abpp, int noLock);
1199 extern int afs_UFSRead(register struct vcache *avc, struct uio *auio,
1200 afs_ucred_t *acred, daddr_t albn,
1201 struct buf **abpp, int noLock);
1202 extern void afs_PrefetchChunk(struct vcache *avc, struct dcache *adc,
1203 afs_ucred_t *acred, struct vrequest *areq);
1206 /* VNOPS/afs_vnop_readdir.c */
1207 extern int afs_rd_stash_i;
1208 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV) || defined(AFS_OSF_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
1209 extern int afs_readdir(OSI_VC_DECL(avc), struct uio *auio,
1210 afs_ucred_t *acred, int *eofp);
1211 #elif defined(AFS_HPUX100_ENV)
1212 extern int afs_readdir2(OSI_VC_DECL(avc), struct uio *auio,
1213 afs_ucred_t *acred);
1215 extern int afs_readdir(OSI_VC_DECL(avc), struct uio *auio,
1216 afs_ucred_t *acred);
1219 /* VNOPS/afs_vnop_remove.c */
1220 extern int afsremove(register struct vcache *adp, register struct dcache *tdc,
1221 register struct vcache *tvc, char *aname,
1222 afs_ucred_t *acred, struct vrequest *treqp);
1223 extern int afs_remunlink(register struct vcache *avc, register int doit);
1224 extern int afs_remove(OSI_VC_DECL(adp), char *aname, afs_ucred_t *acred);
1225 extern char *afs_newname(void);
1227 /* VNOPS/afs_vnop_rename.c */
1228 extern int afsrename(struct vcache *aodp, char *aname1, struct vcache *andp,
1229 char *aname2, afs_ucred_t *acred,
1230 struct vrequest *areq);
1232 extern int afs_rename(OSI_VC_DECL(aodp), char *aname1, struct vcache *andp,
1233 char *aname2, struct pathname *npnp,
1234 afs_ucred_t *acred);
1236 extern int afs_rename(OSI_VC_DECL(aodp), char *aname1, struct vcache *andp,
1237 char *aname2, afs_ucred_t *acred);
1240 /* VNOPS/afs_vnop_strategy.c */
1241 #if defined(AFS_SUN5_ENV) || defined(AFS_OSF_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
1242 extern int afs_ustrategy(register struct buf *adp, afs_ucred_t *credp);
1244 extern int afs_ustrategy(register struct buf *adp);
1247 /* VNOPS/afs_vnop_symlink.c */
1248 extern int afs_MemHandleLink(register struct vcache *avc,
1249 struct vrequest *areq);
1250 extern int afs_UFSHandleLink(register struct vcache *avc,
1251 struct vrequest *areq);
1252 extern int afs_symlink(OSI_VC_DECL(adp), char *aname,
1253 struct vattr *attrs, char *atargetName,
1254 afs_ucred_t *acred);
1255 extern int afs_readlink(OSI_VC_DECL(avc), struct uio *auio,
1256 afs_ucred_t *acred);
1258 /* VNOPS/afs_vnop_write.c */
1259 extern int afs_MemWrite(register struct vcache *avc, struct uio *auio,
1260 int aio, afs_ucred_t *acred, int noLock);
1261 extern int afs_StoreOnLastReference(register struct vcache *avc,
1262 register struct vrequest *treq);
1263 extern int afs_UFSWrite(register struct vcache *avc, struct uio *auio,
1264 int aio, afs_ucred_t *acred, int noLock);
1265 extern int afs_DoPartialWrite(register struct vcache *avc,
1266 struct vrequest *areq);
1267 extern int afs_closex(register struct file *afd);
1269 #ifdef AFS_SGI65_ENV
1270 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1271 lastclose_t lastclose, afs_ucred_t *acred);
1272 #elif defined(AFS_SGI64_ENV)
1273 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1274 lastclose_t lastclose, off_t offset,
1275 afs_ucred_t *acred, struct flid *flp);
1276 #elif defined(AFS_SGI_ENV)
1277 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1278 lastclose_t lastclose, off_t offset,
1279 afs_ucred_t *acred);
1280 #elif defined(AFS_SUN5_ENV)
1281 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags, int count,
1282 offset_t offset, afs_ucred_t *acred);
1284 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1285 afs_ucred_t *acred);
1289 extern int afs_fsync(OSI_VC_DECL(avc), int fflags, afs_ucred_t *acred,
1291 #elif defined(AFS_SGI65_ENV)
1292 extern int afs_fsync(OSI_VC_DECL(avc), int flags, afs_ucred_t *acred,
1293 off_t start, off_t stop);
1294 #elif defined(AFS_SGI_ENV) || defined(AFS_SUN53_ENV)
1295 extern int afs_fsync(OSI_VC_DECL(avc), int flag, afs_ucred_t *acred);
1297 extern int afs_fsync(OSI_VC_DECL(avc), afs_ucred_t *acred);
1302 extern afs_int32 afs_FVIndex;
1303 extern afs_int32 afs_volCounter;
1304 extern afs_rwlock_t afs_xvolume;
1305 extern struct volume *afs_volumes[NVOLS];
1306 extern afs_dcache_id_t volumeInode;
1307 extern struct volume *afs_FindVolume(struct VenusFid *afid,
1308 afs_int32 locktype);
1309 extern struct volume *afs_freeVolList;
1310 extern afs_int32 fvTable[NFENTRIES];
1311 extern void InstallVolumeEntry(struct volume *av, struct vldbentry *ve,
1313 extern void InstallNVolumeEntry(struct volume *av, struct nvldbentry *ve,
1315 extern void InstallUVolumeEntry(struct volume *av, struct uvldbentry *ve,
1316 int acell, struct cell *tcell,
1317 struct vrequest *areq);
1318 extern void afs_ResetVolumeInfo(struct volume *tv);
1319 extern struct volume *afs_MemGetVolSlot(void);
1320 extern void afs_ResetVolumes(struct server *srvp);
1321 extern struct volume *afs_GetVolume(struct VenusFid *afid,
1322 struct vrequest *areq,
1323 afs_int32 locktype);
1324 extern struct volume *afs_GetVolumeByName(register char *aname,
1325 afs_int32 acell, int agood,
1326 struct vrequest *areq,
1327 afs_int32 locktype);
1328 extern struct volume *afs_UFSGetVolSlot(void);
1329 extern void afs_CheckVolumeNames(int flags);
1332 /* Prototypes for generated files that aren't really in src/afs/ */
1335 extern afs_int32 afs_uuid_equal(afsUUID * u1, afsUUID * u2);
1336 extern afs_int32 afs_uuid_is_nil(afsUUID * u1);
1337 extern void afs_htonuuid(afsUUID * uuidp);
1338 extern void afs_ntohuuid(afsUUID * uuidp);
1339 extern afs_int32 afs_uuid_create(afsUUID * uuid);
1340 extern u_short afs_uuid_hash(afsUUID * uuid);
1342 #if defined(AFS_SUN5_ENV) || defined(AFS_LINUX20_ENV) || defined(AFS_AIX_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV) || defined(AFS_HPUX_ENV) || defined(AFS_SGI62_ENV) || defined(AFS_OSF_ENV)
1343 #include "osi_prototypes.h"
1346 #endif /* _AFS_PROTOTYPES_H_ */