]> git.baikalelectronics.ru Git - uboot.git/commitdiff
ARM: imx: imx8mp: Enable support for i2c5 and i2c6 on i.MX8MP
authorMartyn Welch <martyn.welch@collabora.com>
Tue, 25 Oct 2022 09:54:59 +0000 (10:54 +0100)
committerStefano Babic <sbabic@denx.de>
Mon, 7 Nov 2022 21:45:05 +0000 (22:45 +0100)
The i.MX8MP SoC contains 2 more i2c buses. Add support for the
configuration of these buses.

Signed-off-by: Martyn Welch <martyn.welch@collabora.com>
arch/arm/include/asm/arch-imx8m/imx-regs.h
arch/arm/mach-imx/i2c-mxv7.c
arch/arm/mach-imx/imx8m/clock_imx8mm.c

index c46d4f7e00c22fb7cffe7d626daa2b172365fdfd..6595d97f0a2d8bffe45458f84f6a1a42f6db8f76 100644 (file)
 #define I2C3_BASE_ADDR         0x30A40000
 #define I2C4_BASE_ADDR         0x30A50000
 #define UART4_BASE_ADDR                0x30A60000
+#ifdef CONFIG_IMX8MP
+#define I2C5_BASE_ADDR          0x30AD0000
+#define I2C6_BASE_ADDR          0x30AE0000
+#endif
 #define USDHC1_BASE_ADDR       0x30B40000
 #define USDHC2_BASE_ADDR       0x30B50000
 #define QSPI0_AMBA_BASE     0x08000000
index 85d648b56ed44c4c564546606362fd1e468ae958..a5866cf9f7034a39c2f93b4fbe201dcaf5c57ab9 100644 (file)
@@ -70,6 +70,12 @@ static void * const i2c_bases[] = {
 #ifdef I2C4_BASE_ADDR
        (void *)I2C4_BASE_ADDR,
 #endif
+#ifdef I2C5_BASE_ADDR
+       (void *)I2C5_BASE_ADDR,
+#endif
+#ifdef I2C6_BASE_ADDR
+       (void *)I2C6_BASE_ADDR,
+#endif
 };
 
 /* i2c_index can be from 0 - 3 */
index 4db55f86081521c8c1ed20b08d4058034c0e7ab7..64ad57e9b39a32df46f7931bbdb3d54a9d676232 100644 (file)
@@ -36,11 +36,17 @@ void enable_ocotp_clk(unsigned char enable)
 
 int enable_i2c_clk(unsigned char enable, unsigned i2c_num)
 {
-       /* 0 - 3 is valid i2c num */
-       if (i2c_num > 3)
+       u8 i2c_ccgr[6] = {
+                       CCGR_I2C1, CCGR_I2C2, CCGR_I2C3, CCGR_I2C4,
+#if (IS_ENABLED(CONFIG_IMX8MP))
+                       CCGR_I2C5_8MP, CCGR_I2C6_8MP
+#endif
+       };
+
+       if (i2c_num > ARRAY_SIZE(i2c_ccgr))
                return -EINVAL;
 
-       clock_enable(CCGR_I2C1 + i2c_num, !!enable);
+       clock_enable(i2c_ccgr[i2c_num], !!enable);
 
        return 0;
 }