Received: by 10.213.65.68 with SMTP id h4csp47611imn; Mon, 12 Mar 2018 06:20:00 -0700 (PDT) X-Google-Smtp-Source: AG47ELtQjDIl6w/4EawSDbJPvdvAkeSmOeIgpntK2qukTL5DR98fTSvCM9s5Hi8yiF1mWX5Vdi8+ X-Received: by 10.98.234.22 with SMTP id t22mr8013874pfh.56.1520860800405; Mon, 12 Mar 2018 06:20:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520860800; cv=none; d=google.com; s=arc-20160816; b=htLEI6F2uul/z19+wW3FPMb3sW/+uZmT+mXDugyv8PP5EAq/9L+6RTQLAsAnkfeBdg 1A9KRLzPxXXWUm/hCEkmhNFk45W9pfFI3AzjkdaLgNu3wfb+rM0HCuDYMQeaOntvt7R3 VpUMtyRucOofEyJkTK+03l/bLtvm10KqOwcSKVO96rC0aiPrMUTmrxCAfeQpPz9KlRBk 7OJvSES5QoRO/OXoKeEZTMlnNMsol+T+H3E0xo38r5Ehm4BfRgQPXij/rWvnUf/Kj8yP ZWIaxUU092U+/URqngOEKmYgthAWwhTTDb1oQkM41rI2D6+hUEEM3KIBSyFiXlYMSv72 Nn4Q== 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:dkim-signature :arc-authentication-results; bh=ulimTVoEeAmjCjEd0qrczk5QeUcf2L6w2B/2Fwm9szU=; b=PDUYFa0uhmfbRo4CgVII0c2eQuI7VRUWrTLuHrWTvGhGwx5d0Yw46diafdQi4hWflg uL/GiTIdOMgyIhPHE66jtHVB3dFoaDBhNEckmuDQIZY9blplaBKNKCiEnVYc4Tdhi4Zn ywoFTBOxOGDiPRLJozxK2GoYu0tlD7ym171PlJj8c5YUalw/VR5mwJkwxAsM4p8lYYwd t6pmwYF5EXvBrvygHaA6qhktzj1nPqHKu/6HIwwgIqtKJqbEOQYYqeSsVWI0FRLTJLMB NR6yCW1E4zi2plP2wTTTIqZjh/sCbgZaPGdzl/zEa/FsQ0/A4WmbwxBIiM9+RShQJ2Lg xhaw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=L49wCQSF; dkim=pass header.i=@codeaurora.org header.s=default header.b=L49wCQSF; 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 f64si5799174pfa.115.2018.03.12.06.19.45; Mon, 12 Mar 2018 06:20:00 -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=L49wCQSF; dkim=pass header.i=@codeaurora.org header.s=default header.b=L49wCQSF; 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 S932435AbeCLNSP (ORCPT + 99 others); Mon, 12 Mar 2018 09:18:15 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:41650 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751180AbeCLNP2 (ORCPT ); Mon, 12 Mar 2018 09:15:28 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id BE3D76070A; Mon, 12 Mar 2018 13:15:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1520860526; bh=KNlLgl/yxnbIkzFykQiEU5TnY0ekOxDXQv7GPv/rBpg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=L49wCQSF1OFo7sauhhHF92DwDQ7+J2jns8/lj0tenV0vNizgpKyVasxYlyi25QqkC wVjCPvi4Ap/6JUudZkh0YnDGOuaw0LbTsi8WTTo+nUe2wDtVDia9uSE9mzngu8rztB p7JS3jzAuXc4E4UDndK3CcWO5QtfSd2Cyo1FGHt8= 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 absahu-linux.qualcomm.com (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: absahu@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id AC78E6081C; Mon, 12 Mar 2018 13:15:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1520860526; bh=KNlLgl/yxnbIkzFykQiEU5TnY0ekOxDXQv7GPv/rBpg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=L49wCQSF1OFo7sauhhHF92DwDQ7+J2jns8/lj0tenV0vNizgpKyVasxYlyi25QqkC wVjCPvi4Ap/6JUudZkh0YnDGOuaw0LbTsi8WTTo+nUe2wDtVDia9uSE9mzngu8rztB p7JS3jzAuXc4E4UDndK3CcWO5QtfSd2Cyo1FGHt8= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org AC78E6081C 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=absahu@codeaurora.org From: Abhishek Sahu To: Andy Gross , Wolfram Sang Cc: David Brown , Sricharan R , Austin Christ , linux-arm-msm@vger.kernel.org, linux-soc@vger.kernel.org, linux-i2c@vger.kernel.org, linux-kernel@vger.kernel.org, Abhishek Sahu Subject: [PATCH v2 03/13] i2c: qup: minor code reorganization for use_dma Date: Mon, 12 Mar 2018 18:44:52 +0530 Message-Id: <1520860502-14886-4-git-send-email-absahu@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1520860502-14886-1-git-send-email-absahu@codeaurora.org> References: <1520860502-14886-1-git-send-email-absahu@codeaurora.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 1. Assigns use_dma in qup_dev structure itself which will help in subsequent patches to determine the mode in IRQ handler. 2. Does minor code reorganization for loops to reduce the unnecessary comparison and assignment. Signed-off-by: Abhishek Sahu Reviewed-by: Austin Christ Reviewed-by: Andy Gross --- * Changes from v1: None drivers/i2c/busses/i2c-qup.c | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/drivers/i2c/busses/i2c-qup.c b/drivers/i2c/busses/i2c-qup.c index 75e9819..f6ea074 100644 --- a/drivers/i2c/busses/i2c-qup.c +++ b/drivers/i2c/busses/i2c-qup.c @@ -181,6 +181,8 @@ struct qup_i2c_dev { /* dma parameters */ bool is_dma; + /* To check if the current transfer is using DMA */ + bool use_dma; struct dma_pool *dpool; struct qup_i2c_tag start_tag; struct qup_i2c_bam brx; @@ -1288,7 +1290,7 @@ static int qup_i2c_xfer_v2(struct i2c_adapter *adap, int num) { struct qup_i2c_dev *qup = i2c_get_adapdata(adap); - int ret, len, idx = 0, use_dma = 0; + int ret, len, idx = 0; qup->bus_err = 0; qup->qup_err = 0; @@ -1317,13 +1319,12 @@ static int qup_i2c_xfer_v2(struct i2c_adapter *adap, len = (msgs[idx].len > qup->out_fifo_sz) || (msgs[idx].len > qup->in_fifo_sz); - if ((!is_vmalloc_addr(msgs[idx].buf)) && len) { - use_dma = 1; - } else { - use_dma = 0; + if (is_vmalloc_addr(msgs[idx].buf) || !len) break; - } } + + if (idx == num) + qup->use_dma = true; } idx = 0; @@ -1347,15 +1348,17 @@ static int qup_i2c_xfer_v2(struct i2c_adapter *adap, reinit_completion(&qup->xfer); - if (use_dma) { + if (qup->use_dma) { ret = qup_i2c_bam_xfer(adap, &msgs[idx], num); + qup->use_dma = false; + break; } else { if (msgs[idx].flags & I2C_M_RD) ret = qup_i2c_read_one_v2(qup, &msgs[idx]); else ret = qup_i2c_write_one_v2(qup, &msgs[idx]); } - } while ((idx++ < (num - 1)) && !use_dma && !ret); + } while ((idx++ < (num - 1)) && !ret); if (!ret) ret = qup_i2c_change_state(qup, QUP_RESET_STATE); -- QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation