Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp172711ybi; Fri, 7 Jun 2019 06:13:01 -0700 (PDT) X-Google-Smtp-Source: APXvYqwYXTvvnxdz7z2Mto6yMBSLdkITVg798GRxK7kcas8QppRP6VwQoBKwMYwoUKEPuF44m8oR X-Received: by 2002:a63:950d:: with SMTP id p13mr2597961pgd.269.1559913181396; Fri, 07 Jun 2019 06:13:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559913181; cv=none; d=google.com; s=arc-20160816; b=Zl4ong5crwEkvx+EjVC/xiFCg9ziB0MkNC6o+iklyPL0814m5rYW0WjNocYlfkdymw DqVEq+2P9YJVO5rYRB9fpGmsubhlvfO5FlmQtOzvh1IggVwUzkk4rQncjOYcfSZcObIS USegZnyk+MWE8lHxCyd498U2UHAI6fwrSfq5oMKm9oXM4yk1PeP/lbYBg7Pcbua8hfXM FHT7iwW4MY8MnfN3H2QmiHlQR8hvLVUvlvAVkMaME8bzbP3AczTsaM8b9v3aLD7Y82R/ sTssZZ7yF378Ba/o21x6ErhvdASZzFSj9ppsnsTqDkiAoHbxERoARTQ34/CtHhKSYy1O Bgog== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=8B6OyIhbpjR5kkAtvY6qwQAdLdINpOU37ixN750jM70=; b=pwsMf2+1BuGxPv0TSSWCzb/Bi6JA9sRySUCJAhsaMh7l3789EFf7kFmKSxNB1ju1YT qbm4iwCAfbr3guHu5MNUjtovvCagaQoRxfLkxNaj/XduPRgIKCwSW3Y/bOt/7xKQCY7b N11xoP0qRfffntz/+DoXlg/1YQekxiRoHKascs0lpuCF6EEBcqSdjDdictqL6q4+xZPV 7s583yazDvLM2y9XUEq2oOS1S4GbEug3lU9fxgTF3eIDvdgjp5nEdeJJI2OeMslJVYrh H4koJqx8jTLtbtu5av48YprytHuOyZFL4+jtUo8pDilf3gm2CvBlL6OQvhsnC3GxMmPo Db+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=rzb1Vy3w; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o3si1637083pgp.183.2019.06.07.06.12.43; Fri, 07 Jun 2019 06:13:01 -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=@nvidia.com header.s=n1 header.b=rzb1Vy3w; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728813AbfFGLsm (ORCPT + 99 others); Fri, 7 Jun 2019 07:48:42 -0400 Received: from hqemgate14.nvidia.com ([216.228.121.143]:15843 "EHLO hqemgate14.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728576AbfFGLsm (ORCPT ); Fri, 7 Jun 2019 07:48:42 -0400 Received: from hqpgpgate102.nvidia.com (Not Verified[216.228.121.13]) by hqemgate14.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Fri, 07 Jun 2019 04:48:37 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate102.nvidia.com (PGP Universal service); Fri, 07 Jun 2019 04:48:39 -0700 X-PGP-Universal: processed; by hqpgpgate102.nvidia.com on Fri, 07 Jun 2019 04:48:39 -0700 Received: from [10.19.65.14] (10.124.1.5) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Fri, 7 Jun 2019 11:48:35 +0000 Subject: Re: [PATCH V5] drivers: i2c: tegra: fix warning/check/error To: Dmitry Osipenko , Laxman Dewangan , Thierry Reding , Jonathan Hunter , , , CC: Shardar Mohammed , Sowjanya Komatineni , Mantravadi Karthik References: <1559885103-9113-1-git-send-email-bbiswas@nvidia.com> From: Bitan Biswas Message-ID: Date: Fri, 7 Jun 2019 04:48:32 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL101.nvidia.com (172.20.187.10) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: quoted-printable DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1559908117; bh=8B6OyIhbpjR5kkAtvY6qwQAdLdINpOU37ixN750jM70=; h=X-PGP-Universal:Subject:To:CC:References:From:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Language: Content-Transfer-Encoding; b=rzb1Vy3woO88UUaic1g20DHLnD5hD7dH7t4GIVBYHXuTyq8gOhoSjbW/htT5qoARi LPBSOxrYHpCS/kxlkZEiMBAsck3kssmJCAelispG9Z44Dbm91XfgPUtvzM0Xm72Ejc zS/PN7/7CL/akHrA8uQiELOc023Mkf4ShEr6tvSTWtqsBv9zPkVDK1Yr2ux2AwTIbb iqc3IjejLZrwkOsXyyjLqIgOaGhxF8V1PgGf37zKmyZcqTPgE42hU07xOf63pPbboz 1+Fc/oj0KUD09tVaPKZqS0J3sTGykZCndT/ZU+wIbA6jys0Gbyrwu6CqkdUcNcbcOV 18pqXTVgLPl4g== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 6/6/19 11:05 PM, Dmitry Osipenko wrote: > 07.06.2019 8:25, Bitan Biswas =D0=BF=D0=B8=D1=88=D0=B5=D1=82: >> Fix checkpatch.pl warning(s)/error(s)/check(s) in i2c-tegra.c >> >> Ignore checkpatch WARNING for 80 character line limit at >> places where renaming fields compromises readability. >> >> Delay of approximately 1msec in flush i2c FIFO polling loop >> achieved by usleep_range call as msleep can take 20msecs. >> >> Remove redundant BUG_ON calls or replace with WARN_ON_ONCE >> as needed. Replace BUG() with error handling code. >> Define I2C_ERR_UNEXPECTED_STATUS for error handling. >> >> Signed-off-by: Bitan Biswas >> --- >> drivers/i2c/busses/i2c-tegra.c | 61 ++++++++++++++++++++++------------= -------- >> 1 file changed, 32 insertions(+), 29 deletions(-) >> >> diff --git a/drivers/i2c/busses/i2c-tegra.c b/drivers/i2c/busses/i2c-teg= ra.c >> index 1dbba39..161eb28 100644 >> --- a/drivers/i2c/busses/i2c-tegra.c >> +++ b/drivers/i2c/busses/i2c-tegra.c >> @@ -67,17 +67,18 @@ >> =20 >> #define DVC_CTRL_REG1 0x000 >> #define DVC_CTRL_REG1_INTR_EN BIT(10) >> -#define DVC_CTRL_REG2 0x004 >> -#define DVC_CTRL_REG3 0x008 >> +#define DVC_CTRL_REG2 BIT(2) >> +#define DVC_CTRL_REG3 BIT(3) >=20 > This is incorrect change, register address should be kept as a hex value > because it is not a bitmask. I shall remove the modification. >=20 > I'd also recommend to just remove the DVC_CTRL_REG2 since it's not used > anywhere in the code. You may also check all of other #defines and > remove everything unused. I shall remove the unused macro DVC_CTRL_REG2 and remove other unused=20 macros. >=20 > You can also check all of variables for a need to be initialized, like > for example "ret" doesn't need to be init'ed in tegra_i2c_xfer() and > some other places. That will be a good clean up as well. I shall clean up the instances I can make out along and remove the ret=20 initialization in tegra_i2c_xfer function. >=20 >> #define DVC_CTRL_REG3_SW_PROG BIT(26) >> #define DVC_CTRL_REG3_I2C_DONE_INTR_EN BIT(30) >> #define DVC_STATUS 0x00c >> #define DVC_STATUS_I2C_DONE_INTR BIT(30) >> =20 >> -#define I2C_ERR_NONE 0x00 >> -#define I2C_ERR_NO_ACK 0x01 >> -#define I2C_ERR_ARBITRATION_LOST 0x02 >> -#define I2C_ERR_UNKNOWN_INTERRUPT 0x04 >> +#define I2C_ERR_NONE 0x0 >> +#define I2C_ERR_NO_ACK BIT(0) >> +#define I2C_ERR_ARBITRATION_LOST BIT(1) >> +#define I2C_ERR_UNKNOWN_INTERRUPT BIT(2) >> +#define I2C_ERR_UNEXPECTED_STATUS BIT(3) >> =20 >> #define PACKET_HEADER0_HEADER_SIZE_SHIFT 28 >> #define PACKET_HEADER0_PACKET_ID_SHIFT 16 >> @@ -280,6 +281,7 @@ struct tegra_i2c_dev { >> u32 bus_clk_rate; >> u16 clk_divisor_non_hs_mode; >> bool is_multimaster_mode; >> + /* xfer_lock: lock to serialize transfer submission and processing */ >> spinlock_t xfer_lock; >> struct dma_chan *tx_dma_chan; >> struct dma_chan *rx_dma_chan; >> @@ -306,7 +308,7 @@ static u32 dvc_readl(struct tegra_i2c_dev *i2c_dev, = unsigned long reg) >> * to the I2C block inside the DVC block >> */ >> static unsigned long tegra_i2c_reg_addr(struct tegra_i2c_dev *i2c_dev, >> - unsigned long reg) >> + unsigned long reg) >> { >> if (i2c_dev->is_dvc) >> reg +=3D (reg >=3D I2C_TX_FIFO) ? 0x10 : 0x40; >> @@ -314,7 +316,7 @@ static unsigned long tegra_i2c_reg_addr(struct tegra= _i2c_dev *i2c_dev, >> } >> =20 >> static void i2c_writel(struct tegra_i2c_dev *i2c_dev, u32 val, >> - unsigned long reg) >> + unsigned long reg) >> { >> writel(val, i2c_dev->base + tegra_i2c_reg_addr(i2c_dev, reg)); >> =20 >> @@ -329,13 +331,13 @@ static u32 i2c_readl(struct tegra_i2c_dev *i2c_dev= , unsigned long reg) >> } >> =20 >> static void i2c_writesl(struct tegra_i2c_dev *i2c_dev, void *data, >> - unsigned long reg, int len) >> + unsigned long reg, int len) >> { >> writesl(i2c_dev->base + tegra_i2c_reg_addr(i2c_dev, reg), data, len); >> } >> =20 >> static void i2c_readsl(struct tegra_i2c_dev *i2c_dev, void *data, >> - unsigned long reg, int len) >> + unsigned long reg, int len) >> { >> readsl(i2c_dev->base + tegra_i2c_reg_addr(i2c_dev, reg), data, len); >> } >> @@ -486,7 +488,7 @@ static int tegra_i2c_flush_fifos(struct tegra_i2c_de= v *i2c_dev) >> dev_warn(i2c_dev->dev, "timeout waiting for fifo flush\n"); >> return -ETIMEDOUT; >> } >> - msleep(1); >> + usleep_range(1000, 2000); >> } >> return 0; >> } >> @@ -525,7 +527,6 @@ static int tegra_i2c_empty_rx_fifo(struct tegra_i2c_= dev *i2c_dev) >> * prevent overwriting past the end of buf >> */ >> if (rx_fifo_avail > 0 && buf_remaining > 0) { >> - BUG_ON(buf_remaining > 3); >> val =3D i2c_readl(i2c_dev, I2C_RX_FIFO); >> val =3D cpu_to_le32(val); >> memcpy(buf, &val, buf_remaining); >> @@ -533,7 +534,6 @@ static int tegra_i2c_empty_rx_fifo(struct tegra_i2c_= dev *i2c_dev) >> rx_fifo_avail--; >> } >> =20 >> - BUG_ON(rx_fifo_avail > 0 && buf_remaining > 0); >> i2c_dev->msg_buf_remaining =3D buf_remaining; >> i2c_dev->msg_buf =3D buf; >> =20 >> @@ -591,7 +591,6 @@ static int tegra_i2c_fill_tx_fifo(struct tegra_i2c_d= ev *i2c_dev) >> * boundary and fault. >> */ >> if (tx_fifo_avail > 0 && buf_remaining > 0) { >> - BUG_ON(buf_remaining > 3); >> memcpy(&val, buf, buf_remaining); >> val =3D le32_to_cpu(val); >> =20 >> @@ -680,10 +679,11 @@ static int tegra_i2c_wait_for_config_load(struct t= egra_i2c_dev *i2c_dev) >> i2c_writel(i2c_dev, I2C_MSTR_CONFIG_LOAD, I2C_CONFIG_LOAD); >> if (in_interrupt()) >> err =3D readl_poll_timeout_atomic(addr, val, val =3D=3D 0, >> - 1000, I2C_CONFIG_LOAD_TIMEOUT); >> + 1000, >> + I2C_CONFIG_LOAD_TIMEOUT); >> else >> - err =3D readl_poll_timeout(addr, val, val =3D=3D 0, >> - 1000, I2C_CONFIG_LOAD_TIMEOUT); >> + err =3D readl_poll_timeout(addr, val, val =3D=3D 0, 1000, >> + I2C_CONFIG_LOAD_TIMEOUT); >> =20 >> if (err) { >> dev_warn(i2c_dev->dev, >> @@ -856,10 +856,13 @@ static irqreturn_t tegra_i2c_isr(int irq, void *de= v_id) >> =20 >> if (!i2c_dev->is_curr_dma_xfer) { >> if (i2c_dev->msg_read && (status & I2C_INT_RX_FIFO_DATA_REQ)) { >> - if (i2c_dev->msg_buf_remaining) >> + if (i2c_dev->msg_buf_remaining) { >> tegra_i2c_empty_rx_fifo(i2c_dev); >> - else >> - BUG(); >> + } else { >> + dev_err(i2c_dev->dev, "unexpected rx data request\n"); >> + i2c_dev->msg_err |=3D I2C_ERR_UNEXPECTED_STATUS; >> + goto err; >> + } >> } >> =20 >> if (!i2c_dev->msg_read && (status & I2C_INT_TX_FIFO_DATA_REQ)) { >> @@ -885,7 +888,7 @@ static irqreturn_t tegra_i2c_isr(int irq, void *dev_= id) >> if (status & I2C_INT_PACKET_XFER_COMPLETE) { >> if (i2c_dev->is_curr_dma_xfer) >> i2c_dev->msg_buf_remaining =3D 0; >> - BUG_ON(i2c_dev->msg_buf_remaining); >> + WARN_ON_ONCE(i2c_dev->msg_buf_remaining); >> complete(&i2c_dev->msg_complete); >> } >> goto done; >> @@ -1024,7 +1027,7 @@ static int tegra_i2c_issue_bus_clear(struct i2c_ad= apter *adap) >> } >> =20 >> static int tegra_i2c_xfer_msg(struct tegra_i2c_dev *i2c_dev, >> - struct i2c_msg *msg, enum msg_end_type end_state) >> + struct i2c_msg *msg, enum msg_end_type end_state) >=20 > Probably won't hurt to carry the "enum msg_end_type end_state" to a new > line. OK >=20 >> { >> u32 packet_header; >> u32 int_mask; >> @@ -1161,9 +1164,8 @@ static int tegra_i2c_xfer_msg(struct tegra_i2c_dev= *i2c_dev, >> if (err) >> return err; >> =20 >> - time_left =3D wait_for_completion_timeout( >> - &i2c_dev->dma_complete, >> - msecs_to_jiffies(xfer_time)); >> + time_left =3D wait_for_completion_timeout(&i2c_dev->dma_complete, >> + msecs_to_jiffies(xfer_time)); >> if (time_left =3D=3D 0) { >> dev_err(i2c_dev->dev, "DMA transfer timeout\n"); >> dmaengine_terminate_sync(i2c_dev->msg_read ? >> @@ -1225,7 +1227,7 @@ static int tegra_i2c_xfer_msg(struct tegra_i2c_dev= *i2c_dev, >> } >> =20 >> static int tegra_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg msg= s[], >> - int num) >> + int num) >> { >> struct tegra_i2c_dev *i2c_dev =3D i2c_get_adapdata(adap); >> int i; >> @@ -1273,12 +1275,12 @@ static void tegra_i2c_parse_dt(struct tegra_i2c_= dev *i2c_dev) >> int ret; >> =20 >> ret =3D of_property_read_u32(np, "clock-frequency", >> - &i2c_dev->bus_clk_rate); >> + &i2c_dev->bus_clk_rate); >> if (ret) >> i2c_dev->bus_clk_rate =3D 100000; /* default clock rate */ >> =20 >> i2c_dev->is_multimaster_mode =3D of_property_read_bool(np, >> - "multi-master"); >> + "multi-master"); >=20 > You can avoid the line-split with something like this: >=20 > ret =3D of_property_read_bool(np, "multi-master"); > i2c_dev->is_multimaster_mode =3D ret; >=20 OK. I shall share the patches next. -Thanks, Bitan