From nobody Thu Apr 2 07:43:58 2026 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2810F3859C5; Mon, 30 Mar 2026 07:30:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; cv=none; b=o6BXVud0aTjHoOGaSTmoM7w5NqJEcZpctDS+g4htBFtMSQ7wXhmLwfscNJ9x5t36TEhfQiV9A862pwKt8+rQkgqpY6T1S1dJaSkeeVQaF71o78PDYtYBZwuzF808UpE6lrmJ9LFoCbnbbGTQQoeoa8TB+9f1935xRqBh+vPJBoU= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; c=relaxed/simple; bh=jeJK/0eq1Juwssxo5nwTiMxxOoLDoi/bwnaw/cpSUuQ=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=Idt1fZyZN3Pc7xRG7c1ZVfaq2jWs03Ny6pR2mV8UWrCJ8jJtB/ZgmnP72m1QkSM3QncL6ODwTL7o+T2g+koR8itvbfEXeFNQxjfEauDPczwDt7k9K9UK6CPv0/pykmFnl4hPnv9Mw5Ga1ZymfOmu2uPrY4AW6QhQd+XDSH/CtpE= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=H4chgCCL; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="H4chgCCL" Received: by smtp.kernel.org (Postfix) with ESMTPS id D3BB5C4CEF7; Mon, 30 Mar 2026 07:30:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1774855835; bh=jeJK/0eq1Juwssxo5nwTiMxxOoLDoi/bwnaw/cpSUuQ=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=H4chgCCLXKFNvFgh7JzxWjeoTUzf8/hdOicdhlvxRLrZ8y0R1pGs+9eKg07poylYO i8jzveeWw/EJAajv//5MaGBrDXGnwq/yPwQ8kpkhyvIXp9ZsilGF8dXrX9xMb/kT9v PKXV0qpNkrsq5MnhRugCpmwdw+UY/hGZs8tRZrf9q1d7JuE/j6VsCnDzBKtKs+vkvx wp+3woz9D2cvMJeSAAUc/cSJVb/NwW+9fOsCC/hOJDWGY5xmOwc7gcSY/hcnoZgcdU hrW2OQL+6zKmEqu/cOyWHgwMULHWchVUu9DZsdHtg+7fDf6omdpPGJKQ2Llx2OClas +d16kZVtTOYfg== Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id C37C8FF4958; Mon, 30 Mar 2026 07:30:35 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Mon, 30 Mar 2026 15:30:31 +0800 Subject: [PATCH v4 1/4] dt-bindings: i2c: add support for AE350 I2C controller Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260330-atciic100-v4-1-d40822f63e4e@andestech.com> References: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> In-Reply-To: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> To: Andi Shyti , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Paul Walmsley , Palmer Dabbelt , Albert Ou , Alexandre Ghiti Cc: linux-i2c@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, Ben Zong-You Xie , Conor Dooley X-Mailer: b4 0.15-dev-47773 X-Developer-Signature: v=1; a=ed25519-sha256; t=1774855834; l=2147; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=QY1WQtlgEcHyWij1EoGxUJsa8Gq3KZczgBDeH8ReATU=; b=aHryHMU39d3nmQBj2v/ecoPILsTHhtNBnf2NaJeaHpgWmMN4mWwlO7BjgIc2PiMrQS1qMdSQz wPlUIdPFk0jB10HmN/v0kh3YrevU0Xe1sxNUcUYN1f1zHBHHq3cApl+ X-Developer-Key: i=ben717@andestech.com; a=ed25519; pk=nb8L7zQKGJpYk0yvrYKjViOZ34A36g1ZIsCmCsP518s= X-Endpoint-Received: by B4 Relay for ben717@andestech.com/20260120 with auth_id=610 X-Original-From: Ben Zong-You Xie Reply-To: ben717@andestech.com From: Ben Zong-You Xie Document device tree bindings for the I2C controller on Andes AE350 platform. The ATCIIC100 is a dedicated I2C controller IP developed by Andes Technology. This IP block is a core component of the Andes AE350 platform, which serves as a reference architecture for SoC designs. The QiLai SoC also integrates this I2C controller. The binding introduces the following compatible strings: - "andestech,qilai-i2c": For the implementation integrated into the Andes QiLai SoC. - "andestech,ae350-i2c": As a fallback compatible string representing the base IP design used across the AE350 platform architecture. Acked-by: Conor Dooley Signed-off-by: Ben Zong-You Xie --- .../bindings/i2c/andestech,ae350-i2c.yaml | 45 ++++++++++++++++++= ++++ 1 file changed, 45 insertions(+) diff --git a/Documentation/devicetree/bindings/i2c/andestech,ae350-i2c.yaml= b/Documentation/devicetree/bindings/i2c/andestech,ae350-i2c.yaml new file mode 100644 index 000000000000..59a521fb249b --- /dev/null +++ b/Documentation/devicetree/bindings/i2c/andestech,ae350-i2c.yaml @@ -0,0 +1,45 @@ +# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/i2c/andestech,ae350-i2c.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Andes I2C controller on AE350 platform + +maintainers: + - Ben Zong-You Xie + +allOf: + - $ref: /schemas/i2c/i2c-controller.yaml# + +properties: + compatible: + oneOf: + - items: + - enum: + - andestech,qilai-i2c + - const: andestech,ae350-i2c + - const: andestech,ae350-i2c + + reg: + maxItems: 1 + + interrupts: + maxItems: 1 + +required: + - compatible + - reg + - interrupts + +unevaluatedProperties: false + +examples: + - | + #include + + i2c@f0a00000 { + compatible =3D "andestech,ae350-i2c"; + reg =3D <0xf0a00000 0x100000>; + interrupts =3D <6 IRQ_TYPE_LEVEL_HIGH>; + }; --=20 2.34.1 From nobody Thu Apr 2 07:43:58 2026 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2807037F00E; Mon, 30 Mar 2026 07:30:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; cv=none; b=C7+oYNJ5msPfWyaPNKBIdcykYlMiaVC1UKSz8U3IhcWpuT3mzVSz8qYe7PbAqrCVsSqknlQhrcngPDPuyeF5od67nNa1kWGU8uBK/HxrW233enQTxUO4cnEJMYIcIu2wSIkEkBNRbvNtLisEr8GfjVElcqGkVPSBfWDw5TTibsY= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; c=relaxed/simple; bh=5fPzt3XdA3Yulgacz2ac1L2irSRMu6WojI6m9w7c+2U=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=ipxVNHSEQ1mWHCGPEBDWiORYNR9gUHUOWgbdH+efEVCXLoqUii0/pdbDsJ/Tq1f4KF5FY4e3kQ2G+eT7bgKeqD0edvrXhnfqFsFWqVIbLn2tRvHmjWLXn5COjs/GOVd1uaWyZF+xBACIzjy51kCRhD0Ho+43zOGNXxazm5foGTg= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=aUAxQAgJ; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="aUAxQAgJ" Received: by smtp.kernel.org (Postfix) with ESMTPS id E3779C2BCB4; Mon, 30 Mar 2026 07:30:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1774855835; bh=5fPzt3XdA3Yulgacz2ac1L2irSRMu6WojI6m9w7c+2U=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=aUAxQAgJDDgZDdGuVizi5Ucm1Jqjc7ZH2wF19bxEqcbt+KnFpxi/sXaGLT/YtAG/O R6+xniN/pDxSDgezq1O93aJaju2kAELcYFmJPn8d2VIi9/vsXO72r9uYpJMlVohiF8 KxQQtu5hWamLzCtAu/jLWuScUNWKfPo6ny7g2YJkYvEVr1VCeuQ8OniwZqClXXQwJ9 8zJ7G3u5p9ffattD3Dg3JIpPI62/ApwHDGoK6DNJfAyLmvnIl4+iurpPIsoY6FFS2M UuUlkboItZv5eDdIPo1XoPytCoV51QnjI0rAsC1uDmV5iyuKz3qEpJIDarEBl9kj/P IP/W8lGk40+lA== Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id D5373FF4959; Mon, 30 Mar 2026 07:30:35 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Mon, 30 Mar 2026 15:30:32 +0800 Subject: [PATCH v4 2/4] i2c: add Andes I2C driver support Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260330-atciic100-v4-2-d40822f63e4e@andestech.com> References: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> In-Reply-To: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> To: Andi Shyti , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Paul Walmsley , Palmer Dabbelt , Albert Ou , Alexandre Ghiti Cc: linux-i2c@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, Ben Zong-You Xie X-Mailer: b4 0.15-dev-47773 X-Developer-Signature: v=1; a=ed25519-sha256; t=1774855834; l=11439; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=3+VjWSgAEZB0R4IY99RGMkxW2+TuaVt98VIntlANnLM=; b=EILeU0fgt0YGmdEA/+N7Yj5wG0hAHk5WxST/m07dWsCiCmN5QgrDe/tpDi/8s3lWAz2AHV3LL MOGCQV4jSufCQVMIHMuuqDYe/JUkeQVWgJnkbniW/MeNAhVPtdtQkoO X-Developer-Key: i=ben717@andestech.com; a=ed25519; pk=nb8L7zQKGJpYk0yvrYKjViOZ34A36g1ZIsCmCsP518s= X-Endpoint-Received: by B4 Relay for ben717@andestech.com/20260120 with auth_id=610 X-Original-From: Ben Zong-You Xie Reply-To: ben717@andestech.com From: Ben Zong-You Xie Add support for Andes I2C driver. Andes I2C can act as either a controller or a target, depending on the control register settings. Now, we only support controller mode. Signed-off-by: Ben Zong-You Xie --- drivers/i2c/busses/Kconfig | 10 ++ drivers/i2c/busses/Makefile | 1 + drivers/i2c/busses/i2c-andes.c | 341 +++++++++++++++++++++++++++++++++++++= ++++ 3 files changed, 352 insertions(+) diff --git a/drivers/i2c/busses/Kconfig b/drivers/i2c/busses/Kconfig index 7cb6b9b864a7..6aaa5a1223c2 100644 --- a/drivers/i2c/busses/Kconfig +++ b/drivers/i2c/busses/Kconfig @@ -446,6 +446,16 @@ config I2C_AT91_SLAVE_EXPERIMENTAL - There are some mismatches with a SAMA5D4 as slave and a SAMA5D2 as master. =20 +config I2C_ANDES + tristate "Andes I2C Controller" + depends on ARCH_ANDES || COMPILE_TEST + help + If you say yes to this option, support will be included for the + Andes I2C controller. + + This support is also available as a module. If so, the module + will be called i2c-andes. + config I2C_AU1550 tristate "Au1550/Au1200/Au1300 SMBus interface" depends on MIPS_ALCHEMY diff --git a/drivers/i2c/busses/Makefile b/drivers/i2c/busses/Makefile index 547123ab351f..89d85d10f8d2 100644 --- a/drivers/i2c/busses/Makefile +++ b/drivers/i2c/busses/Makefile @@ -41,6 +41,7 @@ obj-$(CONFIG_I2C_ASPEED) +=3D i2c-aspeed.o obj-$(CONFIG_I2C_AT91) +=3D i2c-at91.o i2c-at91-y :=3D i2c-at91-core.o i2c-at91-master.o i2c-at91-$(CONFIG_I2C_AT91_SLAVE_EXPERIMENTAL) +=3D i2c-at91-slave.o +obj-$(CONFIG_I2C_ANDES) +=3D i2c-andes.o obj-$(CONFIG_I2C_AU1550) +=3D i2c-au1550.o obj-$(CONFIG_I2C_AXXIA) +=3D i2c-axxia.o obj-$(CONFIG_I2C_BCM2835) +=3D i2c-bcm2835.o diff --git a/drivers/i2c/busses/i2c-andes.c b/drivers/i2c/busses/i2c-andes.c new file mode 100644 index 000000000000..5f135d8c9b13 --- /dev/null +++ b/drivers/i2c/busses/i2c-andes.c @@ -0,0 +1,341 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * Driver for Andes I2C controller, used in Andes AE350 platform and QiLai= SoC + * + * Copyright (C) 2026 Andes Technology Corporation. + */ + +#include +#include +#include +#include +#include +#include +#include +#include + +#define ANDES_I2C_ID_REG 0x0 +#define ANDES_I2C_ID_MASK GENMASK(31, 8) +#define ANDES_I2C_ID 0x020210 + +#define ANDES_I2C_CFG_REG 0x10 +#define ANDES_I2C_CFG_FIFOSIZE GENMASK(1, 0) + +#define ANDES_I2C_INTEN_REG 0x14 +#define ANDES_I2C_INTEN_FIFO_EMPTY BIT(0) +#define ANDES_I2C_INTEN_FIFO_FULL BIT(1) +#define ANDES_I2C_INTEN_CMPL BIT(9) + +#define ANDES_I2C_STATUS_REG 0x18 +#define ANDES_I2C_STATUS_FIFO_EMPTY BIT(0) +#define ANDES_I2C_STATUS_FIFO_FULL BIT(1) +#define ANDES_I2C_STATUS_ADDR_HIT BIT(3) +#define ANDES_I2C_STATUS_CMPL BIT(9) +#define ANDES_I2C_STATUS_W1C GENMASK(9, 3) + +#define ANDES_I2C_ADDR_REG 0x1C + +#define ANDES_I2C_DATA_REG 0x20 + +#define ANDES_I2C_CTRL_REG 0x24 +#define ANDES_I2C_CTRL_DATA_CNT GENMASK(7, 0) +#define ANDES_I2C_CTRL_DIR BIT(8) +#define ANDES_I2C_CTRL_PHASE GENMASK(12, 9) + +#define ANDES_I2C_CMD_REG 0x28 +#define ANDES_I2C_CMD_ACTION GENMASK(2, 0) +#define ANDES_I2C_CMD_TRANS BIT(0) + +#define ANDES_I2C_SETUP_REG 0x2C +#define ANDES_I2C_SETUP_IICEN BIT(0) +#define ANDES_I2C_SETUP_REQ BIT(2) + +#define ANDES_I2C_TPM_REG 0x30 + +#define ANDES_I2C_TIMEOUT_US 400000 +#define ANDES_I2C_TIMEOUT usecs_to_jiffies(ANDES_I2C_TIMEOUT_US) + +#define ANDES_I2C_MAX_DATA_LEN 256 + +struct andes_i2c { + struct i2c_adapter adap; + struct completion completion; + spinlock_t lock; + struct regmap *map; + u8 *buf; + unsigned int fifo_size; + int irq; + u16 buf_len; + bool addr_hit; + bool xfer_done; +}; + +static const struct regmap_config andes_i2c_regmap_config =3D { + .name =3D "andes_i2c", + .reg_bits =3D 32, + .reg_stride =3D 4, + .val_bits =3D 32, + .pad_bits =3D 0, + .max_register =3D ANDES_I2C_TPM_REG, + .cache_type =3D REGCACHE_NONE, +}; + +static void andes_i2c_xfer_common(struct andes_i2c *i2c, u32 status) +{ + unsigned long flags; + unsigned int fsize =3D i2c->fifo_size; + unsigned int val; + + spin_lock_irqsave(&i2c->lock, flags); + if (status & ANDES_I2C_STATUS_FIFO_EMPTY) { + /* Disable the FIFO empty interrupt for the last write */ + if (i2c->buf_len <=3D fsize) { + fsize =3D i2c->buf_len; + regmap_clear_bits(i2c->map, ANDES_I2C_INTEN_REG, + ANDES_I2C_INTEN_FIFO_EMPTY); + } + + while (fsize--) { + val =3D *i2c->buf++; + regmap_write(i2c->map, ANDES_I2C_DATA_REG, val); + i2c->buf_len--; + } + } else if (status & ANDES_I2C_STATUS_FIFO_FULL) { + while (fsize--) { + regmap_read(i2c->map, ANDES_I2C_DATA_REG, &val); + *i2c->buf++ =3D (u8)val; + i2c->buf_len--; + } + } + + if (status & ANDES_I2C_STATUS_CMPL) { + i2c->xfer_done =3D true; + if (status & ANDES_I2C_STATUS_ADDR_HIT) + i2c->addr_hit =3D true; + + /* Write 1 to clear the status */ + regmap_set_bits(i2c->map, ANDES_I2C_STATUS_REG, + ANDES_I2C_STATUS_W1C); + + /* For the last read, retrieve all remaining data in FIFO. */ + while (i2c->buf_len > 0) { + regmap_read(i2c->map, ANDES_I2C_DATA_REG, &val); + *i2c->buf++ =3D (u8)val; + i2c->buf_len--; + } + } + + spin_unlock_irqrestore(&i2c->lock, flags); +} + +static irqreturn_t andes_i2c_irq_handler(int irq, void *data) +{ + struct andes_i2c *i2c =3D data; + u32 i2c_status; + + regmap_read(i2c->map, ANDES_I2C_STATUS_REG, &i2c_status); + andes_i2c_xfer_common(i2c, i2c_status); + if (i2c->xfer_done) + complete(&i2c->completion); + + return IRQ_HANDLED; +} + +static int andes_i2c_xfer_wait(struct andes_i2c *i2c, struct i2c_msg *msg) +{ + unsigned int mask; + unsigned int i2c_ctrl; + + /* + * Set the data count. If there are 256 bytes to be transmitted, write + * zero to the data count field. + */ + regmap_update_bits(i2c->map, ANDES_I2C_CTRL_REG, + ANDES_I2C_CTRL_DATA_CNT, + FIELD_PREP(ANDES_I2C_CTRL_DATA_CNT, i2c->buf_len)); + + regmap_set_bits(i2c->map, ANDES_I2C_CTRL_REG, ANDES_I2C_CTRL_PHASE); + if (msg->flags & I2C_M_RD) + regmap_set_bits(i2c->map, ANDES_I2C_CTRL_REG, + ANDES_I2C_CTRL_DIR); + else + regmap_clear_bits(i2c->map, ANDES_I2C_CTRL_REG, + ANDES_I2C_CTRL_DIR); + + regmap_write(i2c->map, ANDES_I2C_ADDR_REG, msg->addr); + + if (i2c->irq >=3D 0) { + mask =3D ANDES_I2C_INTEN_CMPL; + mask |=3D (msg->flags & I2C_M_RD) ? ANDES_I2C_INTEN_FIFO_FULL + : ANDES_I2C_INTEN_FIFO_EMPTY; + regmap_set_bits(i2c->map, ANDES_I2C_INTEN_REG, mask); + } + + regmap_set_bits(i2c->map, ANDES_I2C_CMD_REG, ANDES_I2C_CMD_TRANS); + if (i2c->irq >=3D 0) { + unsigned long time_left; + + time_left =3D wait_for_completion_timeout(&i2c->completion, + ANDES_I2C_TIMEOUT); + if (!time_left) + return -ETIMEDOUT; + + if (!i2c->addr_hit) + return -ENXIO; + + regmap_write(i2c->map, ANDES_I2C_INTEN_REG, 0); + reinit_completion(&i2c->completion); + } else { + unsigned int val; + int ret; + + mask =3D ANDES_I2C_STATUS_CMPL; + mask |=3D (msg->flags & I2C_M_RD) ? ANDES_I2C_STATUS_FIFO_FULL + : ANDES_I2C_STATUS_FIFO_EMPTY; + while (!i2c->xfer_done) { + ret =3D regmap_read_poll_timeout(i2c->map, + ANDES_I2C_STATUS_REG, + val, val & mask, 2000, + ANDES_I2C_TIMEOUT_US); + if (ret) + return ret; + + andes_i2c_xfer_common(i2c, val); + } + + if (!i2c->addr_hit) + return -ENXIO; + } + + /* Check if all data is successfully transmitted */ + regmap_read(i2c->map, ANDES_I2C_CTRL_REG, &i2c_ctrl); + if (FIELD_GET(ANDES_I2C_CTRL_DATA_CNT, i2c_ctrl)) + return -EIO; + + return 0; +} + +static int andes_i2c_xfer(struct i2c_adapter *adap, struct i2c_msg *msg, + int num) +{ + int i; + struct i2c_msg *m; + struct andes_i2c *i2c =3D i2c_get_adapdata(adap); + int ret; + + for (i =3D 0; i < num; i++) { + m =3D &msg[i]; + i2c->addr_hit =3D false; + i2c->buf =3D m->buf; + i2c->buf_len =3D m->len; + i2c->xfer_done =3D false; + ret =3D andes_i2c_xfer_wait(i2c, m); + if (ret < 0) + return ret; + } + + return num; +} + +static u32 andes_i2c_func(struct i2c_adapter *adap) +{ + return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL; +} + +static struct i2c_algorithm andes_i2c_algo =3D { + .xfer =3D andes_i2c_xfer, + .functionality =3D andes_i2c_func, +}; + +static const struct i2c_adapter_quirks andes_i2c_quirks =3D { + .flags =3D I2C_AQ_NO_ZERO_LEN, + .max_write_len =3D ANDES_I2C_MAX_DATA_LEN, + .max_read_len =3D ANDES_I2C_MAX_DATA_LEN, +}; + +static int andes_i2c_probe(struct platform_device *pdev) +{ + struct device *dev =3D &pdev->dev; + struct andes_i2c *i2c; + void __iomem *reg_base; + u32 i2c_id; + int ret; + struct i2c_adapter *adap; + + i2c =3D devm_kzalloc(dev, sizeof(*i2c), GFP_KERNEL); + if (!i2c) + return -ENOMEM; + + reg_base =3D devm_platform_ioremap_resource(pdev, 0); + if (IS_ERR(reg_base)) + return dev_err_probe(dev, PTR_ERR(reg_base), + "failed to map I/O space\n"); + + i2c->map =3D devm_regmap_init_mmio(dev, reg_base, + &andes_i2c_regmap_config); + if (IS_ERR(i2c->map)) + return dev_err_probe(dev, PTR_ERR(i2c->map), + "failed to initialize regmap\n"); + + regmap_read(i2c->map, ANDES_I2C_ID_REG, &i2c_id); + if (FIELD_GET(ANDES_I2C_ID_MASK, i2c_id) !=3D ANDES_I2C_ID) + return dev_err_probe(dev, -ENODEV, "unmatched hardware ID 0x%x\n", + i2c_id); + + i2c->irq =3D platform_get_irq(pdev, 0); + if (i2c->irq >=3D 0) { + ret =3D devm_request_irq(dev, i2c->irq, andes_i2c_irq_handler, 0, + dev_name(dev), i2c); + if (ret < 0) + return dev_err_probe(dev, ret, "unable to request IRQ %d\n", + i2c->irq); + } else { + dev_warn(dev, "no IRQ resource, falling back to poll mode\n"); + } + + spin_lock_init(&i2c->lock); + init_completion(&i2c->completion); + adap =3D &i2c->adap; + strscpy(adap->name, pdev->name, sizeof(adap->name)); + adap->algo =3D &andes_i2c_algo; + adap->class =3D I2C_CLASS_HWMON; + adap->dev.parent =3D dev; + adap->dev.of_node =3D dev->of_node; + adap->owner =3D THIS_MODULE; + adap->quirks =3D &andes_i2c_quirks; + adap->retries =3D 1; + adap->timeout =3D ANDES_I2C_TIMEOUT; + i2c_set_adapdata(adap, i2c); + platform_set_drvdata(pdev, i2c); + ret =3D devm_i2c_add_adapter(dev, adap); + if (ret) + return dev_err_probe(dev, ret, "failed to add adapter\n"); + + regmap_read(i2c->map, ANDES_I2C_CFG_REG, &i2c->fifo_size); + i2c->fifo_size =3D 2 << FIELD_GET(ANDES_I2C_CFG_FIFOSIZE, i2c->fifo_size); + + regmap_set_bits(i2c->map, ANDES_I2C_SETUP_REG, + ANDES_I2C_SETUP_IICEN | ANDES_I2C_SETUP_REQ); + return 0; +} + +static const struct of_device_id andes_i2c_of_match[] =3D { + { .compatible =3D "andestech,ae350-i2c" }, + { /* sentinel */ } +}; + +MODULE_DEVICE_TABLE(of, andes_i2c_of_match); + +static struct platform_driver andes_i2c_platform_driver =3D { + .driver =3D { + .name =3D "andes_i2c", + .of_match_table =3D andes_i2c_of_match, + }, + .probe =3D andes_i2c_probe, +}; + +module_platform_driver(andes_i2c_platform_driver); + +MODULE_AUTHOR("Ben Zong-You Xie "); +MODULE_DESCRIPTION("Andes I2C controller driver"); +MODULE_LICENSE("GPL"); --=20 2.34.1 From nobody Thu Apr 2 07:43:58 2026 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 31429395DB4; Mon, 30 Mar 2026 07:30:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; cv=none; b=BQ3dQ34LGGuIbR5NdLo/dXfa9AXJMKfifFcZPGDGKhEbuJ4pArCmbkC+N8LOIPcWfYbsD0g3BwESDUmoSwnk7qPHEBxWrYW09rCYLWSOcNT4R3QfB4iJwz/xbYmhV6UfrVRHpr1q4WafQa9K+FUlK9Wx0G2qFUzq8ZV53SWg/FI= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; c=relaxed/simple; bh=zsqXZYapJk4lTUfsp/UHiNYmhCmbGFBx8fixkiHGjbA=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=Fjo1/xwMLTT2K3EyEI0/7JN9jDaVWLKYWOWAndPqotTb/ks6edjsf2hVnPD5Med9SNqqqzpn1mW4vreqIVKQ4eW4IA3AtYyLTRMQ/0ipqNGBLkz3jh6tswHxhfUnK2kjVKhg5fcZQ0hgF7BEjrEoVH5CKh79PSDOY9AuOybTRNo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=X0p88OMZ; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="X0p88OMZ" Received: by smtp.kernel.org (Postfix) with ESMTPS id F08A9C4AF0B; Mon, 30 Mar 2026 07:30:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1774855836; bh=zsqXZYapJk4lTUfsp/UHiNYmhCmbGFBx8fixkiHGjbA=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=X0p88OMZ0Gb9QxsAtCsO1gdH4Tu6ESMHd6JEqo0MTwdQ18z1rHHzC/VohS/WlNlg5 m/w2DyWkrhxFQlrw7TrNMjSFgtAtbYW5OtjUj/wmQFGqVLzjBgcdRTZsfRFJWaiIi0 TByK8nMpZ//UDtoZhYdYoQ0Cpmkhq7A0ATZwbzIYDNnAkrQs3yNrbBaOWYdQn39i58 edMEd/ZtIkWUaNZ6zhuNqqlJr+gzO7a5vkxIn42g0tcPkuRRB7tjReGziW9Joipe0+ DknkUjUjtLv9L0o/lERjBaFcnT7h2hqywmMSnOvfWVKwZmBHdV7MOEconCzrRgtVat 9f7cjkzYwFnXg== Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id E591CFF495B; Mon, 30 Mar 2026 07:30:35 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Mon, 30 Mar 2026 15:30:33 +0800 Subject: [PATCH v4 3/4] MAINTAINERS: add an entry for Andes I2C driver Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260330-atciic100-v4-3-d40822f63e4e@andestech.com> References: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> In-Reply-To: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> To: Andi Shyti , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Paul Walmsley , Palmer Dabbelt , Albert Ou , Alexandre Ghiti Cc: linux-i2c@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, Ben Zong-You Xie X-Mailer: b4 0.15-dev-47773 X-Developer-Signature: v=1; a=ed25519-sha256; t=1774855834; l=761; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=YiEx76SInP9JPwiKbc2slZ7Do4K0fx/VOtW1zrmzoiE=; b=cGuKKUe2ItklPvrrHhtXXu6mGLNhsReLY7Aqk85OiXJ76fLYf7jOPjpYRCE7znqZPx2tryyT3 YrhaGvbnU5HBw1Ibl3b+Ar480h6R3bFHIfpeiBvdnv725OlGsqi06VI X-Developer-Key: i=ben717@andestech.com; a=ed25519; pk=nb8L7zQKGJpYk0yvrYKjViOZ34A36g1ZIsCmCsP518s= X-Endpoint-Received: by B4 Relay for ben717@andestech.com/20260120 with auth_id=610 X-Original-From: Ben Zong-You Xie Reply-To: ben717@andestech.com From: Ben Zong-You Xie Add an entry for the Andes I2C driver to the MAINTAINERS file. Signed-off-by: Ben Zong-You Xie --- MAINTAINERS | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/MAINTAINERS b/MAINTAINERS index 7d10988cbc62..7272ebe7a22b 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -1863,6 +1863,12 @@ S: Supported F: Documentation/devicetree/bindings/spi/andestech,ae350-spi.yaml F: drivers/spi/spi-atcspi200.c =20 +ANDES I2C DRIVER +M: Ben Zong-You Xie +S: Supported +F: Documentation/devicetree/bindings/i2c/andestech,ae350-i2c.yaml +F: drivers/i2c/busses/i2c-andes.c + ANDROID DRIVERS M: Greg Kroah-Hartman M: Arve Hj=C3=B8nnev=C3=A5g --=20 2.34.1 From nobody Thu Apr 2 07:43:58 2026 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 3D09139E182; Mon, 30 Mar 2026 07:30:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; cv=none; b=F/AHIvfuKYSpS7TM1sj+Kpm6EwGeCaXctJOlJUXWDDfNPPGPgC7cT3pXKliMSlQVdIf22Rnb9vqeVxjQoXsqRKgP3fxaRw87MyUU4DYVuOU9BEUCYkWp48DrRbsdc9BnamfKC7aKOqre8Qv7leUWtrK4oLp96LSijfFERzYz50w= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1774855836; c=relaxed/simple; bh=YUyTnratnqlECwzSAzk6FREP35eA7ZpjXULZWweNn00=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=Y80K54hR3W+I9ZaZziIvDsDXKUp05fakXR/LsEV9BOTOFuJAjeVhv2pfdxATmeCwBwjU4ufUDluHqJwsjtMvQ6X8w+FtbYKZf85Ody8BaoybD5rmKePI21z5xLo44Hd1kqixuUAmez9ayh58NqRG+5CuAbh3PKCwBazBjiNXvS8= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=ZoKQsrAJ; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="ZoKQsrAJ" Received: by smtp.kernel.org (Postfix) with ESMTPS id 0F40DC2BCB6; Mon, 30 Mar 2026 07:30:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1774855836; bh=YUyTnratnqlECwzSAzk6FREP35eA7ZpjXULZWweNn00=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=ZoKQsrAJbzb3TJu/oO7LXEcHIOYjAh59baGNRqqnUvRoWSmjUT8NieQ+cwTfavFY7 YCd+y5PHt3xivi4czI8PVcKrSWFk9Pcpb5nN+vWF7VEjrN90giWPG9ZaK0zD+vIRbX IU6Bl+DyxCsxndSED1DZiH6N+DxIjJqCUJEujnyGHFbUAgzQhWhKyHYD6g9Sk4sRsY bw97S4Bq3J/6cLUimHJNwoYxO5fz33n4gIfRsfnrFPVot7i1TTY7pJx2NfMeSU+5lZ mAR6R8z/ElAf6NruZrHV6qL83N3dmoIVbVq6SWs25KNSQwToz08cHzsOdoEWMMOil8 N8CzQp75De6QA== Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id 004DFFF492F; Mon, 30 Mar 2026 07:30:36 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Mon, 30 Mar 2026 15:30:34 +0800 Subject: [PATCH v4 4/4] riscv: dts: andes: qilai: add I2C controller Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260330-atciic100-v4-4-d40822f63e4e@andestech.com> References: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> In-Reply-To: <20260330-atciic100-v4-0-d40822f63e4e@andestech.com> To: Andi Shyti , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Paul Walmsley , Palmer Dabbelt , Albert Ou , Alexandre Ghiti Cc: linux-i2c@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, Ben Zong-You Xie X-Mailer: b4 0.15-dev-47773 X-Developer-Signature: v=1; a=ed25519-sha256; t=1774855834; l=723; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=lHt2jE6+LDmM/nXD6n9TCCx5A6rJ3cqG+Q1RYfyMh24=; b=3JQUmdg7CTpz4PVd+oiNv5GYe8NiGErraflMYoIzTBmXF+bglT80SfCOh3YAhrvP/Cnx4m9cA wEiDld68pirA8uiNBghFZrqCIMp+oS996n6BNjbin/JG3S8S2dqDTd0 X-Developer-Key: i=ben717@andestech.com; a=ed25519; pk=nb8L7zQKGJpYk0yvrYKjViOZ34A36g1ZIsCmCsP518s= X-Endpoint-Received: by B4 Relay for ben717@andestech.com/20260120 with auth_id=610 X-Original-From: Ben Zong-You Xie Reply-To: ben717@andestech.com From: Ben Zong-You Xie Add the I2C node to QiLai DTS. Signed-off-by: Ben Zong-You Xie --- arch/riscv/boot/dts/andes/qilai.dtsi | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/arch/riscv/boot/dts/andes/qilai.dtsi b/arch/riscv/boot/dts/and= es/qilai.dtsi index de3de32f8c39..8b40f4d7f8d5 100644 --- a/arch/riscv/boot/dts/andes/qilai.dtsi +++ b/arch/riscv/boot/dts/andes/qilai.dtsi @@ -182,5 +182,12 @@ uart0: serial@30300000 { reg-io-width =3D <4>; no-loopback-test; }; + + i2c: i2c@30800000 { + compatible =3D "andestech,qilai-i2c", + "andestech,ae350-i2c"; + reg =3D <0x0 0x30800000 0x0 0x100000>; + interrupts =3D <6 IRQ_TYPE_LEVEL_HIGH>; + }; }; }; --=20 2.34.1