Received: by 10.223.185.116 with SMTP id b49csp1458890wrg; Wed, 21 Feb 2018 19:49:22 -0800 (PST) X-Google-Smtp-Source: AH8x224ts/PvkRjU18gGaHCtx4RRb+CuSqoaHZewJcH7e8pCiEdgKHTXB2cfwoq+EglrzhjWF7on X-Received: by 10.98.134.10 with SMTP id x10mr3342594pfd.78.1519271362838; Wed, 21 Feb 2018 19:49:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519271362; cv=none; d=google.com; s=arc-20160816; b=hSlGd3YhAoUbzlTNvwPOzy7KaDUquDAZnm9tduv+0pOk1le788KI13q4wzXu5X5MEL 15RQZzVLCrGqMjYvxT8u5z5zG1qbArhZ0Uq4U1iYLTuhsdzi4HK+hbr0auP4byPj2iFL K2T40He/SLeGpOPR87shKo4RkoYn/k/fW+p+3uwpsohmcZ4MYmGfyRYoj2HVzpO2rUei K4QquBL+0+1jMUQ2SwklC6ATM+wbhKL1WkmA2WE9K2dIvB5YjTL6X5ghal9qOdfaycqC 86DNPTl9ilrkU1yP8M4KF4gt0Oi5Zlb8pX15jC0QbPGKqfbrrhlRzEhkNgJJ6Z7+ZoDa KpJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:content-transfer-encoding :mime-version:organization:references:in-reply-to:date:cc:to:from :subject:arc-authentication-results; bh=mXb4iicwZwb3Hzqei6N5r+4d1F13iT5lonKZL3Zam4w=; b=imq21cchViaEat/O7k4E++YJMlkv8QWBWtUFPaOD3FUZJ35S/QJKlUY74WIafkxX2Q GtiD5RlaM/hLt7fIphf7oHERqfU3FcZgHx01o4hh4OB6iOFXviV9cNmlcO0s1AsVCn6y NK/ePHSSzSMiLxXv1j0s/xmYPz0Dge3DS4bu+S7j5dqhKOzgpnldde5y+Kxtsgn086fB NckScoiIrhuMuxQb+YmdCaThPd8pB4s/rffdbtJWE6tbgll3RlfovZhZb6VPudYKCjT7 6664+ATWaZWkB8QXQ7+zCOc0nhHjUkCEbS5ULlNjB++mKkN0RkavQVXEu4ImE5Du5vdw hzWg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b3-v6si3053628plc.309.2018.02.21.19.49.08; Wed, 21 Feb 2018 19:49:22 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752163AbeBVDsg (ORCPT + 99 others); Wed, 21 Feb 2018 22:48:36 -0500 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:38490 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751978AbeBVDsf (ORCPT ); Wed, 21 Feb 2018 22:48:35 -0500 Received: from pps.filterd (m0098413.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w1M3hmJ7107342 for ; Wed, 21 Feb 2018 22:48:34 -0500 Received: from e06smtp14.uk.ibm.com (e06smtp14.uk.ibm.com [195.75.94.110]) by mx0b-001b2d01.pphosted.com with ESMTP id 2g9kc4nga0-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Wed, 21 Feb 2018 22:48:33 -0500 Received: from localhost by e06smtp14.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Thu, 22 Feb 2018 03:48:32 -0000 Received: from b06cxnps4074.portsmouth.uk.ibm.com (9.149.109.196) by e06smtp14.uk.ibm.com (192.168.101.144) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Thu, 22 Feb 2018 03:48:29 -0000 Received: from d06av23.portsmouth.uk.ibm.com (d06av23.portsmouth.uk.ibm.com [9.149.105.59]) by b06cxnps4074.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w1M3mTaA47775754; Thu, 22 Feb 2018 03:48:29 GMT Received: from d06av23.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id DB084A404D; Thu, 22 Feb 2018 03:41:38 +0000 (GMT) Received: from d06av23.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 466C9A4040; Thu, 22 Feb 2018 03:41:38 +0000 (GMT) Received: from ozlabs.au.ibm.com (unknown [9.192.253.14]) by d06av23.portsmouth.uk.ibm.com (Postfix) with ESMTP; Thu, 22 Feb 2018 03:41:38 +0000 (GMT) Received: from adsilva.ozlabs.ibm.com (haven.au.ibm.com [9.192.254.114]) (using TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ozlabs.au.ibm.com (Postfix) with ESMTPSA id 4D693A0146; Thu, 22 Feb 2018 14:48:27 +1100 (AEDT) Subject: Re: [PATCH] ocxl: Add get_metadata IOCTL to share OCXL information to userspace From: "Alastair D'Silva" To: Balbir Singh Cc: linuxppc-dev , "linux-kernel@vger.kernel.org" , Arnd Bergmann , frederic.barrat@fr.ibm.com, Greg KH , Andrew Donnellan Date: Thu, 22 Feb 2018 14:48:27 +1100 In-Reply-To: References: <20180221045736.7614-1-alastair@au1.ibm.com> <1519255934.2867.3.camel@au1.ibm.com> Organization: IBM Australia Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.26.5 (3.26.5-1.fc27) Mime-Version: 1.0 Content-Transfer-Encoding: 7bit X-TM-AS-GCONF: 00 x-cbid: 18022203-0016-0000-0000-00000528507B X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18022203-0017-0000-0000-000028646742 Message-Id: <1519271307.2867.12.camel@au1.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2018-02-22_01:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=2 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1802220048 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 2018-02-22 at 14:41 +1100, Balbir Singh wrote: > On Thu, Feb 22, 2018 at 10:32 AM, Alastair D'Silva com> wrote: > > > > On Wed, 2018-02-21 at 17:43 +1100, Balbir Singh wrote: > > > On Wed, Feb 21, 2018 at 3:57 PM, Alastair D'Silva > > bm.c > > > om> wrote: > > > > From: Alastair D'Silva > > > > > > > > Some required information is not exposed to userspace currently > > > > (eg. the > > > > PASID), pass this information back, along with other > > > > information > > > > which > > > > is currently communicated via sysfs, which saves some parsing > > > > effort in > > > > userspace. > > > > > > > > Signed-off-by: Alastair D'Silva > > > > --- > > > > drivers/misc/ocxl/file.c | 27 +++++++++++++++++++++++++++ > > > > include/uapi/misc/ocxl.h | 22 ++++++++++++++++++++++ > > > > 2 files changed, 49 insertions(+) > > > > > > > > diff --git a/drivers/misc/ocxl/file.c > > > > b/drivers/misc/ocxl/file.c > > > > index d9aa407db06a..11514a8444e5 100644 > > > > --- a/drivers/misc/ocxl/file.c > > > > +++ b/drivers/misc/ocxl/file.c > > > > @@ -102,10 +102,32 @@ static long afu_ioctl_attach(struct > > > > ocxl_context *ctx, > > > > return rc; > > > > } > > > > > > > > +static long afu_ioctl_get_metadata(struct ocxl_context *ctx, > > > > + struct ocxl_ioctl_get_metadata __user *uarg) > > > > > > Why do we call this metadata? Isn't this an afu_descriptor? > > > > > > > It's metadata for the descriptor. > > I meant metadata is too generic, could we have other types of > metadata in OCXL? > I don't believe so, we would instead expand the scope of this IOCTL using version & space available from the reserved fields. > > > > > > +{ > > > > + struct ocxl_ioctl_get_metadata arg; > > > > + > > > > + memset(&arg, 0, sizeof(arg)); > > > > + > > > > + arg.version = 0; > > > > > > Does it make sense to have version 0? Even if does, you can > > > afford > > > to skip initialization due to the memset above. I prefer that > > > versions > > > start with 1 > > > > > > > Setting it to 0 is for the reader, not the compiler. I'm not clear > > on > > the benefit of starting the version at 1, could you clarify? > > How do I distinguish between version number never set and 0? > The version number is always set. If the IOCTL doesn't exist, the ioctl call will error instead. > > > > > > + > > > > + arg.afu_version_major = ctx->afu->config.version_major; > > > > + arg.afu_version_minor = ctx->afu->config.version_minor; > > > > + arg.pasid = ctx->pasid; > > > > + arg.pp_mmio_size = ctx->afu->config.pp_mmio_stride; > > > > + arg.global_mmio_size = ctx->afu- > > > > >config.global_mmio_size; > > > > + > > > > + if (copy_to_user(uarg, &arg, sizeof(arg))) > > > > + return -EFAULT; > > > > + > > > > + return 0; > > > > +} > > > > + > > > > #define CMD_STR(x) (x == OCXL_IOCTL_ATTACH ? "ATTACH" > > > > : \ > > > > x == OCXL_IOCTL_IRQ_ALLOC ? "IRQ_ALLOC" > > > > : \ > > > > x == OCXL_IOCTL_IRQ_FREE ? "IRQ_FREE" > > > > : \ > > > > x == OCXL_IOCTL_IRQ_SET_FD ? > > > > "IRQ_SET_FD" > > > > : \ > > > > + x == OCXL_IOCTL_GET_METADATA ? > > > > "GET_METADATA" : \ > > > > "UNKNOWN") > > > > > > > > static long afu_ioctl(struct file *file, unsigned int cmd, > > > > @@ -157,6 +179,11 @@ static long afu_ioctl(struct file *file, > > > > unsigned int cmd, > > > > irq_fd.eventfd); > > > > break; > > > > > > > > + case OCXL_IOCTL_GET_METADATA: > > > > + rc = afu_ioctl_get_metadata(ctx, > > > > + (struct ocxl_ioctl_get_metadata > > > > __user *) args); > > > > + break; > > > > + > > > > default: > > > > rc = -EINVAL; > > > > } > > > > diff --git a/include/uapi/misc/ocxl.h > > > > b/include/uapi/misc/ocxl.h > > > > index 4b0b0b756f3e..16e1f48ce280 100644 > > > > --- a/include/uapi/misc/ocxl.h > > > > +++ b/include/uapi/misc/ocxl.h > > > > @@ -32,6 +32,27 @@ struct ocxl_ioctl_attach { > > > > __u64 reserved3; > > > > }; > > > > > > > > +/* > > > > + * Version contains the version of the struct. > > > > + * Versions will always be backwards compatible, that is, new > > > > versions will not > > > > + * alter existing fields > > > > + */ > > > > +struct ocxl_ioctl_get_metadata { > > > > > > This sounds more like a function name, do we need it to be > > > _get_metdata? > > > > > > > It pretty much is a function, it returns to userspace metadata > > about > > the descriptor being operated on. > > > > It has a verb indicating action I misunderstood, I had named the struct to match the IOCTL, but that isn't necessary. I'll update it in the next patch. -- Alastair D'Silva Open Source Developer Linux Technology Centre, IBM Australia mob: 0423 762 819