extern int Afs_xsetgroups();
extern int afs_xioctl();
-#if !defined(AFS_FBSD90_ENV) && !defined(AFS_FBSD82_ENV)
-static sy_call_t *old_handler;
-#else
-static struct sysent old_sysent;
-
-static struct sysent afs_sysent = {
- 5, /* int sy_narg */
- (sy_call_t *) afs3_syscall, /* sy_call_t *sy_call */
- AUE_NULL, /* au_event_t sy_auevent */
- NULL, /* systrace_args_funt_t sy_systrace_args_func */
- 0, /* u_int32_t sy_entry */
- 0, /* u_int32_t sy_return */
-# ifdef AFS_FBSD90_ENV
- 0, /* u_int32_t sy_flags */
- 0 /* u_int32_t sy_thrcnt */
-# endif
+static struct syscall_helper_data afs_syscalls[] = {
+ {
+ .syscall_no = AFS_SYSCALL,
+ .new_sysent = {
+ .sy_narg = 5,
+ .sy_call = (sy_call_t *)afs3_syscall,
+ .sy_auevent = AUE_NULL,
+ },
+ },
+ SYSCALL_INIT_LAST
};
-#endif /* FBSD90 */
-int
+static int
afs_init(struct vfsconf *vfc)
{
int code;
- int offset = AFS_SYSCALL;
-#if defined(AFS_FBSD90_ENV) || defined(AFS_FBSD82_ENV)
-# if defined(FBSD_SYSCALL_REGISTER_FOUR_ARGS)
- code = syscall_register(&offset, &afs_sysent, &old_sysent, 0);
-# else
- code = syscall_register(&offset, &afs_sysent, &old_sysent);
-# endif
+#if defined(FBSD_SYSCALL_REGISTER_TAKES_FLAGS)
+ code = syscall_helper_register(afs_syscalls, 0);
+#else
+ code = syscall_helper_register(afs_syscalls);
+#endif
if (code) {
printf("AFS_SYSCALL in use, error %i. aborting\n", code);
return code;
}
-#else
- if (sysent[AFS_SYSCALL].sy_call != (sy_call_t *)nosys
- && sysent[AFS_SYSCALL].sy_call != (sy_call_t *)lkmnosys) {
- printf("AFS_SYSCALL in use. aborting\n");
- return EBUSY;
- }
-#endif
osi_Init();
afs_pbuf_freecnt = nswbuf / 2 + 1;
-#if !defined(AFS_FBSD90_ENV) && !defined(AFS_FBSD82_ENV)
- old_handler = sysent[AFS_SYSCALL].sy_call;
- sysent[AFS_SYSCALL].sy_call = afs3_syscall;
- sysent[AFS_SYSCALL].sy_narg = 5;
-#endif
return 0;
}
-int
+static int
afs_uninit(struct vfsconf *vfc)
{
-#if defined(AFS_FBSD90_ENV) || defined(AFS_FBSD82_ENV)
- int offset = AFS_SYSCALL;
-#endif
-
if (afs_globalVFS)
return EBUSY;
-#if defined(AFS_FBSD90_ENV) || defined(AFS_FBSD82_ENV)
- syscall_deregister(&offset, &old_sysent);
-#else
- sysent[AFS_SYSCALL].sy_narg = 0;
- sysent[AFS_SYSCALL].sy_call = old_handler;
-#endif
+
+ return syscall_helper_unregister(afs_syscalls);
+}
+
+static int
+afs_statfs(struct mount *mp, struct statfs *abp)
+{
+ AFS_GLOCK();
+ AFS_STATCNT(afs_statfs);
+
+ abp->f_bsize = mp->vfs_bsize;
+ abp->f_iosize = mp->vfs_bsize;
+
+ abp->f_blocks = abp->f_bfree = abp->f_bavail = abp->f_files =
+ abp->f_ffree = AFS_VFS_FAKEFREE;
+
+ abp->f_fsid.val[0] = mp->mnt_stat.f_fsid.val[0];
+ abp->f_fsid.val[1] = mp->mnt_stat.f_fsid.val[1];
+ if (abp != &mp->mnt_stat) {
+ abp->f_type = mp->mnt_vfc->vfc_typenum;
+ memcpy((caddr_t) & abp->f_mntonname[0],
+ (caddr_t) mp->mnt_stat.f_mntonname, MNAMELEN);
+ memcpy((caddr_t) & abp->f_mntfromname[0],
+ (caddr_t) mp->mnt_stat.f_mntfromname, MNAMELEN);
+ }
+
+ AFS_GUNLOCK();
return 0;
}
-int
+static int
afs_omount(struct mount *mp, char *path, caddr_t data)
{
/* ndp contains the mounted-from device. Just ignore it.
return 0;
}
-int
+static int
afs_mount(struct mount *mp)
{
return afs_omount(mp, NULL, NULL);
}
static int
-#if (__FreeBSD_version >= 900503 && __FreeBSD_version < 1000000) || __FreeBSD_version >= 1000004
+#if __FreeBSD_version >= 1000004
afs_cmount(struct mntarg *ma, void *data, uint64_t flags)
#else
afs_cmount(struct mntarg *ma, void *data, int flags)
return kernel_mount(ma, flags);
}
-int
+static int
afs_unmount(struct mount *mp, int flags)
{
int error = 0;
AFS_GLOCK();
AFS_STATCNT(afs_unmount);
afs_globalVFS = 0;
- afs_shutdown();
+ afs_shutdown(AFS_WARM);
AFS_GUNLOCK();
out:
return error;
}
-int
+static int
afs_root(struct mount *mp, int flags, struct vnode **vpp)
{
int error;
return error;
}
-int
-afs_statfs(struct mount *mp, struct statfs *abp)
-{
- AFS_GLOCK();
- AFS_STATCNT(afs_statfs);
-
- abp->f_bsize = mp->vfs_bsize;
- abp->f_iosize = mp->vfs_bsize;
-
- abp->f_blocks = abp->f_bfree = abp->f_bavail = abp->f_files =
- abp->f_ffree = AFS_VFS_FAKEFREE;
-
- abp->f_fsid.val[0] = mp->mnt_stat.f_fsid.val[0];
- abp->f_fsid.val[1] = mp->mnt_stat.f_fsid.val[1];
- if (abp != &mp->mnt_stat) {
- abp->f_type = mp->mnt_vfc->vfc_typenum;
- memcpy((caddr_t) & abp->f_mntonname[0],
- (caddr_t) mp->mnt_stat.f_mntonname, MNAMELEN);
- memcpy((caddr_t) & abp->f_mntfromname[0],
- (caddr_t) mp->mnt_stat.f_mntfromname, MNAMELEN);
- }
-
- AFS_GUNLOCK();
- return 0;
-}
-
-int
+static int
afs_sync(struct mount *mp, int waitfor)
{
return 0;