Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp6977ybt; Tue, 23 Jun 2020 13:50:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw5uPBPbJWuifvSALqGHSug4vkTQjMxuZ1ILBPoxHhmTk5NdN5yP13Rony2SEaFalQ0eqn8 X-Received: by 2002:a17:906:1cd3:: with SMTP id i19mr21167852ejh.321.1592945419816; Tue, 23 Jun 2020 13:50:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592945419; cv=none; d=google.com; s=arc-20160816; b=eV/t+w+hoZYw2lzQ8vh0oWY4StmqOEbD1qmXiJZqN8iVtD/ek05nHTbw2dzID/jiVU uvDAu72COGBSa9KLQnZO42tYQP62zSFfWXsFHVrShI2PJNTLiokU/tZQF/mTOGn9Wsdj utAVegW+Aj1J3uW9cbSbf8neWEi8ZfO3jPLbbA9MzfQNTgBlB75VnmbbDp9lt8BN61ct vZM+y+N/5uqnTKAAu29Udm57Bq+fvELeLn8X+RT2iWf4mePv9eKK977jL95BNNVV9C3/ 4tpoLXtdZgipftAmzI1WVpbV+IUtb7sumsZIaXdrqWeIZNBzh1TbABNnoKYbNTMNiLLt 81Sw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=YOCTBaf9s+CEjDAPDb83gjAfbzsCgYhKJENat1XxQkA=; b=S995pfXtHylyDR9P+h9fc/uiBvRKu2sLAx08PQ70jev/jTniHKD0e04cbLqPdyHxLi 8Rmdb1HpX8h3AX7jCYbgkoGuNDlrB2VNhbTom4DY7HAPIR19/0ecOECWc2LT6xwWz++b MRjcWavtSK5VAq34Vj8P+xezAqtt1b5oo7osEifKJB/oXBGwChiJ/eJDiNIblbRv4/Gm rWhqLFyMopaBCN849XGkS5lRDkBraKfD+faykNWyyQ8qAUEkjrT0KMqNTxA9i4efTCXh ZctebjHPXDTJ2//iRnEYo0ixTzKTNkl6ORA0d/SDKojnl13GgAfEo2Xu50MmAve1rWpR /+bg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pHrHIlAi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c11si5727242edr.502.2020.06.23.13.49.56; Tue, 23 Jun 2020 13:50:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=pHrHIlAi; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2392847AbgFWUqa (ORCPT + 99 others); Tue, 23 Jun 2020 16:46:30 -0400 Received: from mail.kernel.org ([198.145.29.99]:44256 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2392837AbgFWUqX (ORCPT ); Tue, 23 Jun 2020 16:46:23 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 931FA20781; Tue, 23 Jun 2020 20:46:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592945183; bh=Ci+2swfFDkzxgZVxS88vGgMTtLNa6R7R5ssmpAF3+EU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pHrHIlAiUBgTLHMmCzm/VH/z8eyQmK2+nu1qeAntUT9DjUVuO9VYCl+krO6wCZltR YsFnt2LntRKpsLx0oo14OyIkkqkrQyqXuUWILQYM4E9cVm2A0HbOwjDFLnG+BLoY0H FHrW2yr8+U9VjEGWHS1PIPt5kRMcEEwwTESo/5Pw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Julian Wiedmann , Benjamin Block , Vasily Gorbik , Sasha Levin Subject: [PATCH 4.14 040/136] s390/qdio: put thinint indicator after early error Date: Tue, 23 Jun 2020 21:58:16 +0200 Message-Id: <20200623195305.669742935@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200623195303.601828702@linuxfoundation.org> References: <20200623195303.601828702@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Julian Wiedmann [ Upstream commit 75e82bec6b2622c6f455b7a543fb5476a5d0eed7 ] qdio_establish() calls qdio_setup_thinint() via qdio_setup_irq(). If the subsequent qdio_establish_thinint() fails, we miss to put the DSCI again. Thus the DSCI isn't available for re-use. Given enough of such errors, we could end up with having only the shared DSCI available. Merge qdio_setup_thinint() into qdio_establish_thinint(), and deal with such an error internally. Fixes: 779e6e1c724d ("[S390] qdio: new qdio driver.") Signed-off-by: Julian Wiedmann Reviewed-by: Benjamin Block Signed-off-by: Vasily Gorbik Signed-off-by: Sasha Levin --- drivers/s390/cio/qdio.h | 1 - drivers/s390/cio/qdio_setup.c | 1 - drivers/s390/cio/qdio_thinint.c | 14 ++++++++------ 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/drivers/s390/cio/qdio.h b/drivers/s390/cio/qdio.h index 29d6b5222f1cd..0f8d13288611e 100644 --- a/drivers/s390/cio/qdio.h +++ b/drivers/s390/cio/qdio.h @@ -377,7 +377,6 @@ static inline int multicast_outbound(struct qdio_q *q) extern u64 last_ai_time; /* prototypes for thin interrupt */ -void qdio_setup_thinint(struct qdio_irq *irq_ptr); int qdio_establish_thinint(struct qdio_irq *irq_ptr); void qdio_shutdown_thinint(struct qdio_irq *irq_ptr); void tiqdio_add_input_queues(struct qdio_irq *irq_ptr); diff --git a/drivers/s390/cio/qdio_setup.c b/drivers/s390/cio/qdio_setup.c index d0090c5c88e74..a64615a10352b 100644 --- a/drivers/s390/cio/qdio_setup.c +++ b/drivers/s390/cio/qdio_setup.c @@ -479,7 +479,6 @@ int qdio_setup_irq(struct qdio_initialize *init_data) setup_queues(irq_ptr, init_data); setup_qib(irq_ptr, init_data); - qdio_setup_thinint(irq_ptr); set_impl_params(irq_ptr, init_data->qib_param_field_format, init_data->qib_param_field, init_data->input_slib_elements, diff --git a/drivers/s390/cio/qdio_thinint.c b/drivers/s390/cio/qdio_thinint.c index 831a3a0a2837b..4dc1108069d4a 100644 --- a/drivers/s390/cio/qdio_thinint.c +++ b/drivers/s390/cio/qdio_thinint.c @@ -270,17 +270,19 @@ int __init tiqdio_register_thinints(void) int qdio_establish_thinint(struct qdio_irq *irq_ptr) { + int rc; + if (!is_thinint_irq(irq_ptr)) return 0; - return set_subchannel_ind(irq_ptr, 0); -} -void qdio_setup_thinint(struct qdio_irq *irq_ptr) -{ - if (!is_thinint_irq(irq_ptr)) - return; irq_ptr->dsci = get_indicator(); DBF_HEX(&irq_ptr->dsci, sizeof(void *)); + + rc = set_subchannel_ind(irq_ptr, 0); + if (rc) + put_indicator(irq_ptr->dsci); + + return rc; } void qdio_shutdown_thinint(struct qdio_irq *irq_ptr) -- 2.25.1