Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1683821ybz; Thu, 16 Apr 2020 13:38:05 -0700 (PDT) X-Google-Smtp-Source: APiQypKIyYQ76VFzFrBZrHV2TeNkV0G0uBxCb5ly5xk+SDew2VE22Tem+dJkMKItddzfjHiz0p+2 X-Received: by 2002:a50:e007:: with SMTP id e7mr9160edl.361.1587069485322; Thu, 16 Apr 2020 13:38:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587069485; cv=none; d=google.com; s=arc-20160816; b=vYxvgIc2dxuBOwZGMqIU2WfDTwHDs7+PLUn+RGFJHMNdbbKaohBEf0TmZjyJQ3BsTj LZd3Zec6n3kAm2sA1Zc2BH8ZVEb+tTOBJ8MmjrYvsrH7FOyuUIsVx3ezshK30wtm2jfT V6ZtZJknI4LVOgGV6Cn7OUeHB3gNI6lc5qwP51ymxmAyHS0MrkfhEXCEd6ixeHwjriHU o/HNs6HKgwzlBEUtDuWWdS0a/cR8z9b7mFKgciW8OgnK+yoTMVi36o9EY6vPSMY8lGWK lXjWtgg6l73abvGWW5rEU2OSWy2v5SnOhRKHrbub68tBGsq64USnT+YZtqEte33K7ZmO wW4A== 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=/Klz+Xs8PF3e4QJPZvEXVy0/KCG4tuyny83vV4nKyqU=; b=kHpyu6yzkF2AlNQH0lnfqGO0FkrNRtcZv0rYQxZHSXJIGMIePDw3uKwLySjg59AtlJ rS9a2HA0XdOJ7h+uebs+4JDFt8asbXFZcXKe0spGCuqEWnzNa4xir2aejmyIlqubjHVR 5sZCZ+i2T1BevmDfkdEPljOpq3eU6gWYUbBtEH8GJBA6qi95FOJSaECj+WvNZJTe8iF1 EOyy2EHg4Iz1tCxMxvj8O8DxZGTztjbeIKhyT1wcheznaZJpWl9N9MW3zFS+RtTzUwQs PuQVP63XPJw82Zrl+KyvklT+o5QkCZSwEuNeGMo7Q0pQLLFLH5ZhqPbRstC40f+fnYsC orng== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=zbwN4lPY; 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 k2si7946144edl.244.2020.04.16.13.37.42; Thu, 16 Apr 2020 13:38:05 -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=zbwN4lPY; 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 S2442773AbgDPPuh (ORCPT + 99 others); Thu, 16 Apr 2020 11:50:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:43730 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2895827AbgDPNc6 (ORCPT ); Thu, 16 Apr 2020 09:32:58 -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 BE26A22265; Thu, 16 Apr 2020 13:32:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587043937; bh=uCDUcXmEwX5SSUfpabvQs8S1gdekkxZT6ihr0BNLMug=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zbwN4lPYik2cYIi48nOFEV0fDwBukL97loyHFXKy52zLjxWnk3qfY6t8WPjWzAFPt Y+6HRt7hzNkA8Y2BFxujHwmBRJyMn+d5wSISYztW+wxm0Sdjuff/Fi5+pqqpKdUTmh javoJGA+N0g/gmsk4RQH+YUOe3k4ajpMUnqrFoC4= 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 5.5 015/257] hinic: fix a bug of waitting for IO stopped Date: Thu, 16 Apr 2020 15:21:06 +0200 Message-Id: <20200416131327.770507452@linuxfoundation.org> X-Mailer: git-send-email 2.26.1 In-Reply-To: <20200416131325.891903893@linuxfoundation.org> References: <20200416131325.891903893@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 79b3d53f2fbfa..c7c75b772a866 100644 --- a/drivers/net/ethernet/huawei/hinic/hinic_hw_dev.c +++ b/drivers/net/ethernet/huawei/hinic/hinic_hw_dev.c @@ -360,50 +360,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 @@ -423,11 +379,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