Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp869866ybb; Wed, 8 Apr 2020 11:29:11 -0700 (PDT) X-Google-Smtp-Source: APiQypLEUXUQclG6w/p2Hcs38M1Y5bmiFWgtDGzvNQ14FcfeZNt4muXE2RzRvlz8/SEGwMblRFbV X-Received: by 2002:a05:6808:8:: with SMTP id u8mr3370014oic.37.1586370550743; Wed, 08 Apr 2020 11:29:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586370550; cv=none; d=google.com; s=arc-20160816; b=dzHEY/aC+nFbqfRSOf2bKQ2mUIdVEQnhATCjoKRSPL9W6xCTFjMKz+09hzbmUYibwM Lf4AKkBOTkrx8otb5La64DlXlx+CXT9TtEH0qkalanQbkQ9P1VTRQiAxcFeJoLcLlz/9 3/1Ivj/e7e1ixD399A1bo0PLCZYbkECUSwoD6SOipPJIn6MLHV55KI7Wpi4ovNTkNk8T LsTKAnZX85iL9Y5yStNJ2EzyTNOHaKki8bwmKsCIlIrEXXvDiqOUSmyJMhZB97STnLdG +3vPjj8Ea59SD+DmBX/XqvYbYfNBNLyMNZKl/PQEDEFBW0i9gIa3s42i4BowBQwO6+Nd 63/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=tzBXC8MKkxbrJSTY8tu3nK9ekJI/m7fEjDFS2jjh3TI=; b=shNe+gVHV5M2LhMocWjDQZZ+Wuy3DisC5Pb/8wJ1vZYTZNtproMLA/C5VvSX6NNTJ8 f/dMyv56oH1RC6SSgHBqv5IH9oZ6/aSwRLAyOXhEbZOSMiJsFrNN3QOX1bUV+kBHE2wl 1fNdo1GMZpDpqI+zqmz0loLzGBREbGN7hdd/XFJvbv7M2Qx6++z1SI+pyZiy0Fx0z/gU Y35g4WpHI6Xr2u8cQPl+tVOLoL/yzbwfiU5nOaIsUk3Yh0iQgNlufTuXMOOt13mDhzWv Tl04HhzEWO/i+CipB06WntqbjuXujimgtZrdP2NPQQ4fBYL3i9OeAcuagHpAaF+jOyUR tI6g== 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 z62si2747183oiz.23.2020.04.08.11.28.57; Wed, 08 Apr 2020 11:29:10 -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 S1728734AbgDHQeW (ORCPT + 99 others); Wed, 8 Apr 2020 12:34:22 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:21070 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726891AbgDHQeV (ORCPT ); Wed, 8 Apr 2020 12:34:21 -0400 Received: from pps.filterd (m0098394.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 038GWwkS093586; Wed, 8 Apr 2020 12:34:20 -0400 Received: from pps.reinject (localhost [127.0.0.1]) by mx0a-001b2d01.pphosted.com with ESMTP id 3091yktf7e-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Wed, 08 Apr 2020 12:34:20 -0400 Received: from m0098394.ppops.net (m0098394.ppops.net [127.0.0.1]) by pps.reinject (8.16.0.36/8.16.0.36) with SMTP id 038GYE1D100607; Wed, 8 Apr 2020 12:34:20 -0400 Received: from ppma03dal.us.ibm.com (b.bd.3ea9.ip4.static.sl-reverse.com [169.62.189.11]) by mx0a-001b2d01.pphosted.com with ESMTP id 3091yktf72-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Wed, 08 Apr 2020 12:34:20 -0400 Received: from pps.filterd (ppma03dal.us.ibm.com [127.0.0.1]) by ppma03dal.us.ibm.com (8.16.0.27/8.16.0.27) with SMTP id 038GV6Fc003735; Wed, 8 Apr 2020 16:34:19 GMT Received: from b01cxnp23032.gho.pok.ibm.com (b01cxnp23032.gho.pok.ibm.com [9.57.198.27]) by ppma03dal.us.ibm.com with ESMTP id 3091me02nc-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Wed, 08 Apr 2020 16:34:19 +0000 Received: from b01ledav005.gho.pok.ibm.com (b01ledav005.gho.pok.ibm.com [9.57.199.110]) by b01cxnp23032.gho.pok.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 038GYHxr54198728 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Wed, 8 Apr 2020 16:34:17 GMT Received: from b01ledav005.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 4ABC6AE060; Wed, 8 Apr 2020 16:34:17 +0000 (GMT) Received: from b01ledav005.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 7B144AE05C; Wed, 8 Apr 2020 16:34:16 +0000 (GMT) Received: from cpe-172-100-173-215.stny.res.rr.com (unknown [9.85.151.56]) by b01ledav005.gho.pok.ibm.com (Postfix) with ESMTP; Wed, 8 Apr 2020 16:34:16 +0000 (GMT) Subject: Re: [PATCH v7 01/15] s390/vfio-ap: store queue struct in hash table for quick access To: Cornelia Huck Cc: linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, freude@linux.ibm.com, borntraeger@de.ibm.com, mjrosato@linux.ibm.com, pmorel@linux.ibm.com, pasic@linux.ibm.com, alex.williamson@redhat.com, kwankhede@nvidia.com, jjherne@linux.ibm.com, fiuczy@linux.ibm.com References: <20200407192015.19887-1-akrowiak@linux.ibm.com> <20200407192015.19887-2-akrowiak@linux.ibm.com> <20200408124801.2d61bc5b.cohuck@redhat.com> <20200408182750.6d9443f6.cohuck@redhat.com> From: Tony Krowiak Message-ID: Date: Wed, 8 Apr 2020 12:34:15 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 MIME-Version: 1.0 In-Reply-To: <20200408182750.6d9443f6.cohuck@redhat.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.138,18.0.676 definitions=2020-04-07_10:2020-04-07,2020-04-07 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 malwarescore=0 spamscore=0 clxscore=1015 mlxscore=0 suspectscore=3 bulkscore=0 adultscore=0 phishscore=0 priorityscore=1501 impostorscore=0 mlxlogscore=999 lowpriorityscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2003020000 definitions=main-2004080127 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/8/20 12:27 PM, Cornelia Huck wrote: > On Wed, 8 Apr 2020 11:38:07 -0400 > Tony Krowiak wrote: > >> On 4/8/20 6:48 AM, Cornelia Huck wrote: >>> On Tue, 7 Apr 2020 15:20:01 -0400 >>> Tony Krowiak wrote: >>> >>>> Rather than looping over potentially 65535 objects, let's store the >>>> structures for caching information about queue devices bound to the >>>> vfio_ap device driver in a hash table keyed by APQN. >>> This also looks like a nice code simplification. >>> >>>> Signed-off-by: Tony Krowiak >>>> --- >>>> drivers/s390/crypto/vfio_ap_drv.c | 28 +++------ >>>> drivers/s390/crypto/vfio_ap_ops.c | 90 ++++++++++++++------------- >>>> drivers/s390/crypto/vfio_ap_private.h | 10 ++- >>>> 3 files changed, 60 insertions(+), 68 deletions(-) >>>> >>> (...) >>>> - */ >>>> -static struct vfio_ap_queue *vfio_ap_get_queue( >>>> - struct ap_matrix_mdev *matrix_mdev, >>>> - int apqn) >>>> +struct vfio_ap_queue *vfio_ap_get_queue(unsigned long apqn) >>>> { >>>> struct vfio_ap_queue *q; >>>> - struct device *dev; >>>> - >>>> - if (!test_bit_inv(AP_QID_CARD(apqn), matrix_mdev->matrix.apm)) >>>> - return NULL; >>>> - if (!test_bit_inv(AP_QID_QUEUE(apqn), matrix_mdev->matrix.aqm)) >>>> - return NULL; >>> These were just optimizations and therefore can be dropped now? >> The purpose of this function has changed from its previous incarnation. >> This function was originally called from the handle_pqap() function and >> served two purposes: It retrieved the struct vfio_ap_queue as driver data >> and linked the matrix_mdev to theĀ  vfio_ap_queue. The linking of the >> matrix_mdev and the vfio_ap_queue are now done when queue devices >> are probed and when adapters and domains are assigned; so now, the >> handle_pqap() function calls this function to retrieve both the >> vfio_ap_queue as well as the matrix_mdev to which it is linked. >> Consequently, >> the above code is no longer needed. > Thanks for the explanation, that makes sense. > >>> >>>> - >>>> - dev = driver_find_device(&matrix_dev->vfio_ap_drv->driver, NULL, >>>> - &apqn, match_apqn); >>>> - if (!dev) >>>> - return NULL; >>>> - q = dev_get_drvdata(dev); >>>> - q->matrix_mdev = matrix_mdev; >>>> - put_device(dev); >>>> >>>> - return q; >>>> + hash_for_each_possible(matrix_dev->qtable, q, qnode, apqn) { >>>> + if (q && (apqn == q->apqn)) >>>> + return q; >>>> + } >>> Do we need any serialization here? Previously, the driver core made >>> sure we could get a reference only if the device was still registered; >>> not sure if we need any further guarantees now. >> The vfio_ap_queue structs are created when the queue device is >> probed and removed when the queue device is removed. > Ok, so anything further is not needed. > >>> >>>> + >>>> + return NULL; >>>> } >>>> >>>> /** >>> (...) >>> > Looks good to me, then. With vfio_ap_get_queue made static and the > kerneldoc restored/updated: Already done, thanks for the review. > > Reviewed-by: Cornelia Huck >