As a first generation best-effort hack, use NOCACHE to mean "file
size can change without the kernel knowing" and therefore query the file size before invoking read or write operations.
This commit is contained in:
parent
9ef6d9f3e5
commit
dfa114e254
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: puffs_subr.c,v 1.8 2006/11/16 01:33:37 christos Exp $ */
|
/* $NetBSD: puffs_subr.c,v 1.9 2006/11/18 08:18:24 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2006 Antti Kantee. All Rights Reserved.
|
* Copyright (c) 2005, 2006 Antti Kantee. All Rights Reserved.
|
||||||
@ -33,7 +33,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: puffs_subr.c,v 1.8 2006/11/16 01:33:37 christos Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: puffs_subr.c,v 1.9 2006/11/18 08:18:24 pooka Exp $");
|
||||||
|
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include <sys/conf.h>
|
#include <sys/conf.h>
|
||||||
@ -373,3 +373,15 @@ puffs_updatenode(struct vnode *vp, int flags)
|
|||||||
puffs_vntouser_faf(MPTOPUFFSMP(vp->v_mount), PUFFS_VN_SETATTR,
|
puffs_vntouser_faf(MPTOPUFFSMP(vp->v_mount), PUFFS_VN_SETATTR,
|
||||||
setattr_arg, sizeof(struct puffs_vnreq_setattr), VPTOPNC(vp));
|
setattr_arg, sizeof(struct puffs_vnreq_setattr), VPTOPNC(vp));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
puffs_updatevpsize(struct vnode *vp)
|
||||||
|
{
|
||||||
|
struct vattr va;
|
||||||
|
|
||||||
|
if (VOP_GETATTR(vp, &va, FSCRED, NULL))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (va.va_size != VNOVAL)
|
||||||
|
vp->v_size = va.va_size;
|
||||||
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: puffs_sys.h,v 1.8 2006/11/17 17:48:02 pooka Exp $ */
|
/* $NetBSD: puffs_sys.h,v 1.9 2006/11/18 08:18:24 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2006 Antti Kantee. All Rights Reserved.
|
* Copyright (c) 2005, 2006 Antti Kantee. All Rights Reserved.
|
||||||
@ -180,6 +180,7 @@ void puffs_updatenode(struct vnode *, int);
|
|||||||
#define PUFFS_UPDATECTIME 0x02
|
#define PUFFS_UPDATECTIME 0x02
|
||||||
#define PUFFS_UPDATEMTIME 0x04
|
#define PUFFS_UPDATEMTIME 0x04
|
||||||
#define PUFFS_UPDATESIZE 0x08
|
#define PUFFS_UPDATESIZE 0x08
|
||||||
|
void puffs_updatevpsize(struct vnode *);
|
||||||
|
|
||||||
int puffs_setpmp(pid_t, int, struct puffs_mount *);
|
int puffs_setpmp(pid_t, int, struct puffs_mount *);
|
||||||
void puffs_nukebypmp(struct puffs_mount *);
|
void puffs_nukebypmp(struct puffs_mount *);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: puffs_vnops.c,v 1.11 2006/11/17 17:48:02 pooka Exp $ */
|
/* $NetBSD: puffs_vnops.c,v 1.12 2006/11/18 08:18:24 pooka Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2006 Antti Kantee. All Rights Reserved.
|
* Copyright (c) 2005, 2006 Antti Kantee. All Rights Reserved.
|
||||||
@ -33,7 +33,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/cdefs.h>
|
#include <sys/cdefs.h>
|
||||||
__KERNEL_RCSID(0, "$NetBSD: puffs_vnops.c,v 1.11 2006/11/17 17:48:02 pooka Exp $");
|
__KERNEL_RCSID(0, "$NetBSD: puffs_vnops.c,v 1.12 2006/11/18 08:18:24 pooka Exp $");
|
||||||
|
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include <sys/vnode.h>
|
#include <sys/vnode.h>
|
||||||
@ -1143,12 +1143,16 @@ puffs_read(void *v)
|
|||||||
if (uio->uio_offset < 0)
|
if (uio->uio_offset < 0)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
|
if (vp->v_type == VREG) {
|
||||||
|
const int advice = IO_ADV_DECODE(ap->a_ioflag);
|
||||||
|
|
||||||
ubcflags = 0;
|
ubcflags = 0;
|
||||||
if (UBC_WANT_UNMAP(vp) || pmp->pmp_flags & PUFFSFLAG_NOCACHE)
|
if (UBC_WANT_UNMAP(vp) || pmp->pmp_flags & PUFFSFLAG_NOCACHE)
|
||||||
ubcflags = UBC_UNMAP;
|
ubcflags = UBC_UNMAP;
|
||||||
|
|
||||||
if (vp->v_type == VREG) {
|
/* XXX: first generation hack */
|
||||||
const int advice = IO_ADV_DECODE(ap->a_ioflag);
|
if (pmp->pmp_flags & PUFFSFLAG_NOCACHE)
|
||||||
|
puffs_updatevpsize(vp);
|
||||||
|
|
||||||
while (uio->uio_resid > 0) {
|
while (uio->uio_resid > 0) {
|
||||||
bytelen = MIN(uio->uio_resid,
|
bytelen = MIN(uio->uio_resid,
|
||||||
@ -1258,11 +1262,15 @@ puffs_write(void *v)
|
|||||||
write_argp = NULL;
|
write_argp = NULL;
|
||||||
pmp = MPTOPUFFSMP(ap->a_vp->v_mount);
|
pmp = MPTOPUFFSMP(ap->a_vp->v_mount);
|
||||||
|
|
||||||
|
if (vp->v_type == VREG) {
|
||||||
ubcflags = 0;
|
ubcflags = 0;
|
||||||
if (UBC_WANT_UNMAP(vp) || pmp->pmp_flags & PUFFSFLAG_NOCACHE)
|
if (UBC_WANT_UNMAP(vp) || pmp->pmp_flags & PUFFSFLAG_NOCACHE)
|
||||||
ubcflags = UBC_UNMAP;
|
ubcflags = UBC_UNMAP;
|
||||||
|
|
||||||
if (vp->v_type == VREG) {
|
/* XXX: first generation hack */
|
||||||
|
if (pmp->pmp_flags & PUFFSFLAG_NOCACHE)
|
||||||
|
puffs_updatevpsize(vp);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* userspace *should* be allowed to control this,
|
* userspace *should* be allowed to control this,
|
||||||
* but with UBC it's a bit unclear how to handle it
|
* but with UBC it's a bit unclear how to handle it
|
||||||
|
Loading…
Reference in New Issue
Block a user