play catchup with the rest of the world, i.e. shuffle stuff a bit
This commit is contained in:
parent
80ce20607e
commit
d666e1c0f4
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: dtfs.c,v 1.3 2006/10/26 22:53:25 pooka Exp $ */
|
/* $NetBSD: dtfs.c,v 1.4 2006/11/09 13:11:52 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
||||||
@ -68,6 +68,7 @@ main(int argc, char *argv[])
|
|||||||
memset(&pvfs, 0, sizeof(struct puffs_vfsops));
|
memset(&pvfs, 0, sizeof(struct puffs_vfsops));
|
||||||
memset(&pvn, 0, sizeof(struct puffs_vnops));
|
memset(&pvn, 0, sizeof(struct puffs_vnops));
|
||||||
|
|
||||||
|
pvfs.puffs_mount = dtfs_mount;
|
||||||
pvfs.puffs_start = dtfs_start;
|
pvfs.puffs_start = dtfs_start;
|
||||||
pvfs.puffs_unmount = dtfs_unmount;
|
pvfs.puffs_unmount = dtfs_unmount;
|
||||||
pvfs.puffs_sync = dtfs_sync;
|
pvfs.puffs_sync = dtfs_sync;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: dtfs.h,v 1.4 2006/10/27 14:03:52 pooka Exp $ */
|
/* $NetBSD: dtfs.h,v 1.5 2006/11/09 13:11:52 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
||||||
@ -40,7 +40,6 @@ PUFFSVN_PROTOS(dtfs);
|
|||||||
|
|
||||||
struct dtfs_mount {
|
struct dtfs_mount {
|
||||||
ino_t dtm_nextfileid; /* running number for file id */
|
ino_t dtm_nextfileid; /* running number for file id */
|
||||||
fsid_t dtm_fsidx; /* fsidx from puffs_start() */
|
|
||||||
|
|
||||||
size_t dtm_fsizes; /* sum of file sizes in bytes */
|
size_t dtm_fsizes; /* sum of file sizes in bytes */
|
||||||
fsfilcnt_t dtm_nfiles; /* number of files */
|
fsfilcnt_t dtm_nfiles; /* number of files */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: dtfs_subr.c,v 1.5 2006/10/27 14:03:52 pooka Exp $ */
|
/* $NetBSD: dtfs_subr.c,v 1.6 2006/11/09 13:11:52 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
||||||
@ -98,11 +98,11 @@ dtfs_genfile(struct puffs_node *dir, const char *name, enum vtype type)
|
|||||||
} else
|
} else
|
||||||
dff = dtfs_newfile();
|
dff = dtfs_newfile();
|
||||||
|
|
||||||
|
dtm = dir->pn_mnt->pu_privdata;
|
||||||
newpn = puffs_newpnode(dir->pn_mnt, dff, type);
|
newpn = puffs_newpnode(dir->pn_mnt, dff, type);
|
||||||
if (newpn == NULL)
|
if (newpn == NULL)
|
||||||
errx(1, "getnewpnode");
|
errx(1, "getnewpnode");
|
||||||
dtm = dir->pn_mnt->pu_privdata;
|
dtfs_baseattrs(&newpn->pn_va, type, dir->pn_mnt->pu_fsidx.__fsid_val[0],
|
||||||
dtfs_baseattrs(&newpn->pn_va, type, dtm->dtm_fsidx.__fsid_val[0],
|
|
||||||
dtm->dtm_nextfileid++);
|
dtm->dtm_nextfileid++);
|
||||||
|
|
||||||
df_dir = dir->pn_data;
|
df_dir = dir->pn_data;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: dtfs_vfsops.c,v 1.2 2006/11/08 11:25:29 pooka Exp $ */
|
/* $NetBSD: dtfs_vfsops.c,v 1.3 2006/11/09 13:11:52 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
* Copyright (c) 2006 Antti Kantee. All Rights Reserved.
|
||||||
@ -40,7 +40,7 @@
|
|||||||
#include "dtfs.h"
|
#include "dtfs.h"
|
||||||
|
|
||||||
int
|
int
|
||||||
dtfs_start(struct puffs_usermount *pu, struct puffs_vfsreq_start *arg)
|
dtfs_mount(struct puffs_usermount *pu, void **rootcookie)
|
||||||
{
|
{
|
||||||
struct dtfs_mount *dtm;
|
struct dtfs_mount *dtm;
|
||||||
struct dtfs_file *dff;
|
struct dtfs_file *dff;
|
||||||
@ -49,7 +49,6 @@ dtfs_start(struct puffs_usermount *pu, struct puffs_vfsreq_start *arg)
|
|||||||
/* create mount-local thingie */
|
/* create mount-local thingie */
|
||||||
dtm = emalloc(sizeof(struct dtfs_mount));
|
dtm = emalloc(sizeof(struct dtfs_mount));
|
||||||
dtm->dtm_nextfileid = 2;
|
dtm->dtm_nextfileid = 2;
|
||||||
dtm->dtm_fsidx = arg->psr_fsidx;
|
|
||||||
dtm->dtm_nfiles = 1;
|
dtm->dtm_nfiles = 1;
|
||||||
dtm->dtm_fsizes = 0;
|
dtm->dtm_fsizes = 0;
|
||||||
pu->pu_privdata = dtm;
|
pu->pu_privdata = dtm;
|
||||||
@ -63,15 +62,25 @@ dtfs_start(struct puffs_usermount *pu, struct puffs_vfsreq_start *arg)
|
|||||||
pn = puffs_newpnode(pu, dff, VDIR);
|
pn = puffs_newpnode(pu, dff, VDIR);
|
||||||
if (!pn)
|
if (!pn)
|
||||||
errx(1, "puffs_newpnode");
|
errx(1, "puffs_newpnode");
|
||||||
|
|
||||||
dtfs_baseattrs(&pn->pn_va, VDIR, dtm->dtm_fsidx.__fsid_val[0],
|
|
||||||
dtm->dtm_nextfileid);
|
|
||||||
dtm->dtm_nextfileid++;
|
|
||||||
/* not adddented, so compensate */
|
/* not adddented, so compensate */
|
||||||
pn->pn_va.va_nlink = 2;
|
pn->pn_va.va_nlink = 2;
|
||||||
|
|
||||||
pu->pu_rootnode = pn;
|
pu->pu_rootnode = pn;
|
||||||
arg->psr_cookie = pn;
|
*rootcookie = pn;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
dtfs_start(struct puffs_usermount *pu)
|
||||||
|
{
|
||||||
|
struct dtfs_mount *dtm;
|
||||||
|
|
||||||
|
/* we don't have the fsidx in mount, so do attrs here */
|
||||||
|
dtm = pu->pu_privdata;
|
||||||
|
dtfs_baseattrs(&pu->pu_rootnode->pn_va, VDIR,pu->pu_fsidx.__fsid_val[0],
|
||||||
|
dtm->dtm_nextfileid);
|
||||||
|
dtm->dtm_nextfileid++;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -80,6 +89,7 @@ int
|
|||||||
dtfs_unmount(struct puffs_usermount *pu, int flags, pid_t pid)
|
dtfs_unmount(struct puffs_usermount *pu, int flags, pid_t pid)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/* goodbye blue sky */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,7 +150,7 @@ dtfs_statvfs(struct puffs_usermount *pu, struct statvfs *sbp, pid_t pid)
|
|||||||
|
|
||||||
sbp->f_bresvd = sbp->f_fresvd = 0;
|
sbp->f_bresvd = sbp->f_fresvd = 0;
|
||||||
|
|
||||||
sbp->f_fsidx = dtm->dtm_fsidx;
|
sbp->f_fsidx = pu->pu_fsidx;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user