Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp880226imu; Fri, 4 Jan 2019 08:50:11 -0800 (PST) X-Google-Smtp-Source: ALg8bN5U2T3P8KbRh54x3j9fUjS0BSlfgpAYUZxAwEdlQZUU7Xk3txM8PB6xaeMr7yFTH8Vps7R1 X-Received: by 2002:a63:4e15:: with SMTP id c21mr2269969pgb.50.1546620610965; Fri, 04 Jan 2019 08:50:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546620610; cv=none; d=google.com; s=arc-20160816; b=ovbzKXiASB0i0+vm7Kwo2MKzSErRrY4UAZNHI2FDKdW2BlCvxJmwce4BFNN/kiFnqX 9uybrksQECP0yQyMtfYMOm8jYgqj8ck2DhaBxjV2gAGvkj/shOdVKSAQkD0t5TcG4jKv 4K/0j2An1gPnypKY3qrYBzvCcrkZoz+nSL0aQgwIQ3W4ThTBc5auXAG5HroT4OYSU/tW XR4NVIkvXUBp/g2ulNQ3WxoUh54+Fkid3sJP9nSX7e/O/2QAeh8VXcdoQfF+o+Y5asXY IYK2x8YSlEUsujUmjlBC/m7DPl/N3SFIi38I/kGcKW2CtgCn6psPY+aYIOI1Rag6tnwJ kQmw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=V0LRdtCNgoMiILTjdwzb479cNWhmZGP1oPNl1RQ+hUc=; b=JUXy1wR3U4Fc5/BaI4tt5QXY92DsP6yg6PCQbpkt/5xd0xc7bJeNLgkBVhpeuwJXP5 oYFAyyXsvUQZydzXVgIyY95Nk2X/lDD4SkT9uBOgLr7atplVFxg1/3UGqBBiYMK3qWzi JCJ2hd5QEHpKXI5kA4h7x4G3xw9RqQ5fFRHZokixCf/O1JG8hFl2J2EuA8t3cihsLlwQ 1xISMJQm0Xa9dX91s9gFcr959ieuRL24DQb1c6JC7+J0NPKOGTREUqo++79iQ2Le88lp pCeSYzPYu96IgUI3xWpJkZBwCpUuUyJoIb1oKFHwBXlOeR+LTp6rnq3RT2V33WKVUc1y dR4g== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a26si36871552pgl.282.2019.01.04.08.49.31; Fri, 04 Jan 2019 08:50:10 -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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727663AbfADNTP (ORCPT + 99 others); Fri, 4 Jan 2019 08:19:15 -0500 Received: from mx1.redhat.com ([209.132.183.28]:42430 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726069AbfADNTP (ORCPT ); Fri, 4 Jan 2019 08:19:15 -0500 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 9A2FF42BD3; Fri, 4 Jan 2019 13:19:14 +0000 (UTC) Received: from gondolin (dhcp-192-187.str.redhat.com [10.33.192.187]) by smtp.corp.redhat.com (Postfix) with ESMTP id 4F843600D6; Fri, 4 Jan 2019 13:19:09 +0000 (UTC) Date: Fri, 4 Jan 2019 14:19:06 +0100 From: Cornelia Huck To: Pierre Morel Cc: Michael Mueller , KVM Mailing List , Linux-S390 Mailing List , linux-kernel@vger.kernel.org, Martin Schwidefsky , Heiko Carstens , Christian Borntraeger , Janosch Frank , David Hildenbrand , Halil Pasic Subject: Re: [PATCH v5 10/15] KVM: s390: add functions to (un)register GISC with GISA Message-ID: <20190104141836.0ca98a77.cohuck@redhat.com> In-Reply-To: References: <20181219191756.57973-1-mimu@linux.ibm.com> <20181219191756.57973-11-mimu@linux.ibm.com> Organization: Red Hat GmbH MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.30]); Fri, 04 Jan 2019 13:19:14 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2 Jan 2019 18:29:00 +0100 Pierre Morel wrote: > On 19/12/2018 20:17, Michael Mueller wrote: > > Add the IAM (Interruption Alert Mask) to the architecture specific > > kvm struct. This mask in the GISA is used to define for which ISC > > a GIB alert can be issued. > > > > The functions kvm_s390_gisc_register() and kvm_s390_gisc_unregister() > > are used to (un)register a GISC (guest ISC) with a virtual machine and > > its GISA. > > > > Upon successful completion, kvm_s390_gisc_register() returns the > > ISC to be used for GIB alert interruptions. A negative return code > > indicates an error during registration. > > > > Theses functions will be used by other adapter types like AP and PCI to > > request pass-through interruption support. > > > > Signed-off-by: Michael Mueller > > --- > > arch/s390/include/asm/kvm_host.h | 9 ++++++ > > arch/s390/kvm/interrupt.c | 66 ++++++++++++++++++++++++++++++++++++++++ > > 2 files changed, 75 insertions(+) > > > > +int kvm_s390_gisc_register(struct kvm *kvm, u32 gisc) > > +{ > > + if (!kvm->arch.gib_in_use) > > + return -ENODEV; > > + if (gisc > MAX_ISC) > > + return -ERANGE; > > + > > + spin_lock(&kvm->arch.iam_ref_lock); > > + if (kvm->arch.iam_ref_count[gisc] == 0) > > + kvm->arch.iam |= 0x80 >> gisc; > > + kvm->arch.iam_ref_count[gisc]++; > > + if (kvm->arch.iam_ref_count[gisc] == 1) > > + set_iam(kvm->arch.gisa, kvm->arch.iam); > > testing the set_iam return value? > Even it should be fine if the caller works correctly, this is done > before GISA is ever used. My feeling is that checking the return code is a good idea, even if it Should Never Fail(tm). > > > + spin_unlock(&kvm->arch.iam_ref_lock); > > + > > + return gib->nisc; > > +} > > +EXPORT_SYMBOL_GPL(kvm_s390_gisc_register); > > + > > +int kvm_s390_gisc_unregister(struct kvm *kvm, u32 gisc) > > +{ > > + int rc = 0; > > + > > + if (!kvm->arch.gib_in_use) > > + return -ENODEV; > > + if (gisc > MAX_ISC) > > + return -ERANGE; > > + > > + spin_lock(&kvm->arch.iam_ref_lock); > > + if (kvm->arch.iam_ref_count[gisc] == 0) { > > + rc = -EINVAL; > > + goto out; > > + } > > + kvm->arch.iam_ref_count[gisc]--; > > + if (kvm->arch.iam_ref_count[gisc] == 0) { > > + kvm->arch.iam &= ~(0x80 >> gisc); > > + set_iam(kvm->arch.gisa, kvm->arch.iam); Any chance of this function failing here? If yes, would there be any implications? > > + } > > +out: > > + spin_unlock(&kvm->arch.iam_ref_lock); > > + > > + return rc; > > +} > > +EXPORT_SYMBOL_GPL(kvm_s390_gisc_unregister); > > + > > void kvm_s390_gib_destroy(void) > > { > > if (!gib) > > > >