From patchwork Mon Jun 27 09:42:41 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Greg Kurz X-Patchwork-Id: 9200233 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 1D06860757 for ; Mon, 27 Jun 2016 09:54:58 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 09F5E1FF10 for ; Mon, 27 Jun 2016 09:54:58 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id F0A8D28405; Mon, 27 Jun 2016 09:54:57 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.9 required=2.0 tests=BAYES_00,RCVD_IN_DNSWL_HI autolearn=unavailable version=3.3.1 Received: from lists.gnu.org (lists.gnu.org [208.118.235.17]) (using TLSv1 with cipher AES256-SHA (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id 385001FF10 for ; Mon, 27 Jun 2016 09:54:57 +0000 (UTC) Received: from localhost ([::1]:57557 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1bHTFo-0008C6-BY for patchwork-qemu-devel@patchwork.kernel.org; Mon, 27 Jun 2016 05:54:56 -0400 Received: from eggs.gnu.org ([2001:4830:134:3::10]:34355) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1bHT4U-0001IK-D2 for qemu-devel@nongnu.org; Mon, 27 Jun 2016 05:43:17 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1bHT4Q-0005Zc-HH for qemu-devel@nongnu.org; Mon, 27 Jun 2016 05:43:13 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:55950) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1bHT4Q-0005ZQ-8q for qemu-devel@nongnu.org; Mon, 27 Jun 2016 05:43:10 -0400 Received: from pps.filterd (m0098410.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.11/8.16.0.11) with SMTP id u5R9dHc6100311 for ; Mon, 27 Jun 2016 05:43:09 -0400 Received: from e32.co.us.ibm.com (e32.co.us.ibm.com [32.97.110.150]) by mx0a-001b2d01.pphosted.com with ESMTP id 23spg6w8bg-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Mon, 27 Jun 2016 05:43:09 -0400 Received: from localhost by e32.co.us.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Mon, 27 Jun 2016 03:43:08 -0600 Received: from d03dlp02.boulder.ibm.com (9.17.202.178) by e32.co.us.ibm.com (192.168.1.132) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Mon, 27 Jun 2016 03:42:45 -0600 X-IBM-Helo: d03dlp02.boulder.ibm.com X-IBM-MailFrom: groug@kaod.org Received: from b01cxnp22035.gho.pok.ibm.com (b01cxnp22035.gho.pok.ibm.com [9.57.198.25]) by d03dlp02.boulder.ibm.com (Postfix) with ESMTP id AACB63E4003E; Mon, 27 Jun 2016 03:42:44 -0600 (MDT) Received: from b01ledav006.gho.pok.ibm.com (b01ledav006.gho.pok.ibm.com [9.57.199.111]) by b01cxnp22035.gho.pok.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id u5R9giji57475196; Mon, 27 Jun 2016 09:42:44 GMT Received: from b01ledav006.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 43799AC03A; Mon, 27 Jun 2016 05:42:44 -0400 (EDT) Received: from bahia.lan (unknown [9.164.189.130]) by b01ledav006.gho.pok.ibm.com (Postfix) with ESMTP id E4169AC03C; Mon, 27 Jun 2016 05:42:42 -0400 (EDT) From: Greg Kurz To: qemu-devel@nongnu.org Date: Mon, 27 Jun 2016 11:42:41 +0200 In-Reply-To: <146702045511.5764.17551224268217330628.stgit@bahia.lan> References: <146702045511.5764.17551224268217330628.stgit@bahia.lan> User-Agent: StGit/0.17.1-dirty MIME-Version: 1.0 X-TM-AS-GCONF: 00 X-Content-Scanned: Fidelis XPS MAILER x-cbid: 16062709-0004-0000-0000-00000FC71499 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 16062709-0005-0000-0000-000076897DFF Message-Id: <146702056179.5764.14848404107264883942.stgit@bahia.lan> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:, , definitions=2016-06-27_06:, , signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 suspectscore=1 malwarescore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1604210000 definitions=main-1606270110 X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x [generic] X-Received-From: 148.163.156.1 Subject: [Qemu-devel] [PATCH 13/13] 9p: introduce flistxattr file op X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Eric Van Hensbergen , v9fs-developer@lists.sourceforge.net, "Aneesh Kumar K.V" , Greg Kurz Errors-To: qemu-devel-bounces+patchwork-qemu-devel=patchwork.kernel.org@nongnu.org Sender: "Qemu-devel" X-Virus-Scanned: ClamAV using ClamSMTP This allows flistxattr() in the guest to stay functional even if the file was unlinked. Signed-off-by: Greg Kurz --- fsdev/file-op-9p.h | 2 ++ hw/9pfs/9p-handle.c | 10 ++++++++++ hw/9pfs/9p-local.c | 10 ++++++++++ hw/9pfs/9p-proxy.c | 10 ++++++++++ hw/9pfs/9p-synth.c | 8 ++++++++ hw/9pfs/9p.c | 18 ++++++++++++++---- hw/9pfs/coth.h | 1 + hw/9pfs/coxattr.c | 20 ++++++++++++++++++++ 8 files changed, 75 insertions(+), 4 deletions(-) diff --git a/fsdev/file-op-9p.h b/fsdev/file-op-9p.h index 683596797b51..e23908d98764 100644 --- a/fsdev/file-op-9p.h +++ b/fsdev/file-op-9p.h @@ -147,6 +147,8 @@ struct FileOperations int (*fchmod)(FsContext *, int, V9fsFidOpenState *, FsCred *); ssize_t (*fgetxattr)(FsContext *, int, V9fsFidOpenState *, const char *, void *, size_t); + ssize_t (*flistxattr)(FsContext *, int, V9fsFidOpenState *, + void *, size_t); void *opaque; }; diff --git a/hw/9pfs/9p-handle.c b/hw/9pfs/9p-handle.c index 3153acff663c..d17d9a8ff008 100644 --- a/hw/9pfs/9p-handle.c +++ b/hw/9pfs/9p-handle.c @@ -502,6 +502,15 @@ static ssize_t handle_llistxattr(FsContext *ctx, V9fsPath *fs_path, return ret; } +static ssize_t handle_flistxattr(FsContext *ctx, int fid_type, + V9fsFidOpenState *fs, void *value, size_t size) +{ + int fd; + + fd = v9fs_get_fd_fid(fid_type, fs); + return flistxattr(fd, value, size); +} + static int handle_lsetxattr(FsContext *ctx, V9fsPath *fs_path, const char *name, void *value, size_t size, int flags) { @@ -747,4 +756,5 @@ FileOperations handle_ops = { .fchown = handle_fchown, .fchmod = handle_fchmod, .fgetxattr = handle_fgetxattr, + .flistxattr = handle_flistxattr, }; diff --git a/hw/9pfs/9p-local.c b/hw/9pfs/9p-local.c index 206849a3ed83..3a1caeccdf00 100644 --- a/hw/9pfs/9p-local.c +++ b/hw/9pfs/9p-local.c @@ -1122,6 +1122,15 @@ static ssize_t local_llistxattr(FsContext *ctx, V9fsPath *fs_path, return v9fs_list_xattr(ctx, -1, path, value, size); } +static ssize_t local_flistxattr(FsContext *ctx, int fid_type, + V9fsFidOpenState *fs, void *value, size_t size) +{ + int fd; + + fd = v9fs_get_fd_fid(fid_type, fs); + return v9fs_list_xattr(ctx, fd, NULL, value, size); +} + static int local_lsetxattr(FsContext *ctx, V9fsPath *fs_path, const char *name, void *value, size_t size, int flags) { @@ -1368,4 +1377,5 @@ FileOperations local_ops = { .fchown = local_fchown, .fchmod = local_fchmod, .fgetxattr = local_fgetxattr, + .flistxattr = local_flistxattr, }; diff --git a/hw/9pfs/9p-proxy.c b/hw/9pfs/9p-proxy.c index 074799027873..94ee76f1fbf6 100644 --- a/hw/9pfs/9p-proxy.c +++ b/hw/9pfs/9p-proxy.c @@ -1029,6 +1029,15 @@ static ssize_t proxy_llistxattr(FsContext *ctx, V9fsPath *fs_path, return retval; } +static ssize_t proxy_flistxattr(FsContext *ctx, int fid_type, + V9fsFidOpenState *fs, void *value, size_t size) +{ + int fd; + + fd = v9fs_get_fd_fid(fid_type, fs); + return flistxattr(fd, value, size); +} + static int proxy_lsetxattr(FsContext *ctx, V9fsPath *fs_path, const char *name, void *value, size_t size, int flags) { @@ -1263,4 +1272,5 @@ FileOperations proxy_ops = { .fchown = proxy_fchown, .fchmod = proxy_fchmod, .fgetxattr = proxy_fgetxattr, + .flistxattr = proxy_flistxattr, }; diff --git a/hw/9pfs/9p-synth.c b/hw/9pfs/9p-synth.c index 24505fc2f621..9cd098914d08 100644 --- a/hw/9pfs/9p-synth.c +++ b/hw/9pfs/9p-synth.c @@ -479,6 +479,13 @@ static ssize_t synth_llistxattr(FsContext *ctx, V9fsPath *path, return -1; } +static ssize_t synth_flistxattr(FsContext *ctx, int fid_type, + V9fsFidOpenState *fs, void *value, size_t size) +{ + errno = ENOTSUP; + return -1; +} + static int synth_lsetxattr(FsContext *ctx, V9fsPath *path, const char *name, void *value, size_t size, int flags) @@ -607,4 +614,5 @@ FileOperations synth_ops = { .fchown = synth_fchown, .fchmod = synth_fchmod, .fgetxattr = synth_fgetxattr, + .flistxattr = synth_flistxattr, }; diff --git a/hw/9pfs/9p.c b/hw/9pfs/9p.c index 435100f85be3..14aee2e749d8 100644 --- a/hw/9pfs/9p.c +++ b/hw/9pfs/9p.c @@ -3125,6 +3125,16 @@ static int v9fs_do_getxattr(V9fsPDU *pdu, V9fsFidState *fidp, V9fsString *name, } } +static int v9fs_do_listxattr(V9fsPDU *pdu, V9fsFidState *fidp, void *value, + size_t size) +{ + if (fid_has_file(fidp)) { + return v9fs_co_flistxattr(pdu, fidp, value, size); + } else { + return v9fs_co_llistxattr(pdu, &fidp->path, value, size); + } +} + static void v9fs_xattrwalk(void *opaque) { int64_t size; @@ -3163,7 +3173,7 @@ static void v9fs_xattrwalk(void *opaque) /* * listxattr request. Get the size first */ - size = v9fs_co_llistxattr(pdu, &xattr_fidp->path, NULL, 0); + size = v9fs_do_listxattr(pdu, xattr_fidp, NULL, 0); if (size < 0) { err = size; clunk_fid(s, xattr_fidp->fid); @@ -3175,9 +3185,9 @@ static void v9fs_xattrwalk(void *opaque) xattr_fidp->fs.xattr.len = size; if (size) { xattr_fidp->fs.xattr.value = g_malloc(size); - err = v9fs_co_llistxattr(pdu, &xattr_fidp->path, - xattr_fidp->fs.xattr.value, - xattr_fidp->fs.xattr.len); + err = v9fs_do_listxattr(pdu, xattr_fidp, + xattr_fidp->fs.xattr.value, + xattr_fidp->fs.xattr.len); if (err < 0) { clunk_fid(s, xattr_fidp->fid); goto out; diff --git a/hw/9pfs/coth.h b/hw/9pfs/coth.h index 2e507939d01d..ddb061d91ed3 100644 --- a/hw/9pfs/coth.h +++ b/hw/9pfs/coth.h @@ -100,5 +100,6 @@ extern int v9fs_co_fchown(V9fsPDU *, V9fsFidState *, uid_t, gid_t); extern int v9fs_co_fchmod(V9fsPDU *, V9fsFidState *, mode_t); extern int v9fs_co_fgetxattr(V9fsPDU *, V9fsFidState *, V9fsString *, void *, size_t); +extern int v9fs_co_flistxattr(V9fsPDU *, V9fsFidState *, void *, size_t); #endif diff --git a/hw/9pfs/coxattr.c b/hw/9pfs/coxattr.c index 72e3f38fb371..f4944e6abae3 100644 --- a/hw/9pfs/coxattr.c +++ b/hw/9pfs/coxattr.c @@ -37,6 +37,26 @@ int v9fs_co_llistxattr(V9fsPDU *pdu, V9fsPath *path, void *value, size_t size) return err; } +int v9fs_co_flistxattr(V9fsPDU *pdu, V9fsFidState *fidp, void *value, + size_t size) +{ + int err; + V9fsState *s = pdu->s; + + if (v9fs_request_cancelled(pdu)) { + return -EINTR; + } + v9fs_co_run_in_worker( + { + err = s->ops->flistxattr(&s->ctx, fidp->fid_type, &fidp->fs, value, + size); + if (err < 0) { + err = -errno; + } + }); + return err; +} + int v9fs_co_lgetxattr(V9fsPDU *pdu, V9fsPath *path, V9fsString *xattr_name, void *value, size_t size)