Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp791810imm; Tue, 15 May 2018 09:13:38 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpsYVcnizn+rWHKvGArFfUgP5UjPWbZJSk4YLIs5Rhhf+3moeZtI8vPLJRH9KsXKEK0QpfB X-Received: by 2002:a63:9302:: with SMTP id b2-v6mr12904264pge.263.1526400818587; Tue, 15 May 2018 09:13:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526400818; cv=none; d=google.com; s=arc-20160816; b=woYV2Xg5xMxMs4rvnnQyVq7RtvanKmNWkxZddh1TqFFcGi5RmqNQ82bXT+1cKLNunt AlMDMMFJ0yYIeSg6UdyxuOdbfbrP89/hOuNungBkQjPZ7QwOM2qmnJr7IrJHdQnb9non SEdnEIqQrogaqCE2/qW/vonJjK5kThSxnOu3SQcK5EoRGA6hCHQLDft+yBWtghH8kst3 gWVHwynjSs6hFJIRdMX1yfzfEY11usikWgZr0pDDkQlHvhfnB+1m8GTeBnqpnwUQZNco wlk6LVaVZFWhdsvoJU/AiAtoRM7gvqpU8++tgGWmD7XDWrVSfh3kybH+LY2YRvvFwSlT SXqg== 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-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :from:references:cc:to:subject:arc-authentication-results; bh=0w0yQhxxwXBol6pnQ8Xx4z4L8nAbUAnHn0TUtDx+AvI=; b=DDqp7CbBoiiHoydzLWf+6UjsqmLDCoVwGBUQo64zExJdUifd9RQkbr2FH9QlZvBKSx 6C27CJ1mvT+N1K+3w+n21rSsq4Uqe7uj5HQ+ojArFkNUBFN0a8Uh8eTym6/GhP3t1GBU k2Wc7YvOgoFm8vw5y39qEBOc12ceRPFPW5ZSU8qe/dZdjWxly5udB7lMO0RzoXYZUqfW z2qvzbfuoUqBumkxWGIIvdXYJnehRalrGhvHglHBC4eJUdFcJRuw+LNrMIpGugIPwo6K 0l9M8vCCVHV8bECUPPR0kICVetXNaVF6pDxobQUTMKCxdUK457Jeg3U61D2M+nQvFQQO JO9A== 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 p8-v6si279499plk.441.2018.05.15.09.13.23; Tue, 15 May 2018 09:13:38 -0700 (PDT) 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 S1754080AbeEOQLc (ORCPT + 99 others); Tue, 15 May 2018 12:11:32 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:40390 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753470AbeEOQL3 (ORCPT ); Tue, 15 May 2018 12:11:29 -0400 Received: from pps.filterd (m0098399.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w4FG9QCh040363 for ; Tue, 15 May 2018 12:11:29 -0400 Received: from e13.ny.us.ibm.com (e13.ny.us.ibm.com [129.33.205.203]) by mx0a-001b2d01.pphosted.com with ESMTP id 2j029xa1f4-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Tue, 15 May 2018 12:11:29 -0400 Received: from localhost by e13.ny.us.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Tue, 15 May 2018 12:11:27 -0400 Received: from b01cxnp23033.gho.pok.ibm.com (9.57.198.28) by e13.ny.us.ibm.com (146.89.104.200) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Tue, 15 May 2018 12:11:24 -0400 Received: from b01ledav002.gho.pok.ibm.com (b01ledav002.gho.pok.ibm.com [9.57.199.107]) by b01cxnp23033.gho.pok.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w4FGBNar3932668; Tue, 15 May 2018 16:11:23 GMT Received: from b01ledav002.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id B6F58124055; Tue, 15 May 2018 13:13:18 -0400 (EDT) Received: from b01ledav002.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 1F948124052; Tue, 15 May 2018 13:13:18 -0400 (EDT) Received: from oc8043147753.ibm.com (unknown [9.60.75.218]) by b01ledav002.gho.pok.ibm.com (Postfix) with ESMTP; Tue, 15 May 2018 13:13:18 -0400 (EDT) Subject: Re: [PATCH v5 05/13] s390: vfio-ap: register matrix device with VFIO mdev framework To: Halil Pasic , pmorel@linux.ibm.com, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: freude@de.ibm.com, schwidefsky@de.ibm.com, heiko.carstens@de.ibm.com, borntraeger@de.ibm.com, cohuck@redhat.com, kwankhede@nvidia.com, bjsdjshi@linux.vnet.ibm.com, pbonzini@redhat.com, alex.williamson@redhat.com, pmorel@linux.vnet.ibm.com, alifm@linux.vnet.ibm.com, mjrosato@linux.vnet.ibm.com, jjherne@linux.vnet.ibm.com, thuth@redhat.com, pasic@linux.vnet.ibm.com, berrange@redhat.com, fiuczy@linux.vnet.ibm.com, buendgen@de.ibm.com References: <1525705912-12815-1-git-send-email-akrowiak@linux.vnet.ibm.com> <1525705912-12815-6-git-send-email-akrowiak@linux.vnet.ibm.com> <5471b194-d7ca-c9c6-132e-fa9539fe44f0@linux.ibm.com> <4688078d-3e13-5201-582f-52576b25defa@linux.vnet.ibm.com> <1f9117bd-ed14-bde4-fdbd-cb3733c8c633@linux.ibm.com> <1fb8d1ab-02d5-c170-08e8-a77526fbb7c4@linux.ibm.com> From: Tony Krowiak Date: Tue, 15 May 2018 12:11:22 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.0 MIME-Version: 1.0 In-Reply-To: <1fb8d1ab-02d5-c170-08e8-a77526fbb7c4@linux.ibm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US X-TM-AS-GCONF: 00 x-cbid: 18051516-0008-0000-0000-00000307E56E X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00009030; HX=3.00000241; KW=3.00000007; PH=3.00000004; SC=3.00000260; SDB=6.01032716; UDB=6.00527984; IPR=6.00811847; MB=3.00021128; MTD=3.00000008; XFM=3.00000015; UTC=2018-05-15 16:11:27 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18051516-0009-0000-0000-000039425963 Message-Id: <9eabe7c2-4380-c57f-effe-e6d8e194466a@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-05-15_05:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=0 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-1805150163 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/15/2018 11:48 AM, Halil Pasic wrote: > > > On 05/15/2018 05:16 PM, Tony Krowiak wrote: >> On 05/15/2018 10:17 AM, Pierre Morel wrote: >>> On 14/05/2018 21:42, Tony Krowiak wrote: >>>> On 05/11/2018 01:18 PM, Halil Pasic wrote: >>>>> >>>>> >>>>> On 05/07/2018 05:11 PM, Tony Krowiak wrote: >>>>>> Registers the matrix device created by the VFIO AP device >>>>>> driver with the VFIO mediated device framework. >>>>>> Registering the matrix device will create the sysfs >>>>>> structures needed to create mediated matrix devices >>>>>> each of which will be used to configure the AP matrix >>>>>> for a guest and connect it to the VFIO AP device driver. >>>>>> >>>>> [..] >>>>>> diff --git a/drivers/s390/crypto/vfio_ap_ops.c >>>>>> b/drivers/s390/crypto/vfio_ap_ops.c >>>>>> new file mode 100644 >>>>>> index 0000000..d7d36fb >>>>>> --- /dev/null >>>>>> +++ b/drivers/s390/crypto/vfio_ap_ops.c >>>>>> @@ -0,0 +1,106 @@ >>>>>> +// SPDX-License-Identifier: GPL-2.0+ >>>>>> +/* >>>>>> + * Adjunct processor matrix VFIO device driver callbacks. >>>>>> + * >>>>>> + * Copyright IBM Corp. 2017 >>>>>> + * Author(s): Tony Krowiak >>>>>> + * >>>>>> + */ >>>>>> +#include >>>>>> +#include >>>>>> +#include >>>>>> +#include >>>>>> +#include >>>>>> + >>>>>> +#include "vfio_ap_private.h" >>>>>> + >>>>>> +#define VFOP_AP_MDEV_TYPE_HWVIRT "passthrough" >>>>>> +#define VFIO_AP_MDEV_NAME_HWVIRT "VFIO AP Passthrough Device" >>>>>> + >>>>>> +static int vfio_ap_mdev_create(struct kobject *kobj, struct >>>>>> mdev_device *mdev) >>>>>> +{ >>>>>> + struct ap_matrix *ap_matrix = >>>>>> to_ap_matrix(mdev_parent_dev(mdev)); >>>>>> + >>>>>> + ap_matrix->available_instances--; >>>>>> + >>>>>> + return 0; >>>>>> +} >>>>>> + >>>>>> +static int vfio_ap_mdev_remove(struct mdev_device *mdev) >>>>>> +{ >>>>>> + struct ap_matrix *ap_matrix = >>>>>> to_ap_matrix(mdev_parent_dev(mdev)); >>>>>> + >>>>>> + ap_matrix->available_instances++; >>>>>> + >>>>>> + return 0; >>>>>> +} >>>>>> + >>>>> >>>>> The above functions seem to be called with the lock of this >>>>> auto-generated >>>>> mdev parent device held. That's why we don't have to care about >>>>> synchronization >>>>> ourselves, right? >>>> >>>> I would assume as much. The comments for the 'struct >>>> mdev_parent_ops' in >>>> include/linux/mdev.h do not mention anything about synchronization, >>>> nor did I >>>> see any locking or synchronization in the vfio_ccw implementation >>>> after which >>>> I modeled my code, so frankly it is something I did not consider. >>>> >>>>> >>>>> >>>>> A small comment in the code could be helpful for mdev non-experts. >>>>> Hell, I would >>>>> even consider documenting it for all mdev -- took me some time to >>>>> figure out. >>>> >>>> You may want to bring this up with the VFIO mdev maintainers, but >>>> I'd be happy to >>>> include a comment in the functions in question if you think it >>>> important. >>>> >>>>> >>>>> >>>>> [..] >>>>> >>>>> >>>>>> +int vfio_ap_mdev_register(struct ap_matrix *ap_matrix) >>>>>> +{ >>>>>> + int ret; >>>>>> + >>>>>> + ret = mdev_register_device(&ap_matrix->device, >>>>>> &vfio_ap_matrix_ops); >>>>>> + if (ret) >>>>>> + return ret; >>>>>> + >>>>>> + ap_matrix->available_instances = >>>>>> AP_MATRIX_MAX_AVAILABLE_INSTANCES; >>>>>> + >>>>>> + return 0; >>>>>> +} >>>>>> + >>>>>> +void vfio_ap_mdev_unregister(struct ap_matrix *ap_matrix) >>>>>> +{ >>>>>> + ap_matrix->available_instances--; >>>>> >>>>> What is this for? I don't understand. >>>> >>>> To control the number of mediated devices one can create for the >>>> matrix device. >>>> Once the max is reached, the mdev framework will not allow creation >>>> of another >>>> mediated device until one is removed. This counter keeps track of >>>> the number >>>> of instances that can be created. This is documented with the mediated >>>> framework. You may want to take a look at: >>>> >>>> Documentation/vfio-mediated-device.txt >>>> Documentation/vfio.txt >>>> Documentation/virtual/kvm/devices/vfio.txt >>> >>> This is what you do in create/remove. >>> But here in unregister I agree with Halil, it does not seem to be >>> usefull. >> >> If that is in fact what Halil was asking, then I misinterpreted his >> question; I >> thought he was asking what the available_instances was used for. You are >> correct, this does not belong here although it makes little >> difference given >> this is called only when the driver, which creates the matrix device, >> is unloaded. >> It is necessary in the register function to initialize its value, but >> I'll >> remove it from here. >> > > I questioned the dubious usage of ap_matrix->available_instances > rather than > asking what is the variable for. I said I'd remove it. > > > If I've had this deemed damaging I would have asked if it's damaging > in a way > I think it is. For example take my comment on 'KVM: s390: interfaces > to manage > guest's AP matrix'. I apologize for not being able to read your mind. While this is not necessarily necessary, it is not damaging because this is called only when the driver is being unloaded. The point is moot, however, because I am removing it. > > > Regards, > Halil > >>> >>> >>>> >>>>> >>>>> >>>>> Regards, >>>>> Halil >>>>> >>>>>> + mdev_unregister_device(&ap_matrix->device); >>>>>> +} >>>> >>>> >>> >>