From nobody Tue Jan 7 19:49:53 2025 X-Original-To: dev-commits-ports-branches@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4YSM8K5yrYz5jrK0; Tue, 07 Jan 2025 19:49:53 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R11" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4YSM8K3mG2z3y4n; Tue, 7 Jan 2025 19:49:53 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1736279393; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=tie6Bfxy8LrtS2U+2l/CWROIo0pOUEr6htiAMwjZPVI=; b=C1janGPWPhx2jKlqlBFkH9dJ+hMIKCLhpGM/w/WLiJNF7Dn0qZ6E2UHl4LpfiH7aHfFjGn z8sE+erIv1PTrWVarh3PtlmKjyjpe46BS/w+RCcNRQ1lY7YWipVKVnVvKH5V3jx/PPEiSP 377KD3/I4wM97EC0caouS1g2NN5BUGI65mjxWAWupEActsnDJFgFbCVtwPVqbzd97IthR+ uuTuKwEdC9Ex5TIvFnJ44n9Gh5inRMwdC+UCERBdpfO0UvfDm0sUnNQBXFv6gLki8Guphf sy/oPN8u8IiNY4J+5j1OrGTcTetykTHB7LzXt8+Fg2iZI4yoo/l5S+zoWvy3yA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1736279393; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=tie6Bfxy8LrtS2U+2l/CWROIo0pOUEr6htiAMwjZPVI=; b=Z/76fCDnuj7m3RUSIG6UDzMutoIUh7gcJM1b9Qyt5uOP2MtM3Tg09diHPuKeihCa8umOqq +1eR6/rziE3M6sOdGjc2nxwNw5XZT5Q8dKNDIWrSugrWhLlC4wmYJd0plarjCf96S/iXQJ VEADQsz1LxWJMbK+I7WbtN9yONKYuVP+UFsS+gIIYaplcYSbS5Gaof+zc4CC9flZrJ2CZ6 mtMgy3wWWWrmlEBEDKtnuax++6UEOggQaqI/Vym9f3HzhMF2zJ1EgxP1N/XQlciFl+hRmU g24H2ZFQrYIBOpBZL29c+rCGFrAxlLec+/aoizvxPsKzuZemSYhtvcaKzj6I8A== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1736279393; a=rsa-sha256; cv=none; b=SMsHwyNZgH+8ZdRnDkg8GMbRVRTgl7SDhMVrM30USGi39nJcPjKnqKJc3IE5V6EAsbMeIY EmcB2pV/caGRw9yGV7SF92dwidQKMOs5V2NJ9quZHSGNgnbqLNyRUGjPXc+G8M28xiveiS HI1D1f3jIOZO34XmK+AHGYv4ZhbdqCoOv5LHlwkCYW2NBRgC6BzKHPDqB/nscF03HNMvqb QP54AigvALTYAMB0xQS3daz//GgMGGNFypjuRiDxKK2xzR1LUQ1UUmcqZI/6aQ4sIStuB9 1QCMeUVTgEWAYEBnDHZK1GkND9riJAg9P7T1KUKU77MkzcP7Rmub7JDqvD0KtA== ARC-Authentication-Results: i=1; mx1.freebsd.org; none Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4YSM8K30Vjz8GW; Tue, 07 Jan 2025 19:49:53 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.18.1/8.18.1) with ESMTP id 507Jnr97000457; Tue, 7 Jan 2025 19:49:53 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.18.1/8.18.1/Submit) id 507JnrHU000454; Tue, 7 Jan 2025 19:49:53 GMT (envelope-from git) Date: Tue, 7 Jan 2025 19:49:53 GMT Message-Id: <202501071949.507JnrHU000454@gitrepo.freebsd.org> To: ports-committers@FreeBSD.org, dev-commits-ports-all@FreeBSD.org, dev-commits-ports-branches@FreeBSD.org From: Vladimir Druzenko Subject: git: aed3690309b6 - 2025Q1 - emulators/virtualbox-ose{,-additions}{,-nox11}-legacy: Fix vboxvfs bugs List-Id: Commits to the quarterly branches of the FreeBSD ports repository List-Archive: https://lists.freebsd.org/archives/dev-commits-ports-branches List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-ports-branches@freebsd.org Sender: owner-dev-commits-ports-branches@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: vvd X-Git-Repository: ports X-Git-Refname: refs/heads/2025Q1 X-Git-Reftype: branch X-Git-Commit: aed3690309b69bd8c7d2fe4e91f447e1d49ba935 Auto-Submitted: auto-generated The branch 2025Q1 has been updated by vvd: URL: https://cgit.FreeBSD.org/ports/commit/?id=aed3690309b69bd8c7d2fe4e91f447e1d49ba935 commit aed3690309b69bd8c7d2fe4e91f447e1d49ba935 Author: takahiro.kurosawa AuthorDate: 2025-01-07 19:37:49 +0000 Commit: Vladimir Druzenko CommitDate: 2025-01-07 19:47:56 +0000 emulators/virtualbox-ose{,-additions}{,-nox11}-legacy: Fix vboxvfs bugs This commit fixes vboxvfs (shared foler) kernel module bugs: * fix open file leaks on creating files that causes file descriptor leaks on host; * fix halfway lookups. PR: 245865 MFH: 2025Q1 (cherry picked from commit abe3df235ee4885d7937f2626f566ea48715e02c) --- emulators/virtualbox-ose-additions-legacy/Makefile | 2 +- .../virtualbox-ose-additions-nox11-legacy/Makefile | 2 +- emulators/virtualbox-ose-legacy/Makefile | 2 +- ...ch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs.h | 9 +- ..._VBox_Additions_freebsd_vboxvfs_vboxvfs__prov.c | 19 +- ...VBox_Additions_freebsd_vboxvfs_vboxvfs__vnops.c | 226 +++++++++++++-------- emulators/virtualbox-ose-nox11-legacy/Makefile | 2 +- 7 files changed, 153 insertions(+), 109 deletions(-) diff --git a/emulators/virtualbox-ose-additions-legacy/Makefile b/emulators/virtualbox-ose-additions-legacy/Makefile index 54e77f8d41b3..44ded329e282 100644 --- a/emulators/virtualbox-ose-additions-legacy/Makefile +++ b/emulators/virtualbox-ose-additions-legacy/Makefile @@ -1,6 +1,6 @@ PORTNAME= virtualbox-ose DISTVERSION= 5.2.44 -PORTREVISION?= 6 +PORTREVISION?= 7 CATEGORIES= emulators MASTER_SITES= https://download.virtualbox.org/virtualbox/${DISTVERSION}/ PKGNAMESUFFIX?= -additions-legacy diff --git a/emulators/virtualbox-ose-additions-nox11-legacy/Makefile b/emulators/virtualbox-ose-additions-nox11-legacy/Makefile index d0641c37f11d..c02115f2eb3b 100644 --- a/emulators/virtualbox-ose-additions-nox11-legacy/Makefile +++ b/emulators/virtualbox-ose-additions-nox11-legacy/Makefile @@ -1,4 +1,4 @@ -PORTREVISION= 5 +PORTREVISION= 7 PKGNAMESUFFIX= -additions-nox11-legacy MASTERDIR= ${.CURDIR}/../virtualbox-ose-additions-legacy diff --git a/emulators/virtualbox-ose-legacy/Makefile b/emulators/virtualbox-ose-legacy/Makefile index 2f18be4feb48..b611471a27c4 100644 --- a/emulators/virtualbox-ose-legacy/Makefile +++ b/emulators/virtualbox-ose-legacy/Makefile @@ -1,6 +1,6 @@ PORTNAME= virtualbox-ose DISTVERSION= 5.2.44 -PORTREVISION?= 24 +PORTREVISION?= 25 CATEGORIES= emulators MASTER_SITES= https://download.virtualbox.org/virtualbox/${DISTVERSION}/:src \ LOCAL/bofh/emulators/virtualbox-ose-legacy:docs diff --git a/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs.h b/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs.h index 1bf14e4782f3..427a20d7783f 100644 --- a/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs.h +++ b/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs.h @@ -9,7 +9,7 @@ /* * Copyright (C) 2010-2017 Oracle Corporation * -@@ -21,72 +16,419 @@ +@@ -21,72 +16,420 @@ #define VBOXVFS_VFSNAME "vboxvfs" #define VBOXVFS_VERSION 1 @@ -282,6 +282,7 @@ + struct vnode *sf_vnode; /* vnode if active */ + sfp_file_t *sf_file; /* non NULL if open */ + struct vboxfs_node *sf_parent; /* parent sfnode of this one */ ++ uint32_t sf_opencnt; /* sf_file reference counter */ + uint16_t sf_children; /* number of children sfnodes */ + uint8_t sf_type; /* VDIR or VREG */ + uint8_t sf_vpstate; /* XXX: ADD COMMENT */ @@ -290,7 +291,7 @@ + uint64_t sf_stat_time; /* last-modified time of sf_stat */ + sffs_dirents_t *sf_dir_list; /* list of entries for this directory */ + -+ /* interlock to protect sf_vpstate */ ++ /* interlock to protect sf_vpstate, sf_file and sf_opencnt */ + struct mtx sf_interlock; +}; + @@ -413,7 +414,7 @@ +extern int sfprov_get_fsinfo(sfp_mount_t *, sffs_fsinfo_t *); + +extern int sfprov_create(sfp_mount_t *, char *path, mode_t mode, -+ sfp_file_t **fp, sffs_stat_t *stat); ++ sffs_stat_t *stat); +extern int sfprov_open(sfp_mount_t *, char *path, sfp_file_t **fp); +extern int sfprov_close(sfp_file_t *fp); +extern int sfprov_read(sfp_file_t *, char * buffer, uint64_t offset, @@ -443,7 +444,7 @@ +extern int sfprov_trunc(sfp_mount_t *, char *); +extern int sfprov_remove(sfp_mount_t *, char *path, u_int is_link); +extern int sfprov_mkdir(sfp_mount_t *, char *path, mode_t mode, -+ sfp_file_t **fp, sffs_stat_t *stat); ++ sffs_stat_t *stat); +extern int sfprov_rmdir(sfp_mount_t *, char *path); +extern int sfprov_rename(sfp_mount_t *, char *from, char *to, u_int is_dir); + diff --git a/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__prov.c b/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__prov.c index 340e72a1578d..e606c4f1de6f 100644 --- a/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__prov.c +++ b/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__prov.c @@ -1,6 +1,6 @@ ---- src/VBox/Additions/freebsd/vboxvfs/vboxvfs_prov.c.orig 2020-06-26 09:59:35 UTC -+++ src/VBox/Additions/freebsd/vboxvfs/vboxvfs_prov.c -@@ -0,0 +1,1021 @@ +--- src/VBox/Additions/freebsd/vboxvfs/vboxvfs_prov.c.orig 2024-08-15 13:18:37.777504000 +0900 ++++ src/VBox/Additions/freebsd/vboxvfs/vboxvfs_prov.c 2024-08-15 13:18:37.777446000 +0900 +@@ -0,0 +1,1012 @@ +/* + * Copyright (C) 2008-2016 Oracle Corporation + * @@ -309,7 +309,6 @@ + sfp_mount_t *mnt, + char *path, + mode_t mode, -+ sfp_file_t **fp, + sffs_stat_t *stat) +{ + int rc; @@ -334,10 +333,7 @@ + return (EEXIST); + return (ENOENT); + } -+ newfp = malloc(sizeof(sfp_file_t), M_VBOXVFS, M_WAITOK | M_ZERO); -+ newfp->handle = parms.Handle; -+ newfp->map = mnt->map; -+ *fp = newfp; ++ (void)VbglR0SfClose(&vbox_client, &mnt->map, parms.Handle); + sfprov_stat_from_info(stat, &parms.Info); + return (0); +} @@ -714,14 +710,12 @@ + sfp_mount_t *mnt, + char *path, + mode_t mode, -+ sfp_file_t **fp, + sffs_stat_t *stat) +{ + int rc; + SHFLCREATEPARMS parms; + SHFLSTRING *str; + int size; -+ sfp_file_t *newfp; + + str = sfprov_string(path, &size); + parms.Handle = SHFL_HANDLE_NIL; @@ -739,10 +733,7 @@ + return (EEXIST); + return (ENOENT); + } -+ newfp = malloc(sizeof(sfp_file_t), M_VBOXVFS, M_WAITOK | M_ZERO); -+ newfp->handle = parms.Handle; -+ newfp->map = mnt->map; -+ *fp = newfp; ++ (void)VbglR0SfClose(&vbox_client, &mnt->map, parms.Handle); + sfprov_stat_from_info(stat, &parms.Info); + return (0); +} diff --git a/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__vnops.c b/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__vnops.c index b37af4edac49..02fc514a9c14 100644 --- a/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__vnops.c +++ b/emulators/virtualbox-ose-legacy/files/patch-src_VBox_Additions_freebsd_vboxvfs_vboxvfs__vnops.c @@ -1,6 +1,6 @@ --- src/VBox/Additions/freebsd/vboxvfs/vboxvfs_vnops.c.orig 2020-07-09 16:50:11 UTC +++ src/VBox/Additions/freebsd/vboxvfs/vboxvfs_vnops.c -@@ -14,228 +14,1364 @@ +@@ -14,228 +14,1416 @@ * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. */ @@ -83,7 +83,8 @@ +static vop_fsync_t vboxfs_fsync; +static vop_remove_t vboxfs_remove; +static vop_link_t vboxfs_link; -+static vop_cachedlookup_t vboxfs_lookup; ++static vop_lookup_t vboxfs_lookup; ++static vop_cachedlookup_t vboxfs_cachedlookup; +static vop_rename_t vboxfs_rename; +static vop_mkdir_t vboxfs_mkdir; +static vop_rmdir_t vboxfs_rmdir; @@ -140,8 +141,8 @@ + .vop_inactive = vboxfs_inactive, + .vop_ioctl = vboxfs_ioctl, + .vop_link = vboxfs_link, -+ .vop_lookup = vfs_cache_lookup, -+ .vop_cachedlookup = vboxfs_lookup, ++ .vop_lookup = vboxfs_lookup, ++ .vop_cachedlookup = vboxfs_cachedlookup, + .vop_mkdir = vboxfs_mkdir, + .vop_mknod = VOP_EOPNOTSUPP, + .vop_open = vboxfs_open, @@ -462,13 +463,15 @@ { - return 0; + char *p; ++ size_t dstsz; + + if (len <= 2 && tail[0] == '.' && (len == 1 || tail[1] == '.')) + panic("construct path for %s", tail); -+ p = malloc(strlen(node->sf_path) + 1 + len + 1, M_VBOXVFS, M_WAITOK); ++ dstsz = strlen(node->sf_path) + 1 + len + 1; ++ p = malloc(dstsz, M_VBOXVFS, M_WAITOK); + strcpy(p, node->sf_path); + strcat(p, "/"); -+ strcat(p, tail); ++ strlcat(p, tail, dstsz); + return (p); } @@ -531,38 +534,85 @@ -static int vboxvfs_symlink(struct vop_symlink_args *ap) +static int -+vboxfs_open(struct vop_open_args *ap) ++vboxfs_get_sfp_file(struct vboxfs_node *np) { - return EOPNOTSUPP; -+ struct vboxfs_node *np; + sfp_file_t *fp; + int error; + ++ fp = NULL; ++ VBOXFS_NODE_LOCK(np); ++ for (;;) { ++ if (np->sf_file != NULL) { ++ if (fp != NULL) ++ (void) sfprov_close(fp); ++ np->sf_opencnt++; ++ fp = np->sf_file; ++ break; ++ } else if (fp != NULL) { ++ np->sf_file = fp; ++ KASSERT(np->sf_opencnt == 0, ++ ("np %p opencnt (%d) must be zero.", ++ np, np->sf_opencnt)); ++ np->sf_opencnt = 1; ++ break; ++ } ++ VBOXFS_NODE_UNLOCK(np); ++ error = sfprov_open(np->vboxfsmp->sf_handle, np->sf_path, &fp); ++ if (error != 0) ++ return (error); ++ VBOXFS_NODE_LOCK(np); ++ } ++ VBOXFS_NODE_UNLOCK(np); ++ ++ return (0); + } + +-static int vboxvfs_mknod(struct vop_mknod_args *ap) ++static void ++vboxfs_put_sfp_file(struct vboxfs_node *np) + { +- return EOPNOTSUPP; ++ VBOXFS_NODE_LOCK(np); ++ np->sf_opencnt--; ++ if (np->sf_opencnt == 0) { ++ (void) sfprov_close(np->sf_file); ++ np->sf_file = NULL; ++ } ++ VBOXFS_NODE_UNLOCK(np); + } + +-static int vboxvfs_mkdir(struct vop_mkdir_args *ap) ++static int ++vboxfs_open(struct vop_open_args *ap) + { +- return 0; ++ struct vboxfs_node *np; ++ int error; ++ + MPASS(VOP_ISLOCKED(vp)); + + np = VP_TO_VBOXFS_NODE(ap->a_vp); -+ error = sfprov_open(np->vboxfsmp->sf_handle, np->sf_path, &fp); ++ error = vboxfs_get_sfp_file(np); + if (error != 0) + goto out; + -+ np->sf_file = fp; + vnode_create_vobject(ap->a_vp, 0, ap->a_td); -+ +out: + MPASS(VOP_ISLOCKED(vp)); + + return (error); } --static int vboxvfs_mknod(struct vop_mknod_args *ap) +-static int vboxvfs_rmdir(struct vop_rmdir_args *ap) +static void +vfsnode_invalidate_stat_cache(struct vboxfs_node *np) { -- return EOPNOTSUPP; +- return 0; + np->sf_stat_time = 0; } --static int vboxvfs_mkdir(struct vop_mkdir_args *ap) +-static int vboxvfs_readdir(struct vop_readdir_args *ap) +static int +vboxfs_close(struct vop_close_args *ap) { @@ -585,15 +635,12 @@ + + vfsnode_invalidate_stat_cache(np); + -+ if (np->sf_file != NULL && vp->v_usecount <= 1) { -+ (void) sfprov_close(np->sf_file); -+ np->sf_file = NULL; -+ } ++ vboxfs_put_sfp_file(np); + + return (0); } --static int vboxvfs_rmdir(struct vop_rmdir_args *ap) +-static int vboxvfs_fsync(struct vop_fsync_args *ap) +static int +vboxfs_getattr(struct vop_getattr_args *ap) { @@ -674,7 +721,7 @@ + return (error); } --static int vboxvfs_readdir(struct vop_readdir_args *ap) +-static int vboxvfs_print (struct vop_print_args *ap) +static int +vboxfs_setattr(struct vop_setattr_args *ap) { @@ -738,7 +785,7 @@ + return (error); } --static int vboxvfs_fsync(struct vop_fsync_args *ap) +-static int vboxvfs_pathconf (struct vop_pathconf_args *ap) +#define blkoff(vboxfsmp, loc) ((loc) & (vboxfsmp)->bmask) + +static int @@ -776,6 +823,13 @@ + if (tmpbuf == 0) + return (ENOMEM); + ++ /* ++ * XXX VOP_READ() is called without VOP_OPEN() on exec case. ++ * We need to ensure the file is opened here. ++ */ ++ error = vboxfs_get_sfp_file(np); ++ if (error != 0) /* Maybe removed on the host. */ ++ return (EIO); + do { + offset = uio->uio_offset; + done = bytes = min(PAGE_SIZE, uio->uio_resid); @@ -784,6 +838,7 @@ + if (error == 0 && done > 0) + error = uiomove(tmpbuf, done, uio); + } while (error == 0 && uio->uio_resid > 0 && done > 0); ++ vboxfs_put_sfp_file(np); + + contigfree(tmpbuf, PAGE_SIZE, M_DEVBUF); + @@ -794,7 +849,7 @@ + return (error); } --static int vboxvfs_print (struct vop_print_args *ap) +-static int vboxvfs_strategy (struct vop_strategy_args *ap) +static int +vboxfs_write(struct vop_write_args *ap) { @@ -855,11 +910,11 @@ + return (error); } --static int vboxvfs_pathconf (struct vop_pathconf_args *ap) +-static int vboxvfs_ioctl(struct vop_ioctl_args *ap) +static int +vboxfs_create(struct vop_create_args *ap) { -- return 0; +- return ENOTTY; + struct vnode *dvp = ap->a_dvp; + struct vnode **vpp = ap->a_vpp; + struct componentname *cnp = ap->a_cnp; @@ -867,7 +922,6 @@ + sffs_stat_t stat; + char *fullpath = NULL; + struct vboxfs_node *dir = VP_TO_VBOXFS_NODE(dvp); -+ sfp_file_t *fp; + int error; + struct vboxfs_mnt *vboxfsmp = dir->vboxfsmp; + @@ -875,7 +929,7 @@ + + fullpath = sfnode_construct_path(dir, cnp->cn_nameptr, cnp->cn_namelen); + error = sfprov_create(dir->vboxfsmp->sf_handle, fullpath, vap->va_mode, -+ &fp, &stat); ++ &stat); + + if (error) + goto out; @@ -895,7 +949,7 @@ + return (error); } --static int vboxvfs_strategy (struct vop_strategy_args *ap) +-static int vboxvfs_getextattr(struct vop_getextattr_args *ap) +static int +vboxfs_remove(struct vop_remove_args *ap) { @@ -914,22 +968,6 @@ + np = VP_TO_VBOXFS_NODE(vp); + dir = VP_TO_VBOXFS_NODE(vp); + -+ /* -+ * If anything else is using this vnode, then fail the remove. -+ * Why? Windows hosts can't sfprov_remove() a file that is open, -+ * so we have to sfprov_close() it first. -+ * There is no errno for this - since it's not a problem on UNIX, -+ * but ETXTBSY is the closest. -+ */ -+ if (np->sf_file != NULL) { -+ if (vp->v_usecount > 1) { -+ error = ETXTBSY; -+ goto out; -+ } -+ sfprov_close(np->sf_file); -+ np->sf_file = NULL; -+ } -+ + error = sfprov_remove(np->vboxfsmp->sf_handle, np->sf_path, + np->sf_type == VLNK); + @@ -945,11 +983,11 @@ + return (error); } --static int vboxvfs_ioctl(struct vop_ioctl_args *ap) +-static int vboxvfs_advlock(struct vop_advlock_args *ap) +static int +vboxfs_rename(struct vop_rename_args *ap) { -- return ENOTTY; +- return 0; + struct vnode *fvp; + struct vnode *fdvp; + struct vnode *tvp; @@ -989,7 +1027,7 @@ + return (ret); } --static int vboxvfs_getextattr(struct vop_getextattr_args *ap) +-static int vboxvfs_lookup(struct vop_lookup_args *ap) +static int +vboxfs_link(struct vop_link_args *ap) { @@ -997,7 +1035,7 @@ + return (EOPNOTSUPP); } --static int vboxvfs_advlock(struct vop_advlock_args *ap) +-static int vboxvfs_inactive(struct vop_inactive_args *ap) +static int +vboxfs_symlink(struct vop_symlink_args *ap) { @@ -1032,7 +1070,7 @@ + return (error); } --static int vboxvfs_lookup(struct vop_lookup_args *ap) +-static int vboxvfs_reclaim(struct vop_reclaim_args *ap) +static int +vboxfs_mkdir(struct vop_mkdir_args *ap) { @@ -1044,7 +1082,6 @@ + sffs_stat_t stat; + char *fullpath = NULL; + struct vboxfs_node *dir = VP_TO_VBOXFS_NODE(dvp); -+ sfp_file_t *fp; + int error; + struct vboxfs_mnt *vboxfsmp = dir->vboxfsmp; + @@ -1052,7 +1089,7 @@ + + fullpath = sfnode_construct_path(dir, cnp->cn_nameptr, cnp->cn_namelen); + error = sfprov_mkdir(dir->vboxfsmp->sf_handle, fullpath, vap->va_mode, -+ &fp, &stat); ++ &stat); + + if (error) + goto out; @@ -1069,7 +1106,7 @@ + return (error); } --static int vboxvfs_inactive(struct vop_inactive_args *ap) +-static int vboxvfs_getpages(struct vop_getpages_args *ap) +static int +vboxfs_rmdir(struct vop_rmdir_args *ap) { @@ -1088,22 +1125,6 @@ + np = VP_TO_VBOXFS_NODE(vp); + dir = VP_TO_VBOXFS_NODE(vp); + -+ /* -+ * If anything else is using this vnode, then fail the remove. -+ * Why? Windows hosts can't sfprov_remove() a file that is open, -+ * so we have to sfprov_close() it first. -+ * There is no errno for this - since it's not a problem on UNIX, -+ * but ETXTBSY is the closest. -+ */ -+ if (np->sf_file != NULL) { -+ if (vp->v_usecount > 1) { -+ error = ETXTBSY; -+ goto out; -+ } -+ sfprov_close(np->sf_file); -+ np->sf_file = NULL; -+ } -+ + error = sfprov_rmdir(np->vboxfsmp->sf_handle, np->sf_path); + +#if 0 @@ -1118,7 +1139,7 @@ + return (error); } --static int vboxvfs_reclaim(struct vop_reclaim_args *ap) +-static int vboxvfs_putpages(struct vop_putpages_args *ap) +static int +vboxfs_readdir(struct vop_readdir_args *ap) { @@ -1243,11 +1264,9 @@ + return (error); } --static int vboxvfs_getpages(struct vop_getpages_args *ap) +static int +vboxfs_readlink(struct vop_readlink_args *v) - { -- return 0; ++{ + struct vnode *vp = v->a_vp; + struct uio *uio = v->a_uio; + @@ -1275,13 +1294,11 @@ + if (tmpbuf) + contigfree(tmpbuf, MAXPATHLEN, M_DEVBUF); + return (error); - } - --static int vboxvfs_putpages(struct vop_putpages_args *ap) ++} ++ +static int +vboxfs_fsync(struct vop_fsync_args *ap) - { -- return 0; ++{ + struct vnode *vp; + struct vboxfs_node *np; + int ret; @@ -1292,8 +1309,8 @@ + return (0); + ret = sfprov_fsync(np->sf_file); + return (ret); - } - ++} ++ +static int +vboxfs_print(struct vop_print_args *ap) +{ @@ -1349,17 +1366,10 @@ + * Lookup an entry in a directory and create a new vnode if found. + */ +static int -+vboxfs_lookup(struct vop_cachedlookup_args /* { -+ struct vnodeop_desc *a_desc; -+ struct vnode *a_dvp; -+ struct vnode **a_vpp; -+ struct componentname *a_cnp; -+ } */ *ap) ++vboxfs_lookup1(struct vnode *dvp, struct vnode **vpp, ++ struct componentname *cnp) +{ -+ struct componentname *cnp = ap->a_cnp; -+ struct vnode *dvp = ap->a_dvp; /* the directory vnode */ + char *nameptr = cnp->cn_nameptr; /* the name of the file or directory */ -+ struct vnode **vpp = ap->a_vpp; /* the vnode we found or NULL */ + struct vnode *tdp = NULL; + struct vboxfs_node *node = VP_TO_VBOXFS_NODE(dvp); + struct vboxfs_mnt *vboxfsmp = node->vboxfsmp; @@ -1372,6 +1382,7 @@ + int lkflags = cnp->cn_lkflags; + char *fullpath = NULL; + ++ *vpp = NULLVP; + error = ENOENT; + if (cnp->cn_flags & ISDOTDOT) { + error = vn_vget_ino_gen(dvp, vboxfs_vn_get_ino_alloc, @@ -1444,6 +1455,47 @@ +} + +static int ++vboxfs_cachedlookup(struct vop_cachedlookup_args *ap) ++{ ++ return (vboxfs_lookup1(ap->a_dvp, ap->a_vpp, ap->a_cnp)); ++} ++ ++static int ++vboxfs_lookup(struct vop_lookup_args *ap) ++{ ++ struct vnode *dvp = ap->a_dvp; ++ struct componentname *cnp = ap->a_cnp; ++ struct vboxfs_node *np = VP_TO_VBOXFS_NODE(dvp); ++ struct timespec mtime; ++ int flags = cnp->cn_flags; ++ int error; ++ ++ if (dvp->v_type != VDIR) ++ return (ENOTDIR); ++ ++ if ((flags & ISLASTCN) && (dvp->v_mount->mnt_flag & MNT_RDONLY) && ++ (cnp->cn_nameiop == DELETE || cnp->cn_nameiop == RENAME)) ++ return (EROFS); ++ ++ error = vn_dir_check_exec(dvp, cnp); ++ if (error != 0) ++ return (error); ++ ++ /* Check if the directory is unmodified on the host. */ ++ mtime = np->sf_stat.sf_mtime; ++ error = vsfnode_update_stat_cache(np); ++ if (error == 0) { ++ if (mtime.tv_sec == np->sf_stat.sf_mtime.tv_sec && ++ mtime.tv_nsec == np->sf_stat.sf_mtime.tv_nsec) ++ return (vfs_cache_lookup(ap)); ++ } ++ ++ cache_purge(dvp); ++ ++ return (vboxfs_lookup1(ap->a_dvp, ap->a_vpp, ap->a_cnp)); ++} ++ ++static int +vboxfs_inactive(struct vop_inactive_args *ap) +{ + return (0); diff --git a/emulators/virtualbox-ose-nox11-legacy/Makefile b/emulators/virtualbox-ose-nox11-legacy/Makefile index 21b9fee09903..393e93999c31 100644 --- a/emulators/virtualbox-ose-nox11-legacy/Makefile +++ b/emulators/virtualbox-ose-nox11-legacy/Makefile @@ -1,4 +1,4 @@ -PORTREVISION= 24 +PORTREVISION= 25 PKGNAMESUFFIX= -nox11-legacy MASTERDIR= ${.CURDIR}/../virtualbox-ose-legacy