Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp297884ybz; Tue, 21 Apr 2020 21:21:26 -0700 (PDT) X-Google-Smtp-Source: APiQypK8869lNRRiYKbgZ7Eb3JBkGBLu8kQZ2aa64fY8xQRaGB5NQm6RPggK8wbm/C9ANRYPjik/ X-Received: by 2002:a17:906:468c:: with SMTP id a12mr25273130ejr.149.1587529286598; Tue, 21 Apr 2020 21:21:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587529286; cv=none; d=google.com; s=arc-20160816; b=LkE8v4lO3GwC2RDsJhOlut1wz4oMoBzJiy8md3O8hmc7IA3mVNrfiSdU2cjdJH8Jgw wn1i50SH+o4mYogS6FXtykmAZ3eab4UAKMyvp9m9+KHVzbVBc/I6mAdCo9DinTcHL16E hpbhsqNjNwoAdjjLO5MdvY+sd5aP/D32HpWXqiPGb+lCIvjBbbdW8ot2kVmucY3D0OfA 5w8OkYhvrMHIjTFrH8qQNHrrN5EFdB+ZqaAqfnw9gSRg0k7XmzCiFL45jhKjhtbAe/h0 YDXxR2NkMzTlHPow+gnJydPkkLxsqT7MxSa250yr9LAGnBSdREB5G5YmtTFiqh4MEAd5 K0OA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dmarc-filter:dkim-signature; bh=9ajINjyxVnZz0xrqD52l756TPDsznJMo9dg0aqFR6yM=; b=UhyKecWYPfL7DVEASz4ZWe3pLZkFvBKnmdCVYI7ugdKWT/XfJ924898k46pQK5cqQX CAl3HwpTv7IeWkeNDSi6+lUdMNQDff7cppTpCGneEFHwmMQ8TZPiz4nEYbU/grboKv+r D+Io9hVIIORHnsAB4b+7vWopDv6PJdq4uWt78GoXWfVsI4xDCS2DiOOitFit3586XUSl 8d48ROrkcPXaG9ue/MhIUCiOh5YxCt3vUGPGzL15WTD5XtbjfwWAKJicicqqofC/3lut nhuoGRTikmWsHRZTSZpcQj18F2yuRTfHhjMC+dyk9rEWdNyzPmiGnKuK9CAANDF8ZxND ujgw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=qy7iQExj; 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 q25si2769740ejb.274.2020.04.21.21.21.04; Tue, 21 Apr 2020 21:21:26 -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=fail header.i=@mg.codeaurora.org header.s=smtp header.b=qy7iQExj; 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 S1725961AbgDVEUC (ORCPT + 99 others); Wed, 22 Apr 2020 00:20:02 -0400 Received: from mail26.static.mailgun.info ([104.130.122.26]:18549 "EHLO mail26.static.mailgun.info" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725811AbgDVEUB (ORCPT ); Wed, 22 Apr 2020 00:20:01 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1587529200; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=9ajINjyxVnZz0xrqD52l756TPDsznJMo9dg0aqFR6yM=; b=qy7iQExjREr2AxZ/Gd4BG6xJUE5pf03dTdLkXNeDLNy1S4rxGcozoPpgM3vcPxUeXW96zoL8 3DUi6CTu5yD3qv+Ic41u6G2Op449fnH+N2vXcPIJ5hzPWN7Wmi+TtHUI7YjfQsHlFwL/kAyj jZtfR5l9aEf7KhlszR0si5lz2pc= X-Mailgun-Sending-Ip: 104.130.122.26 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by mxa.mailgun.org with ESMTP id 5e9fc5e6.7fc3729ee8f0-smtp-out-n03; Wed, 22 Apr 2020 04:19:50 -0000 (UTC) Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 548A7C433F2; Wed, 22 Apr 2020 04:19:50 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.0 required=2.0 tests=ALL_TRUSTED,SPF_NONE autolearn=ham autolearn_force=no version=3.4.0 Received: from bbhatt-linux.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: bbhatt) by smtp.codeaurora.org (Postfix) with ESMTPSA id B9DE9C433D2; Wed, 22 Apr 2020 04:19:49 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org B9DE9C433D2 Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=none smtp.mailfrom=bbhatt@codeaurora.org From: Bhaumik Bhatt To: linux-arm-msm@vger.kernel.org Cc: linux-kernel@vger.kernel.org, Hemant Kumar Subject: [PATCH v1 1/8] bus: mhi: core: Cache intmod from mhi event to mhi channel Date: Tue, 21 Apr 2020 21:19:28 -0700 Message-Id: <1587529175-27778-2-git-send-email-bbhatt@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1587529175-27778-1-git-send-email-bbhatt@codeaurora.org> References: <1587529175-27778-1-git-send-email-bbhatt@codeaurora.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Hemant Kumar Driver is using zero initialized intmod value from mhi channel when configuring TRE for bei field. This prevents interrupt moderation to take effect in case it is supported by an event ring. Fix this by copying intmod value from associated event ring to mhi channel upon registering mhi controller. Signed-off-by: Hemant Kumar --- drivers/bus/mhi/core/init.c | 4 ++++ drivers/bus/mhi/core/main.c | 9 ++++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/drivers/bus/mhi/core/init.c b/drivers/bus/mhi/core/init.c index b38359c..4dc7f22 100644 --- a/drivers/bus/mhi/core/init.c +++ b/drivers/bus/mhi/core/init.c @@ -864,6 +864,10 @@ int mhi_register_controller(struct mhi_controller *mhi_cntrl, mutex_init(&mhi_chan->mutex); init_completion(&mhi_chan->completion); rwlock_init(&mhi_chan->lock); + + /* used in setting bei field of TRE */ + mhi_event = &mhi_cntrl->mhi_event[mhi_chan->er_index]; + mhi_chan->intmod = mhi_event->intmod; } if (mhi_cntrl->bounce_buf) { diff --git a/drivers/bus/mhi/core/main.c b/drivers/bus/mhi/core/main.c index eb4256b..23154f1 100644 --- a/drivers/bus/mhi/core/main.c +++ b/drivers/bus/mhi/core/main.c @@ -929,7 +929,7 @@ int mhi_queue_skb(struct mhi_device *mhi_dev, enum dma_data_direction dir, struct mhi_ring *buf_ring = &mhi_chan->buf_ring; struct mhi_buf_info *buf_info; struct mhi_tre *mhi_tre; - int ret; + int ret, bei; /* If MHI host pre-allocates buffers then client drivers cannot queue */ if (mhi_chan->pre_alloc) @@ -966,10 +966,11 @@ int mhi_queue_skb(struct mhi_device *mhi_dev, enum dma_data_direction dir, goto map_error; mhi_tre = tre_ring->wp; + bei = !!(mhi_chan->intmod); mhi_tre->ptr = MHI_TRE_DATA_PTR(buf_info->p_addr); mhi_tre->dword[0] = MHI_TRE_DATA_DWORD0(buf_info->len); - mhi_tre->dword[1] = MHI_TRE_DATA_DWORD1(1, 1, 0, 0); + mhi_tre->dword[1] = MHI_TRE_DATA_DWORD1(bei, 1, 0, 0); /* increment WP */ mhi_add_ring_element(mhi_cntrl, tre_ring); @@ -1006,6 +1007,7 @@ int mhi_queue_dma(struct mhi_device *mhi_dev, enum dma_data_direction dir, struct mhi_ring *buf_ring = &mhi_chan->buf_ring; struct mhi_buf_info *buf_info; struct mhi_tre *mhi_tre; + int bei; /* If MHI host pre-allocates buffers then client drivers cannot queue */ if (mhi_chan->pre_alloc) @@ -1043,10 +1045,11 @@ int mhi_queue_dma(struct mhi_device *mhi_dev, enum dma_data_direction dir, buf_info->len = len; mhi_tre = tre_ring->wp; + bei = !!(mhi_chan->intmod); mhi_tre->ptr = MHI_TRE_DATA_PTR(buf_info->p_addr); mhi_tre->dword[0] = MHI_TRE_DATA_DWORD0(buf_info->len); - mhi_tre->dword[1] = MHI_TRE_DATA_DWORD1(1, 1, 0, 0); + mhi_tre->dword[1] = MHI_TRE_DATA_DWORD1(bei, 1, 0, 0); /* increment WP */ mhi_add_ring_element(mhi_cntrl, tre_ring); -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project