From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.3 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,NICE_REPLY_A, SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id F3F78C47095 for ; Mon, 5 Oct 2020 21:49:03 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 8B15220870 for ; Mon, 5 Oct 2020 21:49:03 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=ibm.com header.i=@ibm.com header.b="TG4tFmkD" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726873AbgJEVtA (ORCPT ); Mon, 5 Oct 2020 17:49:00 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:12408 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726813AbgJEVtA (ORCPT ); Mon, 5 Oct 2020 17:49:00 -0400 Received: from pps.filterd (m0098399.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 095LYj4m070421; Mon, 5 Oct 2020 17:48:58 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=pp1; bh=jZDVkotQxi7x4Hly3cWa39JzA1ufcbu3Zf5hZiZHo3I=; b=TG4tFmkDfWDbrVLrqoa9pkkP16V+VkVQ+P0mWoWtDLf7nrzDN/dv1lwk4Dwo6VsK3snU aI6zMhIg6LPZHGW8eY5nnmxofw4J+AzuhHQqXoWIQKskBAQtF24cCRNGVoSWyLj0SDw8 C4Q9fw5Z4JudmJ6BwEQwLibmYjvMLeMFg8DoSAmy9lDTNlCzrhslXTHZzGX4/zQRwgN1 KmUF/9fcVog37d8RK2eluQUKBX0PKfFazI2MIWmulJ6IAY8vgX8gpA7oMLDiRAFncda/ 7MB/jtlZcaCauD7jtPsFVGWKHmxsLHi2oTouY22CfSW4cr9ngov+0xcXFuEJpAfLMPwT dQ== Received: from pps.reinject (localhost [127.0.0.1]) by mx0a-001b2d01.pphosted.com with ESMTP id 340aub99s0-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 05 Oct 2020 17:48:58 -0400 Received: from m0098399.ppops.net (m0098399.ppops.net [127.0.0.1]) by pps.reinject (8.16.0.36/8.16.0.36) with SMTP id 095Le8dY081867; Mon, 5 Oct 2020 17:48:58 -0400 Received: from ppma01dal.us.ibm.com (83.d6.3fa9.ip4.static.sl-reverse.com [169.63.214.131]) by mx0a-001b2d01.pphosted.com with ESMTP id 340aub99rs-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 05 Oct 2020 17:48:58 -0400 Received: from pps.filterd (ppma01dal.us.ibm.com [127.0.0.1]) by ppma01dal.us.ibm.com (8.16.0.42/8.16.0.42) with SMTP id 095Llch7022227; Mon, 5 Oct 2020 21:48:57 GMT Received: from b01cxnp22034.gho.pok.ibm.com (b01cxnp22034.gho.pok.ibm.com [9.57.198.24]) by ppma01dal.us.ibm.com with ESMTP id 33xgx97bw1-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 05 Oct 2020 21:48:57 +0000 Received: from b01ledav006.gho.pok.ibm.com (b01ledav006.gho.pok.ibm.com [9.57.199.111]) by b01cxnp22034.gho.pok.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 095Lmt9W52167116 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 5 Oct 2020 21:48:55 GMT Received: from b01ledav006.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 5712EAC059; Mon, 5 Oct 2020 21:48:55 +0000 (GMT) Received: from b01ledav006.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 7D518AC060; Mon, 5 Oct 2020 21:48:54 +0000 (GMT) Received: from localhost.localdomain (unknown [9.85.170.177]) by b01ledav006.gho.pok.ibm.com (Postfix) with ESMTP; Mon, 5 Oct 2020 21:48:54 +0000 (GMT) Subject: Re: [PATCH v10 11/16] s390/vfio-ap: allow hot plug/unplug of AP resources using mdev device To: Halil Pasic Cc: linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, freude@linux.ibm.com, borntraeger@de.ibm.com, cohuck@redhat.com, mjrosato@linux.ibm.com, alex.williamson@redhat.com, kwankhede@nvidia.com, fiuczy@linux.ibm.com, frankja@linux.ibm.com, david@redhat.com, imbrenda@linux.ibm.com, hca@linux.ibm.com, gor@linux.ibm.com References: <20200821195616.13554-1-akrowiak@linux.ibm.com> <20200821195616.13554-12-akrowiak@linux.ibm.com> <20200928030147.7ee6f494.pasic@linux.ibm.com> <20201005203003.5db3b1eb.pasic@linux.ibm.com> From: Tony Krowiak Message-ID: <75a3779d-f690-caad-cebd-467d1b4c2ff7@linux.ibm.com> Date: Mon, 5 Oct 2020 17:48:53 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.5.0 MIME-Version: 1.0 In-Reply-To: <20201005203003.5db3b1eb.pasic@linux.ibm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US X-TM-AS-GCONF: 00 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.235,18.0.687 definitions=2020-10-05_16:2020-10-05,2020-10-05 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 clxscore=1015 bulkscore=0 phishscore=0 mlxlogscore=999 spamscore=0 lowpriorityscore=0 impostorscore=0 suspectscore=0 adultscore=0 malwarescore=0 priorityscore=1501 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2006250000 definitions=main-2010050153 Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org On 10/5/20 2:30 PM, Halil Pasic wrote: > On Mon, 5 Oct 2020 12:24:39 -0400 > Tony Krowiak wrote: > >> >> On 9/27/20 9:01 PM, Halil Pasic wrote: >>> On Fri, 21 Aug 2020 15:56:11 -0400 >>> Tony Krowiak wrote: >>> >>>> Let's hot plug/unplug adapters, domains and control domains assigned to or >>>> unassigned from an AP matrix mdev device while it is in use by a guest per >>>> the following: >>>> >>>> * When the APID of an adapter is assigned to a matrix mdev in use by a KVM >>>> guest, the adapter will be hot plugged into the KVM guest as long as each >>>> APQN derived from the Cartesian product of the APID being assigned and >>>> the APQIs already assigned to the guest's CRYCB references a queue device >>>> bound to the vfio_ap device driver. >>>> >>>> * When the APID of an adapter is unassigned from a matrix mdev in use by a >>>> KVM guest, the adapter will be hot unplugged from the KVM guest. >>>> >>>> * When the APQI of a domain is assigned to a matrix mdev in use by a KVM >>>> guest, the domain will be hot plugged into the KVM guest as long as each >>>> APQN derived from the Cartesian product of the APQI being assigned and >>>> the APIDs already assigned to the guest's CRYCB references a queue device >>>> bound to the vfio_ap device driver. >>>> >>>> * When the APQI of a domain is unassigned from a matrix mdev in use by a >>>> KVM guest, the domain will be hot unplugged from the KVM guest >>> Hm, I suppose this means that what your guest effectively gets may depend >>> on whether assign_domain or assign_adapter is done first. >>> >>> Suppose we have the queues >>> 0.0 0.1 >>> 1.0 >>> bound to vfio_ap, i.e. 1.1 is missing for a reason different than >>> belonging to the default drivers (for what exact reason no idea). >> I'm not quite sure what you mean be "we have queue". I will >> assume you mean those queues are bound to the vfio_ap >> device driver. > Yes, this is exactly what I've meant. > > >> The only way this could happen is if somebody >> manually unbinds queue 1.1. >> > Assuming that: > 1) every time we observe ap_perm the ap subsystem in in a settled state > (i.e. not in a middle of pushing things left and right > because of an ap_perm change, > 2) the only non-default driver is vfio_ap, and that > 3) queues handle non-operational states by other means than dissapearing > (should be the case with the latest reworks) > I agree what is left is manual unbind, which I lean towards considering > an edge case. > > If this is indeed just about that edge case, maybe we can live with a > simpler algorithm than this one. The simplest algorithm is: * Forego hot plug of an adapter if any APQN derived from the adapter's    APID and the APQIs of the domains assigned to the matrix mdev references a    queue device not bound to the vfio_ap device driver. In your scenario, this    would result in no queues for the guest at 3) despite the fact that 1.0 is bound    to the vfio_ap dd. As you stated, this is an edge case, so maybe this would be sufficient. Do you have any alternative algorithm that makes sense? Also, keep in mind that one of my goals with this design was to avoid leaving the guest without any queues if possible. Maybe that is not a critical requirement. > > >>> Let's suppose we started with the matix containing only adapter >>> 0 (0.) and domain 0 (.0). >>> >>> After echo 1 > assign_adapter && echo 1 > assign_domain we end up with >>> matrix: >>> 0.0 0.1 >>> 1.0 1.1 >>> guest_matrix: >>> 0.0 0.1 >>> while after echo 1 > assign_domain && echo 1 > assign_adapter we end up >>> with: >>> matrix: >>> 0.0 0.1 >>> 1.0 1.1 >>> guest_matrix: >>> 0.0 >>> 0.1 >>> >>> That means, the set of bound queues and the set of assigned resources do >>> not fully determine the set of resources passed through to the guest. >>> >>> Is that a deliberate design choice? >> Yes, it is a deliberate choice to only allow guest access to queues >> represented by queue devices bound to the vfio_ap device driver. >> The idea here is to adhere to the linux device model. >> > This is not what I've asked. My question was about he fact that > reordering assignments gives different results. Well this was kind > of the case before as well, with the notable difference, that in a > past we always had an error. So if a full sequence of assignments could > be performed without an error, than any permutation would be performed > with the exact same result. I'm not sure that the exact same result can be achieved regardless of the order of assignments - other than possibly the simple algorithm I suggested above - it is something I would have to think about some more. Another option is to call the filtering mechanism introduced in patch 8/16 in which case the results will be consistent with the configuration of the shadow_apcb. This would be the same configuration as if the guest were started after the assignment. > > I'm all for only allowing guest access to queues represented by queue > devices bound to the vfio_ap device driver. I'm concerned with the > permutation (and calculus). > >>>> * When the domain number of a control domain is assigned to a matrix mdev >>>> in use by a KVM guest, the control domain will be hot plugged into the >>>> KVM guest. >>>> >>>> * When the domain number of a control domain is unassigned from a matrix >>>> mdev in use by a KVM guest, the control domain will be hot unplugged >>>> from the KVM guest. >>>> >>>> Signed-off-by: Tony Krowiak >>>> --- > [..] > >>>> +static bool vfio_ap_mdev_assign_guest_apid(struct ap_matrix_mdev *matrix_mdev, >>>> + unsigned long apid) >>>> +{ >>>> + unsigned long apqi, apqn; >>>> + >>>> + if (!vfio_ap_mdev_has_crycb(matrix_mdev) || >>>> + !test_bit_inv(apid, (unsigned long *)matrix_dev->info.apm)) >>>> + return false; >>>> + >>>> + if (bitmap_empty(matrix_mdev->shadow_apcb.aqm, AP_DOMAINS)) >>>> + return vfio_ap_mdev_assign_apqis_4_apid(matrix_mdev, apid); >>> Hm. Let's say we have the same situation regarding the bound queues as >>> above but we start with the empty matrix, and do all the assignments >>> while the guest is running. >>> >>> Consider the following sequence of actions. >>> >>> 1) echo 0 > assign_domain >> matrix:            .0 >> guest_matrix: no APQNs >> >>> 2) echo 1 > assign_domain >> matrix:            .0, .1 >> guest_matrix: no APQNs >> >>> 3) echo 1 > assign_adapter >> matrix:           1.0, 1.1 >> guest_matrix: 1.0 >> >>> 4) echo 0 > assign_adapter >> matrix:           0.0, 0.1, 1.0, 1.1 >> guest_matrix: 0.0, 1.0 >>> 5) echo 1 > unassign_adapter >> matrix:           0.0, 0.1 >> guest_matrix: 0.0 >> >>> I understand that at 3), because >>> bitmap_empty(matrix_mdev->shadow_apcb.aqm)we would end up with a shadow >>> aqm containing just domain 0, as queue 1.1 ain't bound to us. >> True >> >>> Thus at the end we would have >>> matrix: >>> 0.0 0.1 >>> guest_matrix: >>> 0.0 >> At the end I had: >> matrix:            0.0, 0.1 >> guest_matrix: 0.0 >> >>> And if we add in an adapter 2. into the mix with the queues 2.0 and 2.1 >>> then after >>> 6) echo 2 > assign_adapter >>> we get >>> Thus at the end we would have >>> matrix: >>> 0.0 0.1 >>> 2.0 2.1 >>> guest_matrix: >>> 0.0 >>> 2.0 >>> >>> This looks very quirky to me. Did I read the code wrong? Opinions? >> You read the code correctly and I agree, this is a bit quirky. I would say >> that after adding adapter 2, we should end up with guest matrix: >> 0.0, 0.1 >> 2.0, 2.1 >> >> If you agree, I'll make the adjustment. >> > I do agree, but maybe we should discuss what adjustments do you have in > mind. > > [..] > >>>> +static bool vfio_ap_mdev_unassign_guest_apid(struct ap_matrix_mdev *matrix_mdev, >>>> + unsigned long apid) >>>> +{ >>>> + if (vfio_ap_mdev_has_crycb(matrix_mdev)) { >>>> + if (test_bit_inv(apid, matrix_mdev->shadow_apcb.apm)) { >>>> + clear_bit_inv(apid, matrix_mdev->shadow_apcb.apm); >>>> + >>>> + /* >>>> + * If there are no APIDs assigned to the guest, then >>>> + * the guest will not have access to any queues, so >>>> + * let's also go ahead and unassign the APQIs. Keeping >>>> + * them around may yield unpredictable results during >>>> + * a probe that is not related to a host AP >>>> + * configuration change (i.e., an AP adapter is >>>> + * configured online). >>>> + */ >>> I don't quite understand this comment. Clearing out the other mask when >>> the other one becomes empty, does allow us to recover the full possible guest >>> matrix in the scenario described above. I don't see any shadow >>> manipulation in the probe handler at this stage. Are we maybe >>> talking about the same effect as I described for assign? >> Patch 15/16 is for the probe. >> > I still don't understand the logic, but I guess we want to make > adjustments anyways, so maybe I don't have to. > > Regards, > Halil