Received: by 2002:a05:7412:a9a2:b0:e2:908c:2ebd with SMTP id o34csp997955rdh; Fri, 27 Oct 2023 01:27:13 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGfyomaDi9Mc2p4ZseZOjqj9mnpTWXSOk1gDwEUHGzD2Mh+9MEKfZEYRqsl80PoB5Gc3QhZ X-Received: by 2002:a25:ef50:0:b0:d9c:a3b8:f044 with SMTP id w16-20020a25ef50000000b00d9ca3b8f044mr2071464ybm.27.1698395232805; Fri, 27 Oct 2023 01:27:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698395232; cv=none; d=google.com; s=arc-20160816; b=tZgcIN65UwCMFYhACbxx8Iz1vJP9VmFnmqFtV1Kk/vpVj0/8a+pS4mxeNdhIrFNRpd hxb3YHYca+SJ95jy2OF2aOpGwKhPQBDMqlf9WRUke379PHfcpABSMK4wcQC/mOc12z+V 2lXCcGtV9hyIcRcK1LnSyzLTMWFNtnmmg6aTQ/fSfx/Q3cnF/AMZnMVDlZDl1igB9EqO A5wenl6zq6uvvN0/mISmhFdw8vkv9w7Q4tSsOlQCo2o11bHDGWqty5MR1eR59LaxKXSb pOvobFeNZq6QoffAF9BAiH7vGaSvzOOkxvwzSE7e56KnBG8KJ7DFu90nNcjsEI6P/lj0 nWmw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:message-id:references :in-reply-to:mail-reply-to:reply-to:subject:cc:to:from:date :mime-version:dkim-signature; bh=Ydc/j18p3b7EHQ/VYDnN7DJ8GH9rECYSsKAj2yxuRrQ=; fh=sylpO9/vlyzjxOz6CBRy2cjxZYDa2A/ZAulDhpjBEUE=; b=zjycxnss2AYDp8jeqXoaPnR1kGeUmWH/EdT6LK8jClZ0vLNbGkjadG44pVGyb9FKqK V9k4gdhKYdzEEeOWi4gcBLK6L5ZIDhVxDknCyzhADATFcUM0MMFR2hoA0tdG1YfEo2AA +R66Lr6m+r/ZZAZkVx8LJ8VOCMUNz6KHh3ptkgUAvV0cYHUQG8wmn0MYUJ/huE98xQHe 7vLhwiNfzADaVrAaXG1uK+yZV5jEKRQfGcn2JUlRUkIhvn6V76iKpYMLfjhcqXNm2J2N CU4/Uszj7ReWxBfF+KmGLUl2mUh5hYo87e5v23Et3XsAC8fESMn/0rImOkB0GD6n8MLk QDTA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=k66R5I55; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from agentk.vger.email (agentk.vger.email. [23.128.96.32]) by mx.google.com with ESMTPS id n66-20020a254045000000b00d7b9ce0c8cbsi1800850yba.532.2023.10.27.01.27.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 27 Oct 2023 01:27:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) client-ip=23.128.96.32; Authentication-Results: mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=k66R5I55; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=NONE dis=NONE) header.from=ibm.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id 7889F8073DCC; Fri, 27 Oct 2023 01:26:17 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235098AbjJ0I0H (ORCPT + 99 others); Fri, 27 Oct 2023 04:26:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47036 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345539AbjJ0I0C (ORCPT ); Fri, 27 Oct 2023 04:26:02 -0400 Received: from mx0b-001b2d01.pphosted.com (mx0b-001b2d01.pphosted.com [148.163.158.5]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 422891AD; Fri, 27 Oct 2023 01:25:59 -0700 (PDT) Received: from pps.filterd (m0360072.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 39R85X43005432; Fri, 27 Oct 2023 08:25:58 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=mime-version : date : from : to : cc : subject : reply-to : in-reply-to : references : message-id : content-type : content-transfer-encoding; s=pp1; bh=Ydc/j18p3b7EHQ/VYDnN7DJ8GH9rECYSsKAj2yxuRrQ=; b=k66R5I553ezE4knFNEcqmh3oSuHjdXdaM3AV1isaoW7CI+h3BK+kPzpAIfH53POJxwH3 NjcTuA+WbcO9n0ceR/qnTYltbHI5Ts25YeyqeIaq3e+Z7blpiqyyyiqkoYfGzFy1aMfX 8AavoLfekBiyM+NqyJ2rbkNdYEVA4JERyQkOhGAhi/T2zM9DEE1DUG2023j6bIQSlSxH 5ywAWepNFTaIib4UFh3nSdErfzUmVicq7ojh3T2wkp1WWVWx94Ox2p2QiTkCIAzIzn/u 4rrTLBJ/ynUuviRDTUW132NDGcM+8wgKQuRvXwUkhur3kWf0mzapg3JJuD0NXldo97+F Lg== Received: from pps.reinject (localhost [127.0.0.1]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 3u09cyrnmk-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 27 Oct 2023 08:25:58 +0000 Received: from m0360072.ppops.net (m0360072.ppops.net [127.0.0.1]) by pps.reinject (8.17.1.5/8.17.1.5) with ESMTP id 39R85VFS005360; Fri, 27 Oct 2023 08:25:57 GMT Received: from ppma21.wdc07v.mail.ibm.com (5b.69.3da9.ip4.static.sl-reverse.com [169.61.105.91]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 3u09cyrnkx-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 27 Oct 2023 08:25:57 +0000 Received: from pps.filterd (ppma21.wdc07v.mail.ibm.com [127.0.0.1]) by ppma21.wdc07v.mail.ibm.com (8.17.1.19/8.17.1.19) with ESMTP id 39R7phEO021554; Fri, 27 Oct 2023 08:25:57 GMT Received: from smtprelay04.dal12v.mail.ibm.com ([172.16.1.6]) by ppma21.wdc07v.mail.ibm.com (PPS) with ESMTPS id 3tywqrbrbk-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 27 Oct 2023 08:25:57 +0000 Received: from smtpav06.wdc07v.mail.ibm.com (smtpav06.wdc07v.mail.ibm.com [10.39.53.233]) by smtprelay04.dal12v.mail.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 39R8PtYd8651374 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Fri, 27 Oct 2023 08:25:56 GMT Received: from smtpav06.wdc07v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id B090058055; Fri, 27 Oct 2023 08:25:55 +0000 (GMT) Received: from smtpav06.wdc07v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id C16225803F; Fri, 27 Oct 2023 08:25:54 +0000 (GMT) Received: from ltc.linux.ibm.com (unknown [9.5.196.140]) by smtpav06.wdc07v.mail.ibm.com (Postfix) with ESMTP; Fri, 27 Oct 2023 08:25:54 +0000 (GMT) MIME-Version: 1.0 Date: Fri, 27 Oct 2023 10:25:54 +0200 From: Harald Freudenberger To: Tony Krowiak Cc: linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, jjherne@linux.ibm.com, pasic@linux.ibm.com, borntraeger@linux.ibm.com, frankja@linux.ibm.com, imbrenda@linux.ibm.com, david@redhat.com, mjrosato@linux.ibm.com Subject: Re: [PATCH v3 2/3] s390/vfio-ap: set status response code to 06 on gisc registration failure Reply-To: freude@linux.ibm.com Mail-Reply-To: freude@linux.ibm.com In-Reply-To: <20231026183250.254432-3-akrowiak@linux.ibm.com> References: <20231026183250.254432-1-akrowiak@linux.ibm.com> <20231026183250.254432-3-akrowiak@linux.ibm.com> Message-ID: X-Sender: freude@linux.ibm.com Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit X-TM-AS-GCONF: 00 X-Proofpoint-GUID: WK9z_048pRAA6Uu47XJJisIS8aaRAfUM X-Proofpoint-ORIG-GUID: CkPyB9-wDSfB82hIVAlCbVBQIlDjRrQf X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.987,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2023-10-27_06,2023-10-26_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 bulkscore=0 clxscore=1011 lowpriorityscore=0 adultscore=0 spamscore=0 priorityscore=1501 mlxlogscore=999 impostorscore=0 malwarescore=0 suspectscore=0 mlxscore=0 phishscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2310240000 definitions=main-2310270071 X-Spam-Status: No, score=-0.8 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (agentk.vger.email [0.0.0.0]); Fri, 27 Oct 2023 01:26:17 -0700 (PDT) On 2023-10-26 20:32, Tony Krowiak wrote: > From: Anthony Krowiak > > The interception handler for the PQAP(AQIC) command calls the > kvm_s390_gisc_register function to register the guest ISC with the > channel > subsystem. If that call fails, the status response code 08 - indicating > Invalid ZONE/GISA designation - is returned to the guest. This response > code does not make sense because the non-zero return code from the > kvm_s390_gisc_register function can be due one of two things: Either > the > ISC passed as a parameter by the guest to the PQAP(AQIC) command is > greater > than the maximum ISC value allowed, or the guest is not using a GISA. > > Since this scenario is very unlikely to happen and there is no status > response code to indicate an invalid ISC value, let's set the > response code to 06 indicating 'Invalid address of AP-queue > notification > byte'. While this is not entirely accurate, it is better than > indicating > that the ZONE/GISA designation is invalid which is something the guest > can do nothing about since those values are set by the hypervisor. > > Signed-off-by: Anthony Krowiak > Suggested-by: Halil Pasic > --- > drivers/s390/crypto/vfio_ap_ops.c | 6 +++--- > 1 file changed, 3 insertions(+), 3 deletions(-) > > diff --git a/drivers/s390/crypto/vfio_ap_ops.c > b/drivers/s390/crypto/vfio_ap_ops.c > index 9cb28978c186..25d7ce2094f8 100644 > --- a/drivers/s390/crypto/vfio_ap_ops.c > +++ b/drivers/s390/crypto/vfio_ap_ops.c > @@ -393,8 +393,8 @@ static int ensure_nib_shared(unsigned long addr, > struct gmap *gmap) > * Register the guest ISC to GIB interface and retrieve the > * host ISC to issue the host side PQAP/AQIC > * > - * Response.status may be set to AP_RESPONSE_INVALID_ADDRESS in case > the > - * vfio_pin_pages failed. > + * status.response_code may be set to AP_RESPONSE_INVALID_ADDRESS in > case the > + * vfio_pin_pages or kvm_s390_gisc_register failed. > * > * Otherwise return the ap_queue_status returned by the ap_aqic(), > * all retry handling will be done by the guest. > @@ -458,7 +458,7 @@ static struct ap_queue_status > vfio_ap_irq_enable(struct vfio_ap_queue *q, > __func__, nisc, isc, q->apqn); > > vfio_unpin_pages(&q->matrix_mdev->vdev, nib, 1); > - status.response_code = AP_RESPONSE_INVALID_GISA; > + status.response_code = AP_RESPONSE_INVALID_ADDRESS; > return status; > } Interesting ... The INVALID_GISA is handled in the default arm of the switch in ap_queue.c but the INVALID_ADDRESS is handled as irq enablement failed. So this change fits more to the current AP bus code. Thanks Reviewed-by: Harald Freudenberger