Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1684459ybz; Thu, 16 Apr 2020 13:38:51 -0700 (PDT) X-Google-Smtp-Source: APiQypKe5vGQhzAXXJUo2DcAbDcfjOFzNbC02Wg5TlYR8yyCI4a+ScTTGw8f2QjcZP5tbTMxBS5m X-Received: by 2002:a17:906:cf8a:: with SMTP id um10mr11110126ejb.60.1587069531077; Thu, 16 Apr 2020 13:38:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587069531; cv=none; d=google.com; s=arc-20160816; b=yGHmVCgKPdwZVyi55peoXtucGCgQoQZNyDCq7AxmZvCtrdB/2vVi5N4FyHG/j4+vVa 1F3suhY3/r9a4GWaXREAE4I6ezONf92SKKHCGBaYTqZaIkTkX52paJvl6Gg1kcis4QkL DUFM7bxdDomOcZL8EZC2qa3K1UB5Dw4GQxS2H6xQKcreNN7jDKNbZoqHK7OvvBpacVcm DKNmalpYwvz0jwbk8j/UFWrZqn53IaAJpfNDw9LojzU2tBMl14ch1ueSy8V9NVnlin1a KfYrGAWH1ywc4c8Tct0/WB59Noa3J/zWWmDlkohakDRobIxiMMa0ajzAgdYPmmA1DkIL 04TA== 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=2XmnKpAI9pb7L5pvpKq4CP0FDKhmdXR3AwYSGb/gDkM=; b=QrpKeUdz70CwYTBus88XL5mFenV8npCB5aqu72ZNr2Se+X4u3neyRyhOvRMSyCll7S zEOLxCBMlhN5suOXJngcnblOt+kiaHbCb4OZs/5dJ5UFqDgXlcH5oDk2BlnvVKwxDTm8 zLxOOroeCAcZ2bRBN3eXZIWB5BDRQbfsWOeMCUBbUljL4qYzeQNf//a9HwhX9s3IX89y mw5xEPvf+Ma15gzjOVOrh6U0NXkzyGkKRypbVrHSUZlVTh8mYrWWnm8orAdLJ5U9Qtri 60SnQ4yFtR0ZU9L0tOYNHQdBgq/Iqt10Z5XlzTPwcvVOHlCVZ4uML6CK/NB7+EEmcH0E nuWw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=2ItrGqxf; 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 z90si3013643ede.599.2020.04.16.13.38.28; Thu, 16 Apr 2020 13:38:51 -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=2ItrGqxf; 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 S2635999AbgDPQAi (ORCPT + 99 others); Thu, 16 Apr 2020 12:00:38 -0400 Received: from mail.kernel.org ([198.145.29.99]:35302 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2895352AbgDPN1C (ORCPT ); Thu, 16 Apr 2020 09:27:02 -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 D6C5521BE5; Thu, 16 Apr 2020 13:26:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587043620; bh=SXAong0dK9Zt1RqkvYCfwsNxtQBl+WYaOrbAXLIv3TA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=2ItrGqxf5lbj7nehZCrfbqxHcXJCZ5zxnhigTeqHzTyCKfJC4MPew24f3HO/4PT+8 i6j8Y7k5GLGwQlK5UOdvjSr3+tf7IE4BtQ2iPUDyl/Ww5+BdHszl56bzQ4bFMo1TEq V+/p370Ss+SLScHhiixi0hCKV8FF096LDF1rKfqU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Luo bin , "David S. Miller" , Sasha Levin Subject: [PATCH 4.19 005/146] hinic: fix a bug of waitting for IO stopped Date: Thu, 16 Apr 2020 15:22:26 +0200 Message-Id: <20200416131243.187874522@linuxfoundation.org> X-Mailer: git-send-email 2.26.1 In-Reply-To: <20200416131242.353444678@linuxfoundation.org> References: <20200416131242.353444678@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: Luo bin [ Upstream commit 96758117dc528e6d84bd23d205e8cf7f31eda029 ] it's unreliable for fw to check whether IO is stopped, so driver wait for enough time to ensure IO process is done in hw before freeing resources Signed-off-by: Luo bin Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- .../net/ethernet/huawei/hinic/hinic_hw_dev.c | 51 +------------------ 1 file changed, 2 insertions(+), 49 deletions(-) diff --git a/drivers/net/ethernet/huawei/hinic/hinic_hw_dev.c b/drivers/net/ethernet/huawei/hinic/hinic_hw_dev.c index 9deec13d98e93..4c91c8ceac5f9 100644 --- a/drivers/net/ethernet/huawei/hinic/hinic_hw_dev.c +++ b/drivers/net/ethernet/huawei/hinic/hinic_hw_dev.c @@ -370,50 +370,6 @@ static int wait_for_db_state(struct hinic_hwdev *hwdev) return -EFAULT; } -static int wait_for_io_stopped(struct hinic_hwdev *hwdev) -{ - struct hinic_cmd_io_status cmd_io_status; - struct hinic_hwif *hwif = hwdev->hwif; - struct pci_dev *pdev = hwif->pdev; - struct hinic_pfhwdev *pfhwdev; - unsigned long end; - u16 out_size; - int err; - - if (!HINIC_IS_PF(hwif) && !HINIC_IS_PPF(hwif)) { - dev_err(&pdev->dev, "Unsupported PCI Function type\n"); - return -EINVAL; - } - - pfhwdev = container_of(hwdev, struct hinic_pfhwdev, hwdev); - - cmd_io_status.func_idx = HINIC_HWIF_FUNC_IDX(hwif); - - end = jiffies + msecs_to_jiffies(IO_STATUS_TIMEOUT); - do { - err = hinic_msg_to_mgmt(&pfhwdev->pf_to_mgmt, HINIC_MOD_COMM, - HINIC_COMM_CMD_IO_STATUS_GET, - &cmd_io_status, sizeof(cmd_io_status), - &cmd_io_status, &out_size, - HINIC_MGMT_MSG_SYNC); - if ((err) || (out_size != sizeof(cmd_io_status))) { - dev_err(&pdev->dev, "Failed to get IO status, ret = %d\n", - err); - return err; - } - - if (cmd_io_status.status == IO_STOPPED) { - dev_info(&pdev->dev, "IO stopped\n"); - return 0; - } - - msleep(20); - } while (time_before(jiffies, end)); - - dev_err(&pdev->dev, "Wait for IO stopped - Timeout\n"); - return -ETIMEDOUT; -} - /** * clear_io_resource - set the IO resources as not active in the NIC * @hwdev: the NIC HW device @@ -433,11 +389,8 @@ static int clear_io_resources(struct hinic_hwdev *hwdev) return -EINVAL; } - err = wait_for_io_stopped(hwdev); - if (err) { - dev_err(&pdev->dev, "IO has not stopped yet\n"); - return err; - } + /* sleep 100ms to wait for firmware stopping I/O */ + msleep(100); cmd_clear_io_res.func_idx = HINIC_HWIF_FUNC_IDX(hwif); -- 2.20.1