Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3699243pxv; Mon, 26 Jul 2021 09:41:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwZOC4LrhAJQEk303UVFORl6yY9vbGaLAJRWrhthwDeca9dHuT7ZujEXaYChh4wJcK8a76J X-Received: by 2002:aa7:ccc1:: with SMTP id y1mr22314324edt.321.1627317661604; Mon, 26 Jul 2021 09:41:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627317661; cv=none; d=google.com; s=arc-20160816; b=dIICx4q56RYqkqekmuajPfmcwSDUMTdLVghuZgvESNygwer1agn4OE3GP+ntlJAeEK GK3UqJAx5pLq0zh3vXU+uvCzGJR6Bl7jG7yGy+MYH0bwSvrdtX29kBgv+zpURrPdFNkw a53PpNQY0fIHQmAMZ2NjK9nmfiW2/Y/1ufmZX6mCHhcjKf6c+uDbU9xq2DTQwG3RRKbC g2newepNW2QyxTxiygK4A0/HP5dzlG3RM8CGACUjhwLilxDPENVFnqMqkaATp/3DfWl/ 66Mg4qjKa6jkP+8Y2pz1HT+f/Xlpqumr4ga3lCCXldgbXCax1+TafVsB49IRvUSAnwLi iohA== 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=OfrJNc0D3dEkzv11HFc++RwL6NIR7fXmooOW4ffglas=; b=IoOEO0XQoa95e0aQmlzQYdQPj8OMXMq0hqWaAalH84oZJoRd9J6pZP1rwb1bJsI+P5 K5LZRMFNL6Ghj5g7FMrz0B0WiR9b5+Lt+hpoeuYyzXwc56Wz5TMsN1n9XmVEIWPuNoBe yzpYpcrUJS9jhi6KaSyJi6Cm2kaLV21wqEXI1htwTMn+NwVnKWA8RBurmA0lMyckv+Fl dXsb3D4VAWMwQL4frhSYseNNuo22fYjwid9SPp6yz+vPJB345y4EN639zCW+yXsfPvbI 5M31LqAe8jsSDKmq9Mch5AY/y7eiB6wTGCMIE5zmSKhTegNQkHu3CJaTfUkDXArBBoxN EpSA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=GzG0+gZ0; 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 mp33si392109ejc.40.2021.07.26.09.40.32; Mon, 26 Jul 2021 09:41:01 -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=GzG0+gZ0; 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 S239655AbhGZP47 (ORCPT + 99 others); Mon, 26 Jul 2021 11:56:59 -0400 Received: from mail.kernel.org ([198.145.29.99]:54078 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237707AbhGZPgB (ORCPT ); Mon, 26 Jul 2021 11:36:01 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id EB20F60FC1; Mon, 26 Jul 2021 16:16:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1627316188; bh=NU/UYTw5csGX16z4Y0aEdc2v5/xMTL/7VmbglNmRjFI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=GzG0+gZ0fjKWYgAwNUlXlgSvg7HUmnAzn9DjwCzC3KEtLAp+IVqpCHRpGdLWx4cW9 KMVovhThVsNjGH/KXawiUbZA0RWB4AK5pPTAt3mbt/uRW4FX0eqZC3r4SoS6FqoBK/ 12c04VSPhpicyYc+/1vKkdSJ15HeL3RK6xCnEP5g= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hemant kumar , Manivannan Sadhasivam , Loic Poulain , Manivannan Sadhasivam Subject: [PATCH 5.13 189/223] bus: mhi: pci_generic: Fix inbound IPCR channel Date: Mon, 26 Jul 2021 17:39:41 +0200 Message-Id: <20210726153852.383489674@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210726153846.245305071@linuxfoundation.org> References: <20210726153846.245305071@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: Loic Poulain commit b8a97f2a65388394f433bf0730293a94f7d49046 upstream. The qrtr-mhi client driver assumes that inbound buffers are automatically allocated and queued by the MHI core, but this doesn't happen for mhi pci devices since IPCR inbound channel is not flagged with auto_queue, causing unusable IPCR (qrtr) feature. Fix that. Link: https://lore.kernel.org/r/1625736749-24947-1-git-send-email-loic.poulain@linaro.org [mani: fixed a spelling mistake in commit description] Fixes: 855a70c12021 ("bus: mhi: Add MHI PCI support for WWAN modems") Cc: stable@vger.kernel.org #5.10 Reviewed-by: Hemant kumar Reviewed-by: Manivannan Sadhasivam Signed-off-by: Loic Poulain Signed-off-by: Manivannan Sadhasivam Link: https://lore.kernel.org/r/20210716075106.49938-4-manivannan.sadhasivam@linaro.org Signed-off-by: Greg Kroah-Hartman --- drivers/bus/mhi/pci_generic.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) --- a/drivers/bus/mhi/pci_generic.c +++ b/drivers/bus/mhi/pci_generic.c @@ -75,6 +75,22 @@ struct mhi_pci_dev_info { .doorbell_mode_switch = false, \ } +#define MHI_CHANNEL_CONFIG_DL_AUTOQUEUE(ch_num, ch_name, el_count, ev_ring) \ + { \ + .num = ch_num, \ + .name = ch_name, \ + .num_elements = el_count, \ + .event_ring = ev_ring, \ + .dir = DMA_FROM_DEVICE, \ + .ee_mask = BIT(MHI_EE_AMSS), \ + .pollcfg = 0, \ + .doorbell = MHI_DB_BRST_DISABLE, \ + .lpm_notify = false, \ + .offload_channel = false, \ + .doorbell_mode_switch = false, \ + .auto_queue = true, \ + } + #define MHI_EVENT_CONFIG_CTRL(ev_ring, el_count) \ { \ .num_elements = el_count, \ @@ -213,7 +229,7 @@ static const struct mhi_channel_config m MHI_CHANNEL_CONFIG_UL(14, "QMI", 4, 0), MHI_CHANNEL_CONFIG_DL(15, "QMI", 4, 0), MHI_CHANNEL_CONFIG_UL(20, "IPCR", 8, 0), - MHI_CHANNEL_CONFIG_DL(21, "IPCR", 8, 0), + MHI_CHANNEL_CONFIG_DL_AUTOQUEUE(21, "IPCR", 8, 0), MHI_CHANNEL_CONFIG_UL_FP(34, "FIREHOSE", 32, 0), MHI_CHANNEL_CONFIG_DL_FP(35, "FIREHOSE", 32, 0), MHI_CHANNEL_CONFIG_HW_UL(100, "IP_HW0", 128, 2),