Received: by 2002:ab2:2994:0:b0:1ef:ca3e:3cd5 with SMTP id n20csp679827lqb; Fri, 15 Mar 2024 03:32:23 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXeXf5EVSAerWG2MyMFpKq/FGluQEpE95qyQVHTaNoorc7D9i4ZonNbb0Srr2HshQ0kU6JBizMYV/XsrcaA3Pm74bi24DM5ISxXPZaU2g== X-Google-Smtp-Source: AGHT+IEsy+Wja6iKGSXnhk7rY6EbefOwO1/egi0qXGUlsofC428uZiagA2k3u5yvfFCHnC4swa2v X-Received: by 2002:a92:cbc2:0:b0:366:2f7d:d292 with SMTP id s2-20020a92cbc2000000b003662f7dd292mr4306930ilq.6.1710498743723; Fri, 15 Mar 2024 03:32:23 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710498743; cv=pass; d=google.com; s=arc-20160816; b=erbh5K6aMTEUx7nfYIhDEW/cvYHmcmNcmmiKOy0/DstJQykC6X8M9griPSj4iddTfD D5snpu4k1viq+s73PFlpdZfmLsaJ5XEp1I4OTsv+dnqPfKQyCtP+voAcTxZETg7ckpOp 2furUe+U21nF/vVw2iDhgv2L/DRDXUiK/e0jajE+prSllH1qYYubmQUwkS/EZjJX8H0A 9T1blnrgP2om4s587Vyk/EiPXs5rYVryoDfAsYiI8pvStczWtaI6Gy6WH3kSwrMYbkJ+ Q3FD4UcwgyXnA6xhY9also1+3UeUR93hLuxkJxPVZOntAk6u5mHU+oJbEImg5Rrj+84a QMUQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=XuhvpDK8oZ+Fu96smtWi//ks5eVckNXcaN8Zvrrlm7A=; fh=7ENpC46A6CxV8krHifkom9k7B3xNNPEtJmUyjCs7PSk=; b=swZ/LNm0vq9AjtSvkAtt+Dfu69CeXrxLWaTqDUzyQhNKiHGVcVNpt97CLFBYT6MTVo xMA0USgWfFg9GGmGdJlKeq7mqacV3+shoV7USBNzgu6Osr54KLB3saVv8f84jX7Xoapb HcVXEK0MVnhuwX++jo2/xNHOooPg9XXh0gOCETVricbmSH7x3iagI8tO2qRFWdcjmOJV pxfVIcTTivdIXiaQj9erNgZq077Fs3ibOUOWPz2oObGrEt/IdkIMAl2OghK99jQJZGx8 w0Cm7woaNlQp30SHVu5QrExfF6CH751/IkN8l/ZX+fceRewNJvbMgrbwEtxuDeh51BMF 9A6Q==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=HJTNTv4k; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-104267-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-104267-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id j3-20020a63e743000000b005d8bef48a86si2412548pgk.876.2024.03.15.03.32.23 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Mar 2024 03:32:23 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-104267-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=HJTNTv4k; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-104267-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-104267-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 5A611282DCE for ; Fri, 15 Mar 2024 10:32:23 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id B57BB1B94B; Fri, 15 Mar 2024 10:31:38 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="HJTNTv4k" Received: from mail-wm1-f53.google.com (mail-wm1-f53.google.com [209.85.128.53]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 091A91B275; Fri, 15 Mar 2024 10:31:35 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.53 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710498697; cv=none; b=oqOPPE0u3oY0ALTTMv9XGvlQ0Y0t50ZYD8YAGD7i5OBwJN8X3mcXuQ+JptJiFXF1g/DlvsXsp5rqG0mus30/eN+Or36EQbXX3zEsMLiFYZc00rYhPjzHBoUwY46L6U1iSiQRJ7OiisD09DRPaJFOTR4cRK+bf+rnlAyBdw+6+Ps= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710498697; c=relaxed/simple; bh=9ZaYynsaCjU76O3Z51pWLQRwLV311S8QrPtofxK97f0=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=K3TomNcpT2AphsP0RnwoEM/gyZT9ATss8s/EkTnTwRNGUPNfxIZYHOu61lxBf1A92okA/AkYtiL674Tgw0O1Qmc2WYacGzXYH9VARUt+QG0kPVjoC+IWMgpgNAZaCIjhj9vjVJ9EtEqVsvzYZK+YeVKf1x+CEcX4t8Ic4v+53w8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=HJTNTv4k; arc=none smtp.client-ip=209.85.128.53 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-wm1-f53.google.com with SMTP id 5b1f17b1804b1-41324a16c9eso12228835e9.0; Fri, 15 Mar 2024 03:31:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1710498694; x=1711103494; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=XuhvpDK8oZ+Fu96smtWi//ks5eVckNXcaN8Zvrrlm7A=; b=HJTNTv4kKQXbfFg8lBgkveETJodUyV0UAa46iTrl0YPJxFXEoV4yVmSq0XJu4nA6di OLOym3AAjb1/5EMW9kQZluwoP+z03fnXsWaW7Q9UBI5PKTslr0N8eKyUfPODazDt5bfk aPVAZcORlPRHQvCVpYeYRUzxSESRju/KGYXCX8+j8yHKitgF0VK+WeSCFydFqO/3MUJ4 1rcBSRV1OLRT3jCDnaHqbw5m7mB4CJAYf6x5FB7CjtCEkzCiQhS3U0YWkVyXJJ240XnA EbuhbZT9rij0Wm9SdqS4ouCDAbHUSodn19BJ770kIX5ABWoZ24npvYSA5WJpTVdNn30Q ywAw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1710498694; x=1711103494; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=XuhvpDK8oZ+Fu96smtWi//ks5eVckNXcaN8Zvrrlm7A=; b=R0TwHpvGWw0adJ/stAH/BvRh9uv5bF9xN2d2FXn3RsUjtH5ZwgD0xat/gkCUBDTjqO VcZKE89aDr302zqIWDBBRY/DGKwSv0riqfnqmI1atXO32HV/RQz7MLqsMwqMVSP7aJ2p JmiwuONiEQ42imYj3em4ZlFoVJrpRBpcxDo8pOcJetwEY1YuHau2qOlSsYf1mVmInzXV EMNwNwVLMibh+xS0gBxXAa/Le9DKPw0VXMhn5Yx/0fSDxIt/CIB7pw0jzcZxdKctWwR1 srolBYUfCJSlSw6hj3N/f5vO8aurxAeJsLAnURW+HKyDIPMlNVaaQRZ3VesmL7cluo+q Rg+A== X-Forwarded-Encrypted: i=1; AJvYcCXDR7zMVEeIZJL3FW9lGCrRET/L//2k2wip9ZcHqv6LjIzelhH58U8l1ZdpstFIvujVaMdOXKG9JiUhKmRrNKBDQ5/Lo4/daF52XqxXssvA07j3qbAizve0Sx4pe/kmyXm6kakbgHP/uPoQkitpQZ4cluE0ls9PV6Ea9rJQGIeuaB1Wgg== X-Gm-Message-State: AOJu0YzVo/VxPgGHCug8TqR+9PBPpnvkyBwDssukQYQwgs021//rmpXd j4JRuGVv2dGVrAusMNSj6XAEkUAEFvR+wS1N8O0sATW++GlPETcr X-Received: by 2002:a05:600c:5187:b0:413:f1d7:eec9 with SMTP id fa7-20020a05600c518700b00413f1d7eec9mr3735593wmb.31.1710498694373; Fri, 15 Mar 2024 03:31:34 -0700 (PDT) Received: from prasmi.home ([2a00:23c8:2500:a01:ae92:6adf:5cb6:274c]) by smtp.gmail.com with ESMTPSA id l19-20020a05600c4f1300b004130378fb77sm8676549wmq.6.2024.03.15.03.31.32 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Mar 2024 03:31:33 -0700 (PDT) From: Prabhakar X-Google-Original-From: Prabhakar To: Geert Uytterhoeven , Chris Brandt , Andi Shyti , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Magnus Damm , Wolfram Sang Cc: linux-renesas-soc@vger.kernel.org, linux-i2c@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Prabhakar , Fabrizio Castro , Lad Prabhakar Subject: [PATCH v2 3/4] i2c: riic: Pass register offsets and chip details as OF data Date: Fri, 15 Mar 2024 10:30:32 +0000 Message-Id: <20240315103033.141226-4-prabhakar.mahadev-lad.rj@bp.renesas.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240315103033.141226-1-prabhakar.mahadev-lad.rj@bp.renesas.com> References: <20240315103033.141226-1-prabhakar.mahadev-lad.rj@bp.renesas.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Lad Prabhakar With an increasing number of SoCs reusing this driver, each with slight variations in the RIIC IP, it becomes necessary to support passing these details as OF data. This approach simplifies the extension of the driver for other SoCs. This patch lays the groundwork for adding support for the Renesas RZ/V2H SoC. Signed-off-by: Lad Prabhakar --- v1->v2 - Dropped family from struct riic_of_data - Included RIIC_REG_END in enum list as flexible array member in a struct with no named members is not allowed --- drivers/i2c/busses/i2c-riic.c | 56 +++++++++++++++++++++++++---------- 1 file changed, 41 insertions(+), 15 deletions(-) diff --git a/drivers/i2c/busses/i2c-riic.c b/drivers/i2c/busses/i2c-riic.c index 5eb25ef3abc4..3ae2d5c2f85a 100644 --- a/drivers/i2c/busses/i2c-riic.c +++ b/drivers/i2c/busses/i2c-riic.c @@ -46,18 +46,6 @@ #include #include -#define RIIC_ICCR1 0x00 -#define RIIC_ICCR2 0x04 -#define RIIC_ICMR1 0x08 -#define RIIC_ICMR3 0x10 -#define RIIC_ICSER 0x18 -#define RIIC_ICIER 0x1c -#define RIIC_ICSR2 0x24 -#define RIIC_ICBRL 0x34 -#define RIIC_ICBRH 0x38 -#define RIIC_ICDRT 0x3c -#define RIIC_ICDRR 0x40 - #define ICCR1_ICE 0x80 #define ICCR1_IICRST 0x40 #define ICCR1_SOWP 0x10 @@ -87,6 +75,25 @@ #define RIIC_INIT_MSG -1 +enum riic_reg_list { + RIIC_ICCR1 = 0, + RIIC_ICCR2, + RIIC_ICMR1, + RIIC_ICMR3, + RIIC_ICSER, + RIIC_ICIER, + RIIC_ICSR2, + RIIC_ICBRL, + RIIC_ICBRH, + RIIC_ICDRT, + RIIC_ICDRR, + RIIC_REG_END, +}; + +struct riic_of_data { + u8 regs[RIIC_REG_END]; +}; + struct riic_dev { void __iomem *base; u8 *buf; @@ -94,6 +101,7 @@ struct riic_dev { int bytes_left; int err; int is_last; + const struct riic_of_data *info; struct completion msg_done; struct i2c_adapter adapter; struct clk *clk; @@ -107,12 +115,12 @@ struct riic_irq_desc { static inline void riic_writeb(struct riic_dev *riic, u8 offset, u8 val) { - writeb(val, riic->base + offset); + writeb(val, riic->base + riic->info->regs[offset]); } static inline u8 riic_readb(struct riic_dev *riic, u8 offset) { - return readb(riic->base + offset); + return readb(riic->base + riic->info->regs[offset]); } static inline void riic_clear_set_bit(struct riic_dev *riic, u8 clear, u8 set, u8 reg) @@ -453,6 +461,8 @@ static int riic_i2c_probe(struct platform_device *pdev) } } + riic->info = of_device_get_match_data(&pdev->dev); + adap = &riic->adapter; i2c_set_adapdata(adap, riic); strscpy(adap->name, "Renesas RIIC adapter", sizeof(adap->name)); @@ -497,8 +507,24 @@ static void riic_i2c_remove(struct platform_device *pdev) pm_runtime_disable(&pdev->dev); } +static const struct riic_of_data riic_rz_a_info = { + .regs = { + [RIIC_ICCR1] = 0x00, + [RIIC_ICCR2] = 0x04, + [RIIC_ICMR1] = 0x08, + [RIIC_ICMR3] = 0x10, + [RIIC_ICSER] = 0x18, + [RIIC_ICIER] = 0x1c, + [RIIC_ICSR2] = 0x24, + [RIIC_ICBRL] = 0x34, + [RIIC_ICBRH] = 0x38, + [RIIC_ICDRT] = 0x3c, + [RIIC_ICDRR] = 0x40, + }, +}; + static const struct of_device_id riic_i2c_dt_ids[] = { - { .compatible = "renesas,riic-rz", }, + { .compatible = "renesas,riic-rz", .data = &riic_rz_a_info }, { /* Sentinel */ }, }; -- 2.34.1