Received: by 2002:ac0:8845:0:0:0:0:0 with SMTP id g63csp2100844img; Wed, 27 Feb 2019 10:22:22 -0800 (PST) X-Google-Smtp-Source: AHgI3IYVT8UUL2qM+WinWHCJLkOXGm+CzYXyeF3B/vcSqVdLlR5Z14yCI+lkeHsyZ/21+rJWdTOk X-Received: by 2002:a63:43:: with SMTP id 64mr4257909pga.64.1551291742768; Wed, 27 Feb 2019 10:22:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551291742; cv=none; d=google.com; s=arc-20160816; b=t8nrAXLO9H7MR1jo2KIoB3rOvX3cyZVtjN79XsUkT0I1o3VsY2tDmRWoTbWirUcY3A 5U/mN6DquDvTr8bhH32DTBzXIFPNpR1ItbZH1gQVTWPzcyo/r+uIfLQVlFav1QkcUJnS iM2Mm2CXet/uZQDoeLAUkuiTAqv4hALuCyqAVuFdJhptY7dwop4jaSzoVWZSrBja7wrk pXaIcu4KmMO/nf4D6yjykLOT1+XSYeWRuC9pEZBkN+RMl1zCEZaMi3l14BTD4kWz1m7z eH/4h1KDJ6hp0vELwhqZke08+ei4bhEZAtKpJwoZ07O3HTv7Da8MepYF0wuNbaK9jaQ2 mLKA== 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:mime-version :message-id:date:subject:cc:to:from; bh=stiTfV4sIDWENdi8m/jWIVPKut5nUMjtodEnRxRAeB4=; b=Jf+9lTv7ylb2q+deAiprwFWSuUle/QK8704S+mB9cBtWCDEcFQJ/P7SjjDaMED6/jL YrzCpq0ljP2DkloWI1VdnK5fFBGSobsl/tVupdAvCizkyTMJgJWWNej71qSYsGd8C7bY kXzDLh61fZTIXnrXvWW1vEQYfnizv+qDMyWcjbNMjv2n+YIZKCUc8hunIKI+qXK0OdoF BRuKCPoEfPxXuAvztXjLRazJYgdGNznzgEQGQhxMtFIwZjVNG4B6EbPPBtXXUwrhI880 5myKGMQQ+z1citv7RGQIixr/AfX9L+1X2HTrUZIDW2cXXO2cPXvdKfic2nwfqLLF4lrG FABw== ARC-Authentication-Results: i=1; mx.google.com; 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 r6si15808851plo.269.2019.02.27.10.22.09; Wed, 27 Feb 2019 10:22:22 -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; 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 S1729136AbfB0SVs (ORCPT + 99 others); Wed, 27 Feb 2019 13:21:48 -0500 Received: from unicorn.mansr.com ([81.2.72.234]:41654 "EHLO unicorn.mansr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726594AbfB0SVs (ORCPT ); Wed, 27 Feb 2019 13:21:48 -0500 Received: by unicorn.mansr.com (Postfix, from userid 51770) id 913A515632; Wed, 27 Feb 2019 18:21:46 +0000 (GMT) From: Mans Rullgard To: linux-i2c@vger.kernel.org Cc: linux-kernel@vger.kernel.org Subject: [PATCH] i2c: imx: add support for I2C_M_STOP flag Date: Wed, 27 Feb 2019 18:21:37 +0000 Message-Id: <20190227182137.12100-1-mans@mansr.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add support for the I2C_M_STOP flag to the i2c-imx driver. This allows devices requiring a stop between messages to work with this controller. Signed-off-by: Mans Rullgard --- drivers/i2c/busses/i2c-imx.c | 26 ++++++++++++++++++++++---- 1 file changed, 22 insertions(+), 4 deletions(-) diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c index c406700789e1..43b4d5bc2196 100644 --- a/drivers/i2c/busses/i2c-imx.c +++ b/drivers/i2c/busses/i2c-imx.c @@ -908,10 +908,17 @@ static int i2c_imx_xfer(struct i2c_adapter *adapter, /* read/write data */ for (i = 0; i < num; i++) { - if (i == num - 1) - is_lastmsg = true; + if (is_lastmsg) { + /* previous message had I2C_M_STOP flag set */ + temp = imx_i2c_read_reg(i2c_imx, IMX_I2C_I2CR); + temp |= I2CR_MSTA; + imx_i2c_write_reg(temp, i2c_imx, IMX_I2C_I2CR); + result = i2c_imx_bus_busy(i2c_imx, 1); + if (result) + goto fail0; + } - if (i) { + if (i && !is_lastmsg) { dev_dbg(&i2c_imx->adapter.dev, "<%s> repeated start\n", __func__); temp = imx_i2c_read_reg(i2c_imx, IMX_I2C_I2CR); @@ -921,6 +928,10 @@ static int i2c_imx_xfer(struct i2c_adapter *adapter, if (result) goto fail0; } + + if (i == num - 1 || (msgs[i].flags & I2C_M_STOP)) + is_lastmsg = true; + dev_dbg(&i2c_imx->adapter.dev, "<%s> transfer message: %d\n", __func__, i); /* write/read data */ @@ -948,6 +959,13 @@ static int i2c_imx_xfer(struct i2c_adapter *adapter, result = i2c_imx_dma_write(i2c_imx, &msgs[i]); else result = i2c_imx_write(i2c_imx, &msgs[i]); + + if (msgs[i].flags & I2C_M_STOP) { + temp = imx_i2c_read_reg(i2c_imx, IMX_I2C_I2CR); + temp &= ~I2CR_MSTA; + imx_i2c_write_reg(temp, i2c_imx, IMX_I2C_I2CR); + i2c_imx_bus_busy(i2c_imx, 0); + } } if (result) goto fail0; @@ -1034,7 +1052,7 @@ static int i2c_imx_init_recovery_info(struct imx_i2c_struct *i2c_imx, static u32 i2c_imx_func(struct i2c_adapter *adapter) { - return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL + return I2C_FUNC_I2C | I2C_FUNC_PROTOCOL_MANGLING | I2C_FUNC_SMBUS_EMUL | I2C_FUNC_SMBUS_READ_BLOCK_DATA; } -- 2.20.1