Received: by 10.213.65.68 with SMTP id h4csp591430imn; Tue, 13 Mar 2018 14:11:25 -0700 (PDT) X-Google-Smtp-Source: AG47ELso+HPqzpr1x+7T7nlWbAs8bJHzgY1j4kgjR9+o4jWCooJrlYtmRimGxlpV4nAsXSwh5jsy X-Received: by 10.98.217.211 with SMTP id b80mr1931506pfl.107.1520975484944; Tue, 13 Mar 2018 14:11:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520975484; cv=none; d=google.com; s=arc-20160816; b=n5BMR7mO8N9eX74DNh+UEPBs3ZEtcbSTyzjjg0MN1ssuQo9BesXBH8vFjGh5gVYdNW FQ4CgaIOyYmXIFDMfOhF/+jmSZHcGMwHt7u33InLzBoueUufp/85a5ty3pZL6zuRTbwr kMpxhMZ3IZ6cm5FxE6PWuduWrFmlJXbj8JK5J3T+pMhNj3DM6a1hAQOBiCKuQImTLPpJ MZp55DrtsdQf+iY77StlQ13oMm7589c9wcP9ZdynSPzTBthnk66X0L9KwjAubfofmSVn X74mOzWkFhMHuooxKpuf7QkxHBRtUn4Re/EWk27DD4qX/d/hVpfGGJr/DOvFk7dXy0BU ZSHA== 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=Vfz3qTVPTxh+D7zclH0lM+cG/CQENJqmegMYV5lZQk0=; b=lJ/2KyELj8h6H1fYm5cChjyDP5vmnIbfFd6C4NZfh/vvnaKxTzh5SMRyRaBDeQh0ki mnoEv6/HDcTMgZjn+rrCVSQuDo0h5dsFQ5AsDUWcr0L43K703zhVWz1psbgPKTNS9zQP OveSTJCn8Hes82me6UmltbcIsaPnFMQ5W2KZEXoZ2veLilQ6nNh13c2gy4T6F8ocSM8n XjkHNk7SfXlXF6iiGWJiu0YzIAcNZ9SftR+x9P3P2oXWa2TLHLHT44SKiZg1JCIN3fbl X8M5tT4TJqrPX7+pLoM8oHXmFFf/fo+UqQGyuS6aK6sGIo2A1M350UuPn4MHE3C0IE9d d1jQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=iVhQyeqc; dkim=pass header.i=@codeaurora.org header.s=default header.b=iVhQyeqc; 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 v4-v6si713244plo.55.2018.03.13.14.11.10; Tue, 13 Mar 2018 14:11:24 -0700 (PDT) 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=iVhQyeqc; dkim=pass header.i=@codeaurora.org header.s=default header.b=iVhQyeqc; 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 S932710AbeCMVJG (ORCPT + 99 others); Tue, 13 Mar 2018 17:09:06 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:45192 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932372AbeCMVJD (ORCPT ); Tue, 13 Mar 2018 17:09:03 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id DFBF3602FC; Tue, 13 Mar 2018 21:09:02 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1520975342; bh=u0dCXaV+SPvFIGBX4za/5Mk3CDq2BfL7A2EPWHoaFTI=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=iVhQyeqc19zWefp/OCPvbNGoISSe1ueeoMIfIaAxkk1p++Yver4kies3IX/5g34i4 7VfF3dj8fdSiOiulinn1UjWHOH/XSVcwmJ7Tvbz5QYJfbKkw4mpfxrjNzzxbEYrJhF z7+QTguRXuB8Iw1UnDwCHafeKHjUjh0Tz64Kbv/k= 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 6A7C2602FC; Tue, 13 Mar 2018 21:09:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1520975342; bh=u0dCXaV+SPvFIGBX4za/5Mk3CDq2BfL7A2EPWHoaFTI=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=iVhQyeqc19zWefp/OCPvbNGoISSe1ueeoMIfIaAxkk1p++Yver4kies3IX/5g34i4 7VfF3dj8fdSiOiulinn1UjWHOH/XSVcwmJ7Tvbz5QYJfbKkw4mpfxrjNzzxbEYrJhF z7+QTguRXuB8Iw1UnDwCHafeKHjUjh0Tz64Kbv/k= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 6A7C2602FC 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 v2 00/13] Major code reorganization to make all i2c transfers working 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: <1520860502-14886-1-git-send-email-absahu@codeaurora.org> From: "Christ, Austin" Message-ID: <2a092d8f-6d1a-27e4-01f6-49790f767ae6@codeaurora.org> Date: Tue, 13 Mar 2018 15:09:00 -0600 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: <1520860502-14886-1-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 I've tested this v2 series on Centriq 2400. Looks good to me. Reviewed-by: Austin Christ On 3/12/2018 7:14 AM, Abhishek Sahu wrote: > * v2: > > 1. Address review comments in v1 > 2. Changed the license to SPDX > 3. Changed commit messages for some of the patch having more detail > 4. Removed event-based completion and changed transfer completion > detection logic in interrupt handler > 5. Removed dma_threshold and blk_mode_threshold from global structure > 6. Improved determine mode logic for QUP v2 transfers > 7. Fixed function comments > 8. Fixed auto build test WARNING ‘idx' may be used uninitialized > in this function > 9. Renamed tx/rx_buf to tx/rx_cnt > > * v1: > > The current driver is failing in following test case > 1. Handling of failure cases is not working in long run for BAM > mode. It generates error message “bam-dma-engine 7884000.dma: Cannot > free busy channel” sometimes. > 2. Following I2C transfers are failing > a. Single transfer with multiple read messages > b. Single transfer with multiple read/write message with maximum > allowed length per message (65K) in BAM mode > c. Single transfer with write greater than 32 bytes in QUP v1 and > write greater than 64 bytes in QUP v2 for non-DMA mode. > 3. No handling is present for Block/FIFO interrupts. Any non-error > interrupts are being treated as the transfer completion and then > polling is being done for available/free bytes in FIFO. > > To fix all these issues, major code changes are required. This patch > series fixes all the above issues and makes the driver interrupt based > instead of polling based. After these changes, all the mentioned test > cases are working properly. > > The code changes have been tested for QUP v1 (IPQ8064) and QUP > v2 (IPQ8074) with sample application written over i2c-dev. > > Abhishek Sahu (13): > i2c: qup: fix copyrights and update to SPDX identifier > i2c: qup: fixed releasing dma without flush operation completion > i2c: qup: minor code reorganization for use_dma > i2c: qup: remove redundant variables for BAM SG count > i2c: qup: schedule EOT and FLUSH tags at the end of transfer > i2c: qup: fix the transfer length for BAM RX EOT FLUSH tags > i2c: qup: proper error handling for i2c error in BAM mode > i2c: qup: use the complete transfer length to choose DMA mode > i2c: qup: change completion timeout according to transfer length > i2c: qup: fix buffer overflow for multiple msg of maximum xfer len > i2c: qup: send NACK for last read sub transfers > i2c: qup: reorganization of driver code to remove polling for qup v1 > i2c: qup: reorganization of driver code to remove polling for qup v2 > > drivers/i2c/busses/i2c-qup.c | 1507 ++++++++++++++++++++++++------------------ > 1 file changed, 880 insertions(+), 627 deletions(-) > -- 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.