Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp1119134ybi; Wed, 3 Jul 2019 09:48:36 -0700 (PDT) X-Google-Smtp-Source: APXvYqxsiHBMmYBaTad8WzYo25ouvBMb8DydZLL85RXFujKRXpc+9QUJanjs1gwCAqZksBaLJLjT X-Received: by 2002:a63:4d50:: with SMTP id n16mr38387329pgl.146.1562172516081; Wed, 03 Jul 2019 09:48:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562172516; cv=none; d=google.com; s=arc-20160816; b=c/0/G4gO6Lyroqdxay8X9KlNeUPbJutpTyMSP5gBIZL93C8Z6yvQIkCEekH7NqpkdN BrWDahql85wwsy0ZhqNfrinwvtgLRo9+jn3eUlRfxiNHyEvprwwDqwLZwffQQtekr+RP aZ4ZHPfwnm0cSmqPF8UvVc/QpUGAobKBnUpZ4oo293ufWfn1xzoO6V01XO+dWTx1dSbS f8o/UYcV+IPtOThjuxKRFinxy5i/NydZrHL7RPmo625ASPp8RNuy6p//TBfrafBkb7Jc IKq3SyPbG9XJu6SBvZwutnvwW8gMc80QBXKCvriWSBn0NvD6rzhWKl953CDq7a5rv4WN Yvgw== 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=GlAqmfHkGJMQ6NWOPPP3kRAAFGBLmaL+NG/hE+Lf6nQ=; b=J85jg35bIbv+uZTA7SKWFDVyeGJ1ueEs2depLy1WmpENcbEVW1hvhfkx9/DmZIOWjZ GzmrqQtzNxL9fvE+fy1hjaPErjcQFZ9yNbgR9CBPNV6bsIxxSFvz3MJbGsnweSpNflcD dMI86/EoRoFFRs9Wxf2yzh7GHNZZ7QyPTKqMXjhV6Q4S+cbX18QUJmaYQxmCEQ5Sjaff fKL/oRGI+P1WG2nXLLiE+9xYP7/QgS6f/uDGA6FqEDmGN1zF1NqghuVXkkZ5BOVUPlsy YahnsVJUi7m+M6dHMm/cINlfOXWHc+zXZFbwtsz/sIxfSNb7EvLEkfi+jQySmVeevu4+ 7nQQ== 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 j14si2767070pgj.519.2019.07.03.09.48.20; Wed, 03 Jul 2019 09:48:36 -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; 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 S1726988AbfGCQrm (ORCPT + 99 others); Wed, 3 Jul 2019 12:47:42 -0400 Received: from unicorn.mansr.com ([81.2.72.234]:58034 "EHLO unicorn.mansr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726430AbfGCQrm (ORCPT ); Wed, 3 Jul 2019 12:47:42 -0400 Received: by unicorn.mansr.com (Postfix, from userid 51770) id 7637C1538A; Wed, 3 Jul 2019 17:47:39 +0100 (BST) From: Mans Rullgard To: linux-i2c@vger.kernel.org Cc: linux-kernel@vger.kernel.org Subject: [RESEND][PATCH] i2c: imx: add support for I2C_M_STOP flag Date: Wed, 3 Jul 2019 17:47:32 +0100 Message-Id: <20190703164732.27973-1-mans@mansr.com> X-Mailer: git-send-email 2.22.0 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 7bd409eaf0ac..a7f801bb5dc9 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.22.0