Received: by 10.223.185.116 with SMTP id b49csp5458375wrg; Tue, 27 Feb 2018 13:47:46 -0800 (PST) X-Google-Smtp-Source: AH8x227Ow2enT2xgLflPQjRUz42Bc0q6VHxsqTywyNbrGwDdwWEXD0s9ZQIyPcCNuVB8Nqdb6Qq/ X-Received: by 10.98.36.217 with SMTP id k86mr15453586pfk.137.1519768066737; Tue, 27 Feb 2018 13:47:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519768066; cv=none; d=google.com; s=arc-20160816; b=yzvu3pdMoI7lkAWPy68WG7GkqjwP+TCjzMC2Rrk9tjvnZ+pOCxupLxKroe/YucSIqC HeRdi9wowXD8N6eJJfTIQEtvBXgLt9UdL1jGlcw5jGetFk6C2gDK/x1Zt9dnXGqMXb5O PWosb/b4pBT7316D3Jhuefvdrj8mfnRduNyYZoXAz4CbbzKKbYIjwaBpGbGWYE05gS40 4bS3fVXSv/qjqfMEc92SGW8M8R+L9X9sD6z1HaHR+x3zQ82KMmCqpW/eyEUeP+Ku+Nre RT3f9k4rz4GK4T9xS4qnn8dHwfWIds/EO1HznVnuMMQBIneyls3jbiVUWNwopCdo31Un 9TXg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=ZsuBthHqE+bJo8QNxrtnmHvmRrE01wmVeH5E/f1z+Is=; b=HfZWsIlhqyqK6fNMZkX+vgUXSOC2J4fxDj4xxTS8hUoHaIbO4zz56dojVw6YXUkhmp v3ROXx1Q0vlOLI5rvDaasyyXHr/JGH4qf4FCpGJK5jQIDYOBV0sFJNHvcINxQZxTIhaR nsI+Rw8xQAYhZVN6e2oI5iDe1Q1Abo7l1T7/hArptSIL9/qLDeGeV2UhfMt48YKq0MR3 5yf0H0mA2Qf28hgA6bQ4TmauYuAG/wZcEAcVamjtK+1VSsl4HnSkOTUodeY45gMQXD8T 9skd3dZ86vvRYwv65w8STQ5l6OOXmwEUwt2TOa6G9C3ooOMIrsZu/k01YroPk1457xFk CFvA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=B70Iw/+V; dkim=pass header.i=@codeaurora.org header.s=default header.b=gixb6Kfz; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e8si80456pfi.359.2018.02.27.13.47.32; Tue, 27 Feb 2018 13:47:46 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=B70Iw/+V; dkim=pass header.i=@codeaurora.org header.s=default header.b=gixb6Kfz; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751825AbeB0Vq6 (ORCPT + 99 others); Tue, 27 Feb 2018 16:46:58 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:40472 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751689AbeB0Vq4 (ORCPT ); Tue, 27 Feb 2018 16:46:56 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 08158607EF; Tue, 27 Feb 2018 21:46:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1519768016; bh=TS9NADP5fLNaTCMbWcltSnjQe2PnTaPfBsLw13RKSUY=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=B70Iw/+V4Fdv6xnfwcwR/NQCw2U1hsd1NGsHRoLQ9L5btpqMurA7vP42CkSfmwTe2 TPz3N5IcVETJ1Yv8EKNszsfoRTilGumrRzFda2iHTYYA9L0pkyEj+I6R4zjHqG93WJ oXynkYUrM4gNhqbGaRo2r1p2ZYUBDr5/w4RElWQc= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [10.226.60.117] (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: austinwc@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id D51EA600C1; Tue, 27 Feb 2018 21:46:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1519768015; bh=TS9NADP5fLNaTCMbWcltSnjQe2PnTaPfBsLw13RKSUY=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=gixb6KfzmA186VmwzgrxmwssFQG/oXj/1ehJF7VpxGW2m/nUxKdLQfWyV7n5Wh0Kb 1tGoYcWnrvMFBkC+xIU4HJQqrP7ZWonJMCa6YPJBAtq8x5gd6udcMpFVx8xlHA/k2R 5O7NWaEraAd8k0oskw9Yu+jUiXHUycI2RhCmwBRg= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org D51EA600C1 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=austinwc@codeaurora.org Subject: Re: [PATCH 01/12] i2c: qup: fixed releasing dma without flush operation completion To: Abhishek Sahu , Andy Gross , Wolfram Sang Cc: David Brown , Sricharan R , linux-arm-msm@vger.kernel.org, linux-soc@vger.kernel.org, linux-i2c@vger.kernel.org, linux-kernel@vger.kernel.org References: <1517644697-30806-1-git-send-email-absahu@codeaurora.org> <1517644697-30806-2-git-send-email-absahu@codeaurora.org> From: "Christ, Austin" Message-ID: <789b2136-da54-b1d5-385d-71b36b368247@codeaurora.org> Date: Tue, 27 Feb 2018 14:46:53 -0700 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <1517644697-30806-2-git-send-email-absahu@codeaurora.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Tested on Centriq 2400 Reviewed-by: Austin Christ On 2/3/2018 12:58 AM, Abhishek Sahu wrote: > The QUP BSLP BAM generates the following error sometimes if the > current I2C DMA transfer fails and the flush operation has been > scheduled > > “bam-dma-engine 7884000.dma: Cannot free busy channel” > > If any I2C error comes during BAM DMA transfer, then the QUP I2C > interrupt will be generated and the flush operation will be > carried out to make i2c consume all scheduled DMA transfer. > Currently, the same completion structure is being used for BAM > transfer which has already completed without reinit. It will make > flush operation wait_for_completion_timeout completed immediately > and will proceed for freeing the DMA resources where the > descriptors are still in process. > > Signed-off-by: Abhishek Sahu > --- > drivers/i2c/busses/i2c-qup.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/drivers/i2c/busses/i2c-qup.c b/drivers/i2c/busses/i2c-qup.c > index 08f8e01..9faa26c41a 100644 > --- a/drivers/i2c/busses/i2c-qup.c > +++ b/drivers/i2c/busses/i2c-qup.c > @@ -1,5 +1,5 @@ > /* > - * Copyright (c) 2009-2013, The Linux Foundation. All rights reserved. > + * Copyright (c) 2009-2013, 2016-2018, The Linux Foundation. All rights reserved. > * Copyright (c) 2014, Sony Mobile Communications AB. > * > * > @@ -844,6 +844,8 @@ static int qup_i2c_bam_do_xfer(struct qup_i2c_dev *qup, struct i2c_msg *msg, > } > > if (ret || qup->bus_err || qup->qup_err) { > + reinit_completion(&qup->xfer); > + > if (qup_i2c_change_state(qup, QUP_RUN_STATE)) { > dev_err(qup->dev, "change to run state timed out"); > goto desc_err; > -- Qualcomm Datacenter Technologies as an affiliate of Qualcomm Technologies, Inc. Qualcomm Technologies, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project.