From nobody Sun Feb 8 09:22:51 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 0E9AD2F12AC; Thu, 22 Jan 2026 03:53:33 +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=1769054014; cv=none; b=cpJV/ct5DgDvb0n0Fxvl17hnO2Ytw65nozoPMWA8fsyEhJyajmGZFCwzKF6F7viQDshETh9nio6d8Lki0JPm2rTRBymub5KeeeCchVITx17TtadleElSO3GkK4qn6AOmX9OzbbVcVbeKWVKKdH94BFpvjE4eSQLOTzjJaYsu4Eo= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769054014; c=relaxed/simple; bh=6yOhuHzNdTY30xD/XYfZjff1L82lMLcjgD+SFKPnxTk=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=ha7+wiay0hvXcdH1ikdG7+OXHOf2egS6OKptA91CGGOZng7ucvu5AssAuV4eWAdT35WfyDyBGQnOmczrI7qrLQl21FV0bIvdlzr4ofjwMg3TVmr1N6VN1RrURRh8FSIrYG7HUM/H4mCv3L4slURLV/QWcpp2hCHmOHWdZkMgaj4= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=Y+lN9bJC; 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="Y+lN9bJC" Received: by smtp.kernel.org (Postfix) with ESMTPS id 92496C19422; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1769054013; bh=6yOhuHzNdTY30xD/XYfZjff1L82lMLcjgD+SFKPnxTk=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=Y+lN9bJC/OHh6pjeCDwLN+4tn/hu2+LX6v15VoiWVpO3Zr0gU0T1nYSiijkqfYZfX 8rR+kHJ+PzJ/NcFnj3daFZ6rbdCuOgKyuzF9B9pYi1QnIfPy/a74lBhXLZAXfY4rL1 nJUTmQQRx8Be4nqxOwCBIAiOamV8WTVB+I5eaQwporb6C4hAg6AMvpja+sZZWCaMqB WOVnBuFox8TqU495d97ugwOha2fO0nPsk8t59HtME9DeuZrN2OxFcvXrnY8wjZMkTa QyypRMh5Ojm6OrhccWkuDAAn7DeH4eoLqvIMoQjzh8JGD/dc2R1wtdgMNw7vIbIluU g31EZ7pVBN5YA== 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 831F7D625E7; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Thu, 22 Jan 2026 11:53:18 +0800 Subject: [PATCH v2 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: <20260122-atciic100-v2-1-7559136d07cf@andestech.com> References: <20260122-atciic100-v2-0-7559136d07cf@andestech.com> In-Reply-To: <20260122-atciic100-v2-0-7559136d07cf@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=1769054012; l=1551; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=bzYjfsqz3N3OJ2j9q6l3BfHCzA65mq7d2npy3Ry0CC0=; b=cae9XqVaBijHpGFgb5ZB/sdG9gKCTINR921/4Qy5OD1h21DNmNwnafowJvlmWthFpi9or8KCX C+KJXDzvmThANQo0SX0may8Eanire4JSRp0jXdgjucOtcPuKWi2gVZ+ 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. 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 Sun Feb 8 09:22:51 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 0EB1533DED9; Thu, 22 Jan 2026 03:53:33 +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=1769054014; cv=none; b=g8dPvLZA2XM2tc9wsRF48lJmLgbyyz/IrARyw3396m/ePC4dvD6o7Ff6G0DTmTctLt7g8YeUdV+T4qb9tfoo/SCQ/pQ4zYTNqOuADGUpDDFG9DIcuPBbZXCv97ST36CahZ2uSfu9OKEMuoS7mmvd/cOM/wocLofV6ILGCqjX2MI= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769054014; c=relaxed/simple; bh=m4Bu2xjNxMaziu7cHr/9vWIkSqxp2HE82nWmIg/qftM=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=CwJVPNp29ne/4Jat/RL5aMtHloGupBVRClfTxdGxiQruJTNhWMPv/hgBKGbG0sovB+xXIukmYLCh5FzJxqNNN48HdzbuKg9RF/MyVI/CPA65XRmV9UdI/fBRC4UXeT+L3klc18em17AVqGjrWp4jb0muNsuXoGfmymPTAAbuHRQ= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=gVVWz2N/; 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="gVVWz2N/" Received: by smtp.kernel.org (Postfix) with ESMTPS id A7A02C2BC86; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1769054013; bh=m4Bu2xjNxMaziu7cHr/9vWIkSqxp2HE82nWmIg/qftM=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=gVVWz2N/tKocCvh3vdBjLHrzX68dKZaBGVQQJFhaq/FI6SwtTbTXu+CYIEia7iw+K W9Tyx7Nx23wDcVm2Lug7YDx/OanYoN3vP5GuiDWnyOfCq2TBz9OucK3KqB8BZtp2lg Qxtc3vO3pkgS9/ozC18rCmPe5S+LRllw4E13A52l31LtYpt6oQjxazYX3yLCTXE1hf Mm7swDw2bCh61Ps4ZrR9m1TIsO5okqb6nmMnkGgdgjKchrZPa/ZtVrtNAd/Gc8eN3l QTOJaUiObb9/zwTmCsosu9Q/UbVO9WA10SoSzdYGpnaRjNCihkrgfwqy967rSB99rE mc2TxEHmEh+Jg== 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 985FED625E8; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Thu, 22 Jan 2026 11:53:19 +0800 Subject: [PATCH v2 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: <20260122-atciic100-v2-2-7559136d07cf@andestech.com> References: <20260122-atciic100-v2-0-7559136d07cf@andestech.com> In-Reply-To: <20260122-atciic100-v2-0-7559136d07cf@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=1769054012; l=11439; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=JJvoU5xm6NYwGRCQSVZcQTCsnH+d2KxcC6DNdPLV+u8=; b=xZR9ZrMYttfqiprnQpov1qhhkZW7p2P+ykEkE6FJM0pXFt3+GtkadtP6nf/v8XDR6dFfeX9WT +tF/KP7PSv6BJZEjvjw4sjzBqK5d+plRbQe8j6R/MacentK1jp5+ViG 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 e11d50750e63..8b9dbc25af8b 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 Sun Feb 8 09:22:51 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 2930238FF04; Thu, 22 Jan 2026 03:53:33 +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=1769054014; cv=none; b=GeOL6yYUNeSNEYoyOEnQKuyfbkrwnjR6k6NtzbLvHbP5TA4rtMFB01afBMzHzDhN+xhSJcjHhDWgsruz0Zhj8/OFcwdZypuUkDFdrczC3BI8TKBJCviTsxzTIMve96EMZrtMKy/UzT/Hz5yaYoXA79Asn2uxu6nKRvq/1NPSA5k= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769054014; c=relaxed/simple; bh=orgXr9zmHCBms+ytEAP7IDI/EZXaKPysvA5ieVEr3Ew=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=HbaXXCnApr6UtSjTA+B+3BX6oqf2awgnVZ44UujeoultyrF9uE1PY8ez+vAOzmvTAC0fRE0Xu5gdyd+scYdFQSBJcMqaSUQ1czb85Qt9waBzLow4ifwVxT+nTs//2lN5+P318BkVaJ0sTqJUKsNcd0E+/Dodb+NnBjQE8RmKMHM= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=fhREJzOH; 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="fhREJzOH" Received: by smtp.kernel.org (Postfix) with ESMTPS id B4BB9C2BC87; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1769054013; bh=orgXr9zmHCBms+ytEAP7IDI/EZXaKPysvA5ieVEr3Ew=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=fhREJzOHffx6T8npPEpP/KlJePfThT4OZaG8GQxNvQswFdFjj5h7Fgz0J/i57S7TI uShHYTWrbpvXrqA7s35ZN31FB2xJqbHoEmPKOFQb+eWEzgdxe6PcGPRrSuNVtkCLb4 ojcg0iITC6G9CofAl+bODRv0xvWchpmcO64BDxNZkjjma4zEKWLY33F8oFBJBLeW+/ OuUx1Sx1d5VpkW7mS3drXO5LlTs9wC25eDgRRWLFgRX06w/YrEoTBFPKzAWZ6xs3Pu PPjjNLskge9jZmTfBN+lh3+R8CJ6UrR2bn1JkiHSckD8YV30XSPY1HJ/AbWR5Qx7vo tI9BxPVfDSJ/Q== 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 AA94FC44536; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Thu, 22 Jan 2026 11:53:20 +0800 Subject: [PATCH v2 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: <20260122-atciic100-v2-3-7559136d07cf@andestech.com> References: <20260122-atciic100-v2-0-7559136d07cf@andestech.com> In-Reply-To: <20260122-atciic100-v2-0-7559136d07cf@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=1769054012; l=725; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=3+hkSp62Y0BxAKsBp1ZxlSLfzIge4HcMfARxzT3H5hA=; b=e7/vVAFZV27UkQ/Y8zBjVN4l0NYgFJh+kCZNDbRFv2AD8POEZ9jRu368iAIFWqvLny0r0aGH6 D4kYM/XQK4BBUW8e/e525q+toe9lHBit4IS/Bt6rRUDZ+ZxTm2MT61R 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 dc731d37c8fe..c1145ee1038e 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -1817,6 +1817,12 @@ S: Supported F: drivers/clk/analogbits/* F: include/linux/clk/analogbits* =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 Sun Feb 8 09:22:51 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 3E34738FF0F; Thu, 22 Jan 2026 03:53:33 +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=1769054014; cv=none; b=SjfKkkNuMvsYTZ+K/lZh2L4nOOPvguGmEFrualQOM01ysiLtcN/jZbPhl47kYaDkSAHtCe6EU9OtlHPe8ruHMJwtlKQFLvjaBjwSTbc8cERyu9UvYgors1ESv7sQLcN0vFgzl/7LVhNOurmMK6Oj6r3hjyL77UC8uMaREz1geI8= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1769054014; c=relaxed/simple; bh=YUyTnratnqlECwzSAzk6FREP35eA7ZpjXULZWweNn00=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=KyGw/WyNDfqRZNdEvT592KqBkPE4ipYox+H3mQbRjKy8nYuuNLez30Fnelte8UU/BuZhnMz5gGgSIB8GbkhtOJSjjbRjrgXFWA0f7CQ35iT6MurOhWanFi4jo6kQB74ZGrglvfI5jI0zUpnw6ut7nFSDzKIh8uY8kovnkLeFMaE= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=bpGMLl4m; 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="bpGMLl4m" Received: by smtp.kernel.org (Postfix) with ESMTPS id C7DC6C19423; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1769054013; bh=YUyTnratnqlECwzSAzk6FREP35eA7ZpjXULZWweNn00=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=bpGMLl4mIFgV61A9Q2THHlMjzlDs6K7ieCZNsfNdZb9KBAcRDsE5RtPxlTjmPy5vc mtalZMlIjwXm5BLp7UP4Dq33+WbtXb5D2vT1Soi5Em2dLowP5DtXaaEdOYISTdoxFb ns0VocjMMpRNQh9K8QhanaaJLqF4r8HjsEeb279G/wO7xbHFInZQs7DT9jueejEsAn r9msHCLe+/4Vl1B+AzSBUapG7r9wUjk15sVOTQpjOZSGj9zWkYevssBIzjeYBa7pu+ p3ZnyYqzGQCXulSKmxhP/KEaWNYiY8cj8nvDhzb3gNOPwChrJz18DfE/FMIY6fJdec pR+svBXIhDvVQ== 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 BEC92D625E9; Thu, 22 Jan 2026 03:53:33 +0000 (UTC) From: Ben Zong-You Xie via B4 Relay Date: Thu, 22 Jan 2026 11:53:21 +0800 Subject: [PATCH v2 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: <20260122-atciic100-v2-4-7559136d07cf@andestech.com> References: <20260122-atciic100-v2-0-7559136d07cf@andestech.com> In-Reply-To: <20260122-atciic100-v2-0-7559136d07cf@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=1769054012; l=723; i=ben717@andestech.com; s=20260120; h=from:subject:message-id; bh=lHt2jE6+LDmM/nXD6n9TCCx5A6rJ3cqG+Q1RYfyMh24=; b=iQnJZd47qVd7XoSMvzcJ5R5zVO+zQfuzU0q0WaUJznzsDZ59v88OiVEbBZPkzjzFOhclrG4vg k/KD4r89D2YAmX40WHr5xetJkK4m8lyEL3ckbopFs6NGdMUp6uLwRzV 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