Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3519326pxf; Mon, 15 Mar 2021 11:21:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxGfFEWGPEUUGoFjMPqdVXpc5UWEX9LujEQpKguIU5YaxLZJd6irC7j3Qn09QYHohpksfza X-Received: by 2002:a17:906:39a:: with SMTP id b26mr25654647eja.158.1615832474617; Mon, 15 Mar 2021 11:21:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615832474; cv=none; d=google.com; s=arc-20160816; b=Zyu7ZK5OP35XQNFpLXklTskc9uqJKUtNPmhZNtpDm75qJdm7ORps7kho/8TgMrkQfK PVYeqvv/GxiVRtjajerkKc/gdfqE1CmSRFcIs2MbYUewN0Dy6qqTVdM9J0N98yaYBbmQ MOCbK3LHXFBgKtAQLcwZYGiK2F61LqDGNmFbNBiKY/tjEZq3vXdRVKYQpD7R6sBCOuOn P7pp3/3axLgPPFN0KWIexvjcTjNk84jAf1eAHaFLGLETJBEeDGgXwNsCtaCrHlpDYtSn okj8LHf05T4GtBKhOva5gFAz9Egt8d+5SFbwHvHpl7f6XAUVLIndpukSAwRbrLfvG1Ym b8HQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=FWGS3LJc0Ox7n5sAg80C5VrBIUDpBKACb1VgyUVIIL0=; b=ejHk1piTy1ldp6slgCXy2f85gmiAn0bdJe31Rix0yJ9mZAsHujey47AW6GXSTNFX55 TFQriMgZhKSTuitvGTOFjo2QGSi+tel4yBE2Q9fhqIWPes99zmkPmORcfWbZLhKSNg2Z LyCMgAfXu7oRSnleI0Ud39zB6WVvUi4XdCaFICJtVavwf5f82LZAyJOFUe8oTfc1nBNm LGf+4g08hCEFsNKhf3/LmDTlH+dvFjnYuLi4oI0jjze8LMuImf7BKOwFID/HAEv++IDx vieND9V5PnNF99TBIZ+DjWtE6nJLphy3jRH8R+gUHtZf6bxCZgsBD7BhhdOzwNgZCXmW Sm5g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="J/wlUBDf"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hd8si11218628ejc.78.2021.03.15.11.20.52; Mon, 15 Mar 2021 11:21:14 -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=@linuxfoundation.org header.s=korg header.b="J/wlUBDf"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237700AbhCOOTk (ORCPT + 99 others); Mon, 15 Mar 2021 10:19:40 -0400 Received: from mail.kernel.org ([198.145.29.99]:36622 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232757AbhCON7l (ORCPT ); Mon, 15 Mar 2021 09:59:41 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id E42D664F75; Mon, 15 Mar 2021 13:59:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816765; bh=WmxsyXZaGuqzBHTg7H7zF124/i5Yo16djBp6yK0QzCA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=J/wlUBDfNJYXMCxBLM/XrsSsdO1QxAEoFW0yQ48YNvG92b6UPb/Kq4BmahdJvchDP QE1Rhwbfqfs7EU9UkHUt8Fbs51I3Rc0xROyU6JhWy8jpxhqrlwoHB2ZR9gIaPioQBj C8n1m5U9EzNV+sOF9OqwHu/lW1tSukd3coDaJoz4= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Stefan Haberland , Bjoern Walk , Jan Hoeppner , Jens Axboe Subject: [PATCH 4.14 46/95] s390/dasd: fix hanging DASD driver unbind Date: Mon, 15 Mar 2021 14:57:16 +0100 Message-Id: <20210315135741.786571914@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135740.245494252@linuxfoundation.org> References: <20210315135740.245494252@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greg Kroah-Hartman From: Stefan Haberland commit 7d365bd0bff3c0310c39ebaffc9a8458e036d666 upstream. In case of an unbind of the DASD device driver the function dasd_generic_remove() is called which shuts down the device. Among others this functions removes the int_handler from the cdev. During shutdown the device cancels all outstanding IO requests and waits for completion of the clear request. Unfortunately the clear interrupt will never be received when there is no interrupt handler connected. Fix by moving the int_handler removal after the call to the state machine where no request or interrupt is outstanding. Cc: stable@vger.kernel.org Signed-off-by: Stefan Haberland Tested-by: Bjoern Walk Reviewed-by: Jan Hoeppner Signed-off-by: Jens Axboe Signed-off-by: Greg Kroah-Hartman --- drivers/s390/block/dasd.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) --- a/drivers/s390/block/dasd.c +++ b/drivers/s390/block/dasd.c @@ -3489,8 +3489,6 @@ void dasd_generic_remove(struct ccw_devi struct dasd_device *device; struct dasd_block *block; - cdev->handler = NULL; - device = dasd_device_from_cdev(cdev); if (IS_ERR(device)) { dasd_remove_sysfs_files(cdev); @@ -3509,6 +3507,7 @@ void dasd_generic_remove(struct ccw_devi * no quite down yet. */ dasd_set_target_state(device, DASD_STATE_NEW); + cdev->handler = NULL; /* dasd_delete_device destroys the device reference. */ block = device->block; dasd_delete_device(device);