Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3419275pxf; Mon, 29 Mar 2021 01:30:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyCyaXGrx6Ulcz+LgMRFkKhRNgCoXMkRSB1bp9lUuFllKYAKojWkhki177l0nu71D6F+Osh X-Received: by 2002:a17:906:53d7:: with SMTP id p23mr27567804ejo.140.1617006621594; Mon, 29 Mar 2021 01:30:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617006621; cv=none; d=google.com; s=arc-20160816; b=Tt71mcFyx4mAxcn83lPqTfL0ha+16DRn/ygAvyVtvRsuGmvuiu1qbJ+pEo3s2egPkO nGD3FsAgqyivlsHc6CTIqW1UBVw2bze4A8/7HGSc4TStlVWbr7P4V13KoE9ar3mYhTDl 7xgigSWnLl118va0EgOwMh4ZTAJaSpGbfzhJ/SjW43eenMeBhxHk7e9z2FOuZecp2zUs M2V/ILKonca0bnNXZBy9sTz/zB6kav2SoPGlJAoLHuWDY/jVAK5sqnTTj5aacS4poaPb I5dbq4rOCCQQEoN4ROV87XqVS5ATGSoAebL6EJF2WxMICv6TBnQk0OM5PgLRJdOP36aL UJuQ== 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=8p3NRl8pbum+SObbXEWNUwkSefgjY9Y+fuCrmsqCVvA=; b=M2OgBE7/UdXE5bUGVDqwLMytz+2Uc0wE7XKdpzhM0sEmhPcu34Y19p6Hidlu3/dG8F joM4om1sUgmqs6ixggq9Qy5XkqudK8PRMqOxs02QwAkuQDu9GCV0Dlz8y0jj/y1tgjJS 7sUUaO9WxxbfB5M3tAMaNcp8J2gjjAW/O7Vun1H/l5HLLSsv0LJc43A7khao4Urvap4H P5DwI5b7OkE2U5HrSQySGJDa2xHmuNV3TC4BigSqMn6z+8CWzEGFADqm+dCmrImUYqL3 rHBo7YzU6kKNopEYhyDmGYFpUfP+oVwIi2rZpoqNmv6Ou4fRNReC8FSBKuZ7skOq16HY yBNA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=t7+rtNnp; 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 u1si12210510ejt.544.2021.03.29.01.29.53; Mon, 29 Mar 2021 01:30:21 -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=t7+rtNnp; 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 S231859AbhC2IZm (ORCPT + 99 others); Mon, 29 Mar 2021 04:25:42 -0400 Received: from mail.kernel.org ([198.145.29.99]:58584 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233149AbhC2IQk (ORCPT ); Mon, 29 Mar 2021 04:16:40 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 18C636044F; Mon, 29 Mar 2021 08:16:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1617005771; bh=qoUxGxk9gJE2+hpBf/VZrCxTVRJNIWJ2wIMtvFpXqW4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=t7+rtNnpjzqKn3kDi0Vq6DgUOcBWZ1ZsesYJP44NN+vMcxiF0bYJtsQLgzspu0kk8 ENac1mXOiBcEFSRmstfkHtb9y10dAVUg9TG6k9ZnvZvtiIJz2y2Z5hDWudj+bIdvNR BLrdyByQMXv3g/GjfkO0Ya0dF9yZ73M7FbVqCIcU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Marc Kleine-Budde , Torin Cooper-Bennun , Sasha Levin Subject: [PATCH 5.4 076/111] can: m_can: m_can_rx_peripheral(): fix RX being blocked by errors Date: Mon, 29 Mar 2021 09:58:24 +0200 Message-Id: <20210329075617.744814279@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210329075615.186199980@linuxfoundation.org> References: <20210329075615.186199980@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: Torin Cooper-Bennun [ Upstream commit e98d9ee64ee2cc9b1d1a8e26610ec4d0392ebe50 ] For M_CAN peripherals, m_can_rx_handler() was called with quota = 1, which caused any error handling to block RX from taking place until the next time the IRQ handler is called. This had been observed to cause RX to be blocked indefinitely in some cases. This is fixed by calling m_can_rx_handler with a sensibly high quota. Fixes: f524f829b75a ("can: m_can: Create a m_can platform framework") Link: https://lore.kernel.org/r/20210303144350.4093750-1-torin@maxiluxsystems.com Suggested-by: Marc Kleine-Budde Signed-off-by: Torin Cooper-Bennun Signed-off-by: Marc Kleine-Budde Signed-off-by: Sasha Levin --- drivers/net/can/m_can/m_can.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/can/m_can/m_can.c b/drivers/net/can/m_can/m_can.c index cf72a7e464ec..b2224113987c 100644 --- a/drivers/net/can/m_can/m_can.c +++ b/drivers/net/can/m_can/m_can.c @@ -839,7 +839,7 @@ static int m_can_rx_peripheral(struct net_device *dev) { struct m_can_classdev *cdev = netdev_priv(dev); - m_can_rx_handler(dev, 1); + m_can_rx_handler(dev, M_CAN_NAPI_WEIGHT); m_can_enable_all_interrupts(cdev); -- 2.30.1