
Hi Philipp:
On 2017年07月19日 04:36, Philipp Tomsich wrote:
The RK3368 GRF header was still defines with a shifted-mask but with non-shifted function selectors for the IOMUX defines. As the RK3368 support is still fresh enough to allow a quick rename, we do this now before having more code use this.
As some of the downstream drivers (e.g. the Designware GMAC wrapper) may need to include the grf-header of multiple devices, we rename the various defines for the RK3368 by prefixing them with the device name. This avoids future trouble during driver integration.
Is that really necessary to add such a prefix for all the register definition, just to fit the GMAC dirver? Maybe the gmac driver can define the platform specific macro in its own code like dwmac-rk in the kernel. Then we can keep the register header file a little tidy.
Signed-off-by: Philipp Tomsich philipp.tomsich@theobroma-systems.com
arch/arm/include/asm/arch-rockchip/grf_rk3368.h | 617 +++++++++++++----------- drivers/pinctrl/rockchip/pinctrl_rk3368.c | 17 +- 2 files changed, 334 insertions(+), 300 deletions(-)
diff --git a/arch/arm/include/asm/arch-rockchip/grf_rk3368.h b/arch/arm/include/asm/arch-rockchip/grf_rk3368.h index a438f5d..a97dc1e 100644 --- a/arch/arm/include/asm/arch-rockchip/grf_rk3368.h +++ b/arch/arm/include/asm/arch-rockchip/grf_rk3368.h @@ -1,4 +1,6 @@ -/* (C) Copyright 2016 Rockchip Electronics Co., Ltd +/*
- (C) Copyright 2016 Rockchip Electronics Co., Ltd
*/
- (C) Copyright 2017 Theobroma Systems Design und Consulting GmbH
- SPDX-License-Identifier: GPL-2.0+
@@ -100,315 +102,318 @@ check_member(rk3368_pmu_grf, os_reg[0], 0x200);
/*GRF_GPIO0C_IOMUX*/ enum {
- GPIO0C7_SHIFT = 14,
- GPIO0C7_MASK = 3 << GPIO0C7_SHIFT,
- GPIO0C7_GPIO = 0,
- GPIO0C7_LCDC_D19,
- GPIO0C7_TRACE_D9,
- GPIO0C7_UART1_RTSN,
- GPIO0C6_SHIFT = 12,
- GPIO0C6_MASK = 3 << GPIO0C6_SHIFT,
- GPIO0C6_GPIO = 0,
- GPIO0C6_LCDC_D18,
- GPIO0C6_TRACE_D8,
- GPIO0C6_UART1_CTSN,
- GPIO0C5_SHIFT = 10,
- GPIO0C5_MASK = 3 << GPIO0C5_SHIFT,
- GPIO0C5_GPIO = 0,
- GPIO0C5_LCDC_D17,
- GPIO0C5_TRACE_D7,
- GPIO0C5_UART1_SOUT,
- GPIO0C4_SHIFT = 8,
- GPIO0C4_MASK = 3 << GPIO0C4_SHIFT,
- GPIO0C4_GPIO = 0,
- GPIO0C4_LCDC_D16,
- GPIO0C4_TRACE_D6,
- GPIO0C4_UART1_SIN,
- GPIO0C3_SHIFT = 6,
- GPIO0C3_MASK = 3 << GPIO0C3_SHIFT,
- GPIO0C3_GPIO = 0,
- GPIO0C3_LCDC_D15,
- GPIO0C3_TRACE_D5,
- GPIO0C3_MCU_JTAG_TDO,
- GPIO0C2_SHIFT = 4,
- GPIO0C2_MASK = 3 << GPIO0C2_SHIFT,
- GPIO0C2_GPIO = 0,
- GPIO0C2_LCDC_D14,
- GPIO0C2_TRACE_D4,
- GPIO0C2_MCU_JTAG_TDI,
- GPIO0C1_SHIFT = 2,
- GPIO0C1_MASK = 3 << GPIO0C1_SHIFT,
- GPIO0C1_GPIO = 0,
- GPIO0C1_LCDC_D13,
- GPIO0C1_TRACE_D3,
- GPIO0C1_MCU_JTAG_TRTSN,
- GPIO0C0_SHIFT = 0,
- GPIO0C0_MASK = 3 << GPIO0C0_SHIFT,
- GPIO0C0_GPIO = 0,
- GPIO0C0_LCDC_D12,
- GPIO0C0_TRACE_D2,
- GPIO0C0_MCU_JTAG_TDO,
RK3368_GPIO0C7_MASK = GENMASK(15, 14),
RK3368_GPIO0C7_GPIO = 0,
RK3368_GPIO0C7_LCDC_D19 = (1 << 14),
RK3368_GPIO0C7_TRACE_D9 = (2 << 14),
RK3368_GPIO0C7_UART1_RTSN = (3 << 14),
RK3368_GPIO0C6_MASK = GENMASK(13, 12),
RK3368_GPIO0C6_GPIO = 0,
RK3368_GPIO0C6_LCDC_D18 = (1 << 12),
RK3368_GPIO0C6_TRACE_D8 = (2 << 12),
RK3368_GPIO0C6_UART1_CTSN = (3 << 12),
RK3368_GPIO0C5_MASK = GENMASK(11, 10),
RK3368_GPIO0C5_GPIO = 0,
RK3368_GPIO0C5_LCDC_D17 = (1 << 10),
RK3368_GPIO0C5_TRACE_D7 = (2 << 10),
RK3368_GPIO0C5_UART1_SOUT = (3 << 10),
RK3368_GPIO0C4_MASK = GENMASK(9, 8),
RK3368_GPIO0C4_GPIO = 0,
RK3368_GPIO0C4_LCDC_D16 = (1 << 8),
RK3368_GPIO0C4_TRACE_D6 = (2 << 8),
RK3368_GPIO0C4_UART1_SIN = (3 << 8),
RK3368_GPIO0C3_MASK = GENMASK(7, 6),
RK3368_GPIO0C3_GPIO = 0,
RK3368_GPIO0C3_LCDC_D15 = (1 << 6),
RK3368_GPIO0C3_TRACE_D5 = (2 << 6),
RK3368_GPIO0C3_MCU_JTAG_TDO = (3 << 6),
RK3368_GPIO0C2_MASK = GENMASK(5, 4),
RK3368_GPIO0C2_GPIO = 0,
RK3368_GPIO0C2_LCDC_D14 = (1 << 4),
RK3368_GPIO0C2_TRACE_D4 = (2 << 4),
RK3368_GPIO0C2_MCU_JTAG_TDI = (3 << 4),
RK3368_GPIO0C1_MASK = GENMASK(3, 2),
RK3368_GPIO0C1_GPIO = 0,
RK3368_GPIO0C1_LCDC_D13 = (1 << 2),
RK3368_GPIO0C1_TRACE_D3 = (2 << 2),
RK3368_GPIO0C1_MCU_JTAG_TRTSN = (3 << 2),
RK3368_GPIO0C0_MASK = GENMASK(1, 0),
RK3368_GPIO0C0_GPIO = 0,
RK3368_GPIO0C0_LCDC_D12 = (1 << 0),
RK3368_GPIO0C0_TRACE_D2 = (2 << 0),
RK3368_GPIO0C0_MCU_JTAG_TDO = (3 << 0), };
/*GRF_GPIO0D_IOMUX*/ enum {
- GPIO0D7_SHIFT = 14,
- GPIO0D7_MASK = 3 << GPIO0D7_SHIFT,
- GPIO0D7_GPIO = 0,
- GPIO0D7_LCDC_DCLK,
- GPIO0D7_TRACE_CTL,
- GPIO0D7_PMU_DEBUG5,
- GPIO0D6_SHIFT = 12,
- GPIO0D6_MASK = 3 << GPIO0D6_SHIFT,
- GPIO0D6_GPIO = 0,
- GPIO0D6_LCDC_DEN,
- GPIO0D6_TRACE_CLK,
- GPIO0D6_PMU_DEBUG4,
- GPIO0D5_SHIFT = 10,
- GPIO0D5_MASK = 3 << GPIO0D5_SHIFT,
- GPIO0D5_GPIO = 0,
- GPIO0D5_LCDC_VSYNC,
- GPIO0D5_TRACE_D15,
- GPIO0D5_PMU_DEBUG3,
- GPIO0D4_SHIFT = 8,
- GPIO0D4_MASK = 3 << GPIO0D4_SHIFT,
- GPIO0D4_GPIO = 0,
- GPIO0D4_LCDC_HSYNC,
- GPIO0D4_TRACE_D14,
- GPIO0D4_PMU_DEBUG2,
- GPIO0D3_SHIFT = 6,
- GPIO0D3_MASK = 3 << GPIO0D3_SHIFT,
- GPIO0D3_GPIO = 0,
- GPIO0D3_LCDC_D23,
- GPIO0D3_TRACE_D13,
- GPIO0D3_UART4_SIN,
- GPIO0D2_SHIFT = 4,
- GPIO0D2_MASK = 3 << GPIO0D2_SHIFT,
- GPIO0D2_GPIO = 0,
- GPIO0D2_LCDC_D22,
- GPIO0D2_TRACE_D12,
- GPIO0D2_UART4_SOUT,
- GPIO0D1_SHIFT = 2,
- GPIO0D1_MASK = 3 << GPIO0D1_SHIFT,
- GPIO0D1_GPIO = 0,
- GPIO0D1_LCDC_D21,
- GPIO0D1_TRACE_D11,
- GPIO0D1_UART4_RTSN,
- GPIO0D0_SHIFT = 0,
- GPIO0D0_MASK = 3 << GPIO0D0_SHIFT,
- GPIO0D0_GPIO = 0,
- GPIO0D0_LCDC_D20,
- GPIO0D0_TRACE_D10,
- GPIO0D0_UART4_CTSN,
RK3368_GPIO0D7_MASK = GENMASK(15, 14),
RK3368_GPIO0D7_GPIO = 0,
RK3368_GPIO0D7_LCDC_DCLK = (1 << 14),
RK3368_GPIO0D7_TRACE_CTL = (2 << 14),
RK3368_GPIO0D7_PMU_DEBUG5 = (3 << 14),
RK3368_GPIO0D6_MASK = GENMASK(13, 12),
RK3368_GPIO0D6_GPIO = 0,
RK3368_GPIO0D6_LCDC_DEN = (1 << 12),
RK3368_GPIO0D6_TRACE_CLK = (2 << 12),
RK3368_GPIO0D6_PMU_DEBUG4 = (3 << 12),
RK3368_GPIO0D5_MASK = GENMASK(11, 10),
RK3368_GPIO0D5_GPIO = 0,
GPIO0D5_LCDC_VSYNC = (1 << 10),
RK3368_GPIO0D5_TRACE_D15 = (2 << 10),
RK3368_GPIO0D5_PMU_DEBUG3 = (3 << 10),
RK3368_GPIO0D4_MASK = GENMASK(9, 8),
RK3368_GPIO0D4_GPIO = 0,
RK3368_GPIO0D4_LCDC_HSYNC = (1 << 8),
RK3368_GPIO0D4_TRACE_D14 = (2 << 8),
RK3368_GPIO0D4_PMU_DEBUG2 = (3 << 8),
RK3368_GPIO0D3_MASK = GENMASK(7, 6),
RK3368_GPIO0D3_GPIO = 0,
RK3368_GPIO0D3_LCDC_D23 = (1 << 6),
RK3368_GPIO0D3_TRACE_D13 = (2 << 6),
RK3368_GPIO0D3_UART4_SIN = (3 << 6),
RK3368_GPIO0D2_MASK = GENMASK(5, 4),
RK3368_GPIO0D2_GPIO = 0,
RK3368_GPIO0D2_LCDC_D22 = (1 << 4),
RK3368_GPIO0D2_TRACE_D12 = (2 << 4),
RK3368_GPIO0D2_UART4_SOUT = (3 << 4),
RK3368_GPIO0D1_MASK = GENMASK(3, 2),
RK3368_GPIO0D1_GPIO = 0,
RK3368_GPIO0D1_LCDC_D21 = (1 << 2),
RK3368_GPIO0D1_TRACE_D11 = (2 << 2),
RK3368_GPIO0D1_UART4_RTSN = (3 << 2),
RK3368_GPIO0D0_MASK = GENMASK(1, 0),
RK3368_GPIO0D0_GPIO = 0,
RK3368_GPIO0D0_LCDC_D20 = (1 << 0),
RK3368_GPIO0D0_TRACE_D10 = (2 << 0),
RK3368_GPIO0D0_UART4_CTSN = (3 << 0), };
/*GRF_GPIO2A_IOMUX*/ enum {
- GPIO2A7_SHIFT = 14,
- GPIO2A7_MASK = 3 << GPIO2A7_SHIFT,
- GPIO2A7_GPIO = 0,
- GPIO2A7_SDMMC0_D2,
- GPIO2A7_JTAG_TCK,
- GPIO2A6_SHIFT = 12,
- GPIO2A6_MASK = 3 << GPIO2A6_SHIFT,
- GPIO2A6_GPIO = 0,
- GPIO2A6_SDMMC0_D1,
- GPIO2A6_UART2_SIN,
- GPIO2A5_SHIFT = 10,
- GPIO2A5_MASK = 3 << GPIO2A5_SHIFT,
- GPIO2A5_GPIO = 0,
- GPIO2A5_SDMMC0_D0,
- GPIO2A5_UART2_SOUT,
- GPIO2A4_SHIFT = 8,
- GPIO2A4_MASK = 3 << GPIO2A4_SHIFT,
- GPIO2A4_GPIO = 0,
- GPIO2A4_FLASH_DQS,
- GPIO2A4_EMMC_CLKO,
- GPIO2A3_SHIFT = 6,
- GPIO2A3_MASK = 3 << GPIO2A3_SHIFT,
- GPIO2A3_GPIO = 0,
- GPIO2A3_FLASH_CSN3,
- GPIO2A3_EMMC_RSTNO,
- GPIO2A2_SHIFT = 4,
- GPIO2A2_MASK = 3 << GPIO2A2_SHIFT,
- GPIO2A2_GPIO = 0,
- GPIO2A2_FLASH_CSN2,
- GPIO2A1_SHIFT = 2,
- GPIO2A1_MASK = 3 << GPIO2A1_SHIFT,
- GPIO2A1_GPIO = 0,
- GPIO2A1_FLASH_CSN1,
- GPIO2A0_SHIFT = 0,
- GPIO2A0_MASK = 3 << GPIO2A0_SHIFT,
- GPIO2A0_GPIO = 0,
- GPIO2A0_FLASH_CSN0,
- RK3368_GPIO2A7_MASK = GENMASK(15, 14),
- RK3368_GPIO2A7_GPIO = 0,
- RK3368_GPIO2A7_SDMMC0_D2 = (1 << 14),
- RK3368_GPIO2A7_JTAG_TCK = (2 << 14),
- RK3368_GPIO2A6_MASK = GENMASK(13, 12),
- RK3368_GPIO2A6_GPIO = 0,
- RK3368_GPIO2A6_SDMMC0_D1 = (1 << 12),
- RK3368_GPIO2A6_UART2_SIN = (2 << 12),
- RK3368_GPIO2A5_MASK = GENMASK(11, 10),
- RK3368_GPIO2A5_GPIO = 0,
- RK3368_GPIO2A5_SDMMC0_D0 = (1 << 10),
- RK3368_GPIO2A5_UART2_SOUT = (2 << 10),
- RK3368_GPIO2A4_MASK = GENMASK(9, 8),
- RK3368_GPIO2A4_RK3368_GPIO = 0,
- RK3368_GPIO2A4_FLASH_DQS = (1 << 8),
- RK3368_GPIO2A4_EMMC_CLKOUT = (2 << 8),
- RK3368_GPIO2A3_MASK = GENMASK(7, 6),
- RK3368_GPIO2A3_GPIO = 0,
- RK3368_GPIO2A3_FLASH_CSN3 = (1 << 6),
- RK3368_GPIO2A3_EMMC_RSTNOUT = (2 << 6),
- RK3368_GPIO2A2_MASK = GENMASK(5, 4),
- RK3368_GPIO2A2_GPIO = 0,
- RK3368_GPIO2A2_FLASH_CSN2 = (1 << 4),
- RK3368_GPIO2A1_MASK = GENMASK(3, 2),
- RK3368_GPIO2A1_GPIO = 0,
- RK3368_GPIO2A1_FLASH_CSN1 = (1 << 2),
- RK3368_GPIO2A0_MASK = GENMASK(1, 0),
- RK3368_GPIO2A0_GPIO = 0,
- RK3368_GPIO2A0_FLASH_CSN0 = (1 << 0), };
-/*GRF_GPIO2D_IOMUX*/ +/*GRF_RK3368_GPIO2D_IOMUX*/ enum {
- GPIO2D7_SHIFT = 14,
- GPIO2D7_MASK = 3 << GPIO2D7_SHIFT,
- GPIO2D7_GPIO = 0,
- GPIO2D7_SDIO0_D3,
- GPIO2D6_SHIFT = 12,
- GPIO2D6_MASK = 3 << GPIO2D6_SHIFT,
- GPIO2D6_GPIO = 0,
- GPIO2D6_SDIO0_D2,
- GPIO2D5_SHIFT = 10,
- GPIO2D5_MASK = 3 << GPIO2D5_SHIFT,
- GPIO2D5_GPIO = 0,
- GPIO2D5_SDIO0_D1,
- GPIO2D4_SHIFT = 8,
- GPIO2D4_MASK = 3 << GPIO2D4_SHIFT,
- GPIO2D4_GPIO = 0,
- GPIO2D4_SDIO0_D0,
- GPIO2D3_SHIFT = 6,
- GPIO2D3_MASK = 3 << GPIO2D3_SHIFT,
- GPIO2D3_GPIO = 0,
- GPIO2D3_UART0_RTS0,
- GPIO2D2_SHIFT = 4,
- GPIO2D2_MASK = 3 << GPIO2D2_SHIFT,
- GPIO2D2_GPIO = 0,
- GPIO2D2_UART0_CTS0,
- GPIO2D1_SHIFT = 2,
- GPIO2D1_MASK = 3 << GPIO2D1_SHIFT,
- GPIO2D1_GPIO = 0,
- GPIO2D1_UART0_SOUT,
- GPIO2D0_SHIFT = 0,
- GPIO2D0_MASK = 3 << GPIO2D0_SHIFT,
- GPIO2D0_GPIO = 0,
- GPIO2D0_UART0_SIN,
- RK3368_GPIO2D7_MASK = GENMASK(15, 14),
- RK3368_GPIO2D7_GPIO = 0,
- RK3368_GPIO2D7_SDIO0_D3 = (1 << 14),
- RK3368_GPIO2D6_MASK = GENMASK(13, 12),
- RK3368_GPIO2D6_GPIO = 0,
- RK3368_GPIO2D6_SDIO0_D2 = (1 << 12),
- RK3368_GPIO2D5_MASK = GENMASK(11, 10),
- RK3368_GPIO2D5_GPIO = 0,
- RK3368_GPIO2D5_SDIO0_D1 = (1 << 10),
- RK3368_GPIO2D4_MASK = GENMASK(9, 8),
- RK3368_GPIO2D4_GPIO = 0,
- RK3368_GPIO2D4_SDIO0_D0 = (1 << 8),
- RK3368_GPIO2D3_MASK = GENMASK(7, 6),
- RK3368_GPIO2D3_GPIO = 0,
- RK3368_GPIO2D3_UART0_RTS0 = (1 << 6),
- RK3368_GPIO2D2_MASK = GENMASK(5, 4),
- RK3368_GPIO2D2_GPIO = 0,
- RK3368_GPIO2D2_UART0_CTS0 = (1 << 4),
- RK3368_GPIO2D1_MASK = GENMASK(3, 2),
- RK3368_GPIO2D1_GPIO = 0,
- RK3368_GPIO2D1_UART0_SOUT = (1 << 2),
- RK3368_GPIO2D0_MASK = GENMASK(1, 0),
- RK3368_GPIO2D0_GPIO = 0,
- RK3368_GPIO2D0_UART0_SIN = (1 << 0),
+};
+/* GRF_GPIO1C_IOMUX */ +enum {
- RK3368_GPIO1C7_MASK = GENMASK(15, 14),
- RK3368_GPIO1C7_GPIO = 0,
- RK3368_GPIO1C7_EMMC_DATA5 = (2 << 14),
- RK3368_GPIO1C6_MASK = GENMASK(13, 12),
- RK3368_GPIO1C6_GPIO = 0,
- RK3368_GPIO1C6_EMMC_DATA4 = (2 << 12),
- RK3368_GPIO1C5_MASK = GENMASK(11, 10),
- RK3368_GPIO1C5_GPIO = 0,
- RK3368_GPIO1C5_EMMC_DATA3 = (2 << 10),
- RK3368_GPIO1C4_MASK = GENMASK(9, 8),
- RK3368_GPIO1C4_GPIO = 0,
- RK3368_GPIO1C4_EMMC_DATA2 = (2 << 8),
- RK3368_GPIO1C3_MASK = GENMASK(7, 6),
- RK3368_GPIO1C3_GPIO = 0,
- RK3368_GPIO1C3_EMMC_DATA1 = (2 << 6),
- RK3368_GPIO1C2_MASK = GENMASK(5, 4),
- RK3368_GPIO1C2_GPIO = 0,
- RK3368_GPIO1C2_EMMC_DATA0 = (2 << 4),
+};
+/* GRF_GPIO1D_IOMUX*/ +enum {
- RK3368_GPIO1D3_MASK = GENMASK(7, 6),
- RK3368_GPIO1D3_GPIO = 0,
- RK3368_GPIO1D3_EMMC_PWREN = (2 << 6),
- RK3368_GPIO1D2_MASK = GENMASK(5, 4),
- RK3368_GPIO1D2_GPIO = 0,
- RK3368_GPIO1D2_EMMC_CMD = (2 << 4),
- RK3368_GPIO1D1_MASK = GENMASK(3, 2),
- RK3368_GPIO1D1_GPIO = 0,
- RK3368_GPIO1D1_EMMC_DATA7 = (2 << 2),
- RK3368_GPIO1D0_MASK = GENMASK(1, 0),
- RK3368_GPIO1D0_GPIO = 0,
- RK3368_GPIO1D0_EMMC_DATA6 = (2 << 0),
+};
+/*GRF_GPIO3B_IOMUX*/ +enum {
RK3368_GPIO3B7_MASK = GENMASK(15, 14),
RK3368_GPIO3B7_GPIO = 0,
RK3368_GPIO3B7_MAC_RXD0 = (1 << 14),
RK3368_GPIO3B6_MASK = GENMASK(13, 12),
RK3368_GPIO3B6_GPIO = 0,
RK3368_GPIO3B6_MAC_TXD3 = (1 << 12),
RK3368_GPIO3B5_MASK = GENMASK(11, 10),
RK3368_GPIO3B5_GPIO = 0,
RK3368_GPIO3B5_MAC_TXEN = (1 << 10),
RK3368_GPIO3B4_MASK = GENMASK(9, 8),
RK3368_GPIO3B4_GPIO = 0,
RK3368_GPIO3B4_MAC_COL = (1 << 8),
RK3368_GPIO3B3_MASK = GENMASK(7, 6),
RK3368_GPIO3B3_GPIO = 0,
RK3368_GPIO3B3_MAC_CRS = (1 << 6),
RK3368_GPIO3B2_MASK = GENMASK(5, 4),
RK3368_GPIO3B2_GPIO = 0,
RK3368_GPIO3B2_MAC_TXD2 = (1 << 4),
RK3368_GPIO3B1_MASK = GENMASK(3, 2),
RK3368_GPIO3B1_GPIO = 0,
RK3368_GPIO3B1_MAC_TXD1 = (1 << 2),
RK3368_GPIO3B0_MASK = GENMASK(1, 0),
RK3368_GPIO3B0_GPIO = 0,
RK3368_GPIO3B0_MAC_TXD0 = (1 << 0),
RK3368_GPIO3B0_PWM0 = (2 << 0), };
/*GRF_GPIO3C_IOMUX*/ enum {
- GPIO3C7_SHIFT = 14,
- GPIO3C7_MASK = 3 << GPIO3C7_SHIFT,
- GPIO3C7_GPIO = 0,
- GPIO3C7_EDPHDMI_CECINOUT,
- GPIO3C7_ISP_FLASHTRIGIN,
- GPIO3C6_SHIFT = 12,
- GPIO3C6_MASK = 3 << GPIO3C6_SHIFT,
- GPIO3C6_GPIO = 0,
- GPIO3C6_MAC_CLK,
- GPIO3C6_ISP_SHUTTERTRIG,
- GPIO3C5_SHIFT = 10,
- GPIO3C5_MASK = 3 << GPIO3C5_SHIFT,
- GPIO3C5_GPIO = 0,
- GPIO3C5_MAC_RXER,
- GPIO3C5_ISP_PRELIGHTTRIG,
- GPIO3C4_SHIFT = 8,
- GPIO3C4_MASK = 3 << GPIO3C4_SHIFT,
- GPIO3C4_GPIO = 0,
- GPIO3C4_MAC_RXDV,
- GPIO3C4_ISP_FLASHTRIGOUT,
- GPIO3C3_SHIFT = 6,
- GPIO3C3_MASK = 3 << GPIO3C3_SHIFT,
- GPIO3C3_GPIO = 0,
- GPIO3C3_MAC_RXDV,
- GPIO3C3_EMMC_RSTNO,
- GPIO3C2_SHIFT = 4,
- GPIO3C2_MASK = 3 << GPIO3C2_SHIFT,
- GPIO3C2_MAC_MDC = 0,
- GPIO3C2_ISP_SHUTTEREN,
- GPIO3C1_SHIFT = 2,
- GPIO3C1_MASK = 3 << GPIO3C1_SHIFT,
- GPIO3C1_GPIO = 0,
- GPIO3C1_MAC_RXD2,
- GPIO3C1_UART3_RTSN,
- GPIO3C0_SHIFT = 0,
- GPIO3C0_MASK = 3 << GPIO3C0_SHIFT,
- GPIO3C0_GPIO = 0,
- GPIO3C0_MAC_RXD1,
- GPIO3C0_UART3_CTSN,
- GPIO3C0_GPS_RFCLK,
RK3368_GPIO3C6_MASK = GENMASK(13, 12),
RK3368_GPIO3C6_GPIO = 0,
RK3368_GPIO3C6_MAC_CLK = (1 << 12),
RK3368_GPIO3C5_MASK = GENMASK(11, 10),
RK3368_GPIO3C5_GPIO = 0,
RK3368_GPIO3C5_MAC_RXEN = (1 << 10),
RK3368_GPIO3C4_MASK = GENMASK(9, 8),
RK3368_GPIO3C4_GPIO = 0,
RK3368_GPIO3C4_MAC_RXDV = (1 << 8),
RK3368_GPIO3C3_MASK = GENMASK(7, 6),
RK3368_GPIO3C3_GPIO = 0,
RK3368_GPIO3C3_MAC_MDC = (1 << 6),
RK3368_GPIO3C2_MASK = GENMASK(5, 4),
RK3368_GPIO3C2_GPIO = 0,
RK3368_GPIO3C2_MAC_RXD3 = (1 << 4),
RK3368_GPIO3C1_MASK = GENMASK(3, 2),
RK3368_GPIO3C1_GPIO = 0,
RK3368_GPIO3C1_MAC_RXD2 = (1 << 2),
RK3368_GPIO3C0_MASK = GENMASK(1, 0),
RK3368_GPIO3C0_GPIO = 0,
RK3368_GPIO3C0_MAC_RXD1 = (1 << 0), };
/*GRF_GPIO3D_IOMUX*/ enum {
- GPIO3D7_SHIFT = 14,
- GPIO3D7_MASK = 3 << GPIO3D7_SHIFT,
- GPIO3D7_GPIO = 0,
- GPIO3D7_SC_VCC18V,
- GPIO3D7_I2C2_SDA,
- GPIO3D7_GPUJTAG_TCK,
- GPIO3D6_SHIFT = 12,
- GPIO3D6_MASK = 3 << GPIO3D6_SHIFT,
- GPIO3D6_GPIO = 0,
- GPIO3D6_IR_TX,
- GPIO3D6_UART3_SOUT,
- GPIO3D6_PWM3,
- GPIO3D5_SHIFT = 10,
- GPIO3D5_MASK = 3 << GPIO3D5_SHIFT,
- GPIO3D5_GPIO = 0,
- GPIO3D5_IR_RX,
- GPIO3D5_UART3_SIN,
- GPIO3D4_SHIFT = 8,
- GPIO3D4_MASK = 3 << GPIO3D4_SHIFT,
- GPIO3D4_GPIO = 0,
- GPIO3D4_MAC_TXCLKOUT,
- GPIO3D4_SPI1_CSN1,
- GPIO3D3_SHIFT = 6,
- GPIO3D3_MASK = 3 << GPIO3D3_SHIFT,
- GPIO3D3_GPIO = 0,
- GPIO3D3_HDMII2C_SCL,
- GPIO3D3_I2C5_SCL,
- GPIO3D2_SHIFT = 4,
- GPIO3D2_MASK = 3 << GPIO3D2_SHIFT,
- GPIO3D2_GPIO = 0,
- GPIO3D2_HDMII2C_SDA,
- GPIO3D2_I2C5_SDA,
- GPIO3D1_SHIFT = 2,
- GPIO3D1_MASK = 3 << GPIO3D1_SHIFT,
- GPIO3D1_GPIO = 0,
- GPIO3D1_MAC_RXCLKIN,
- GPIO3D1_I2C4_SCL,
- GPIO3D0_SHIFT = 0,
- GPIO3D0_MASK = 3 << GPIO3D0_SHIFT,
- GPIO3D0_GPIO = 0,
- GPIO3D0_MAC_MDIO,
- GPIO3D0_I2C4_SDA,
- RK3368_GPIO3D4_MASK = GENMASK(9, 8),
- RK3368_GPIO3D4_GPIO = 0,
- RK3368_GPIO3D4_MAC_TXCLK = (1 << 8),
- RK3368_GPIO3D1_MASK = GENMASK(3, 2),
- RK3368_GPIO3D1_GPIO = 0,
- RK3368_GPIO3D1_MAC_RXCLK = (1 << 2),
- RK3368_GPIO3D0_MASK = GENMASK(1, 0),
- RK3368_GPIO3D0_GPIO = 0,
- RK3368_GPIO3D0_MAC_MDIO = (1 << 0),
+};
+/* GRF_SOC_CON0 */ +enum {
NOC_RSP_ERR_STALL = BIT(9),
MOBILE_DDR_SEL = BIT(4),
DDR0_16BIT_EN = BIT(3),
MSCH0_MAINDDR3_DDR3 = BIT(2),
MSCH0_MAINPARTIALPOP = BIT(1),
UPCTL_C_ACTIVE = BIT(0), };
/*GRF_SOC_CON11/12/13*/
@@ -440,4 +445,34 @@ enum { MCU_CODE_BASE_BIT31_BIT28_SHIFT = 0, MCU_CODE_BASE_BIT31_BIT28_MASK = GENMASK(3, 0), };
+/*GRF_SOC_CON15*/ +enum {
- RK3368_GMAC_PHY_INTF_SEL_RGMII = 1 << 9,
- RK3368_GMAC_PHY_INTF_SEL_MASK = GENMASK(11, 9),
- RK3368_RMII_MODE_MASK = BIT(6),
- RK3368_RMII_MODE = BIT(6),
- RK3368_GMAC_CLK_SEL_2_5M = 2 << 4,
- RK3368_GMAC_CLK_SEL_25M = 3 << 4,
- RK3368_GMAC_CLK_SEL_125M = 0 << 4,
- RK3368_GMAC_CLK_SEL_MASK = GENMASK(5, 4),
+};
+/* GRF_SOC_CON16 */ +enum {
- RK3368_RXCLK_DLY_ENA_GMAC_MASK = BIT(15),
- RK3368_RXCLK_DLY_ENA_GMAC_DISABLE = 0,
- RK3368_RXCLK_DLY_ENA_GMAC_ENABLE = BIT(15),
- RK3368_TXCLK_DLY_ENA_GMAC_MASK = BIT(7),
- RK3368_TXCLK_DLY_ENA_GMAC_DISABLE = 0,
- RK3368_TXCLK_DLY_ENA_GMAC_ENABLE = BIT(7),
- RK3368_CLK_RX_DL_CFG_GMAC_SHIFT = 8,
- RK3368_CLK_RX_DL_CFG_GMAC_MASK = GENMASK(14, 8),
- RK3368_CLK_TX_DL_CFG_GMAC_SHIFT = 0,
- RK3368_CLK_TX_DL_CFG_GMAC_MASK = GENMASK(6, 0),
+};
- #endif
diff --git a/drivers/pinctrl/rockchip/pinctrl_rk3368.c b/drivers/pinctrl/rockchip/pinctrl_rk3368.c index bdf0758..b77c5ab 100644 --- a/drivers/pinctrl/rockchip/pinctrl_rk3368.c +++ b/drivers/pinctrl/rockchip/pinctrl_rk3368.c @@ -30,9 +30,9 @@ static void pinctrl_rk3368_uart_config(struct rk3368_pinctrl_priv *priv, switch (uart_id) { case PERIPH_ID_UART2: rk_clrsetreg(&grf->gpio2a_iomux,
GPIO2A6_MASK | GPIO2A5_MASK,
GPIO2A6_UART2_SIN << GPIO2A6_SHIFT |
GPIO2A5_UART2_SOUT << GPIO2A5_SHIFT);
RK3368_GPIO2A6_MASK | RK3368_GPIO2A5_MASK,
RK3368_GPIO2A6_UART2_SIN |
break; case PERIPH_ID_UART0: break;RK3368_GPIO2A5_UART2_SOUT);
@@ -42,12 +42,11 @@ static void pinctrl_rk3368_uart_config(struct rk3368_pinctrl_priv *priv, break; case PERIPH_ID_UART4: rk_clrsetreg(&pmugrf->gpio0d_iomux,
GPIO0D0_MASK | GPIO0D1_MASK |
GPIO0D2_MASK | GPIO0D3_MASK,
GPIO0D0_GPIO << GPIO0D0_SHIFT |
GPIO0D1_GPIO << GPIO0D1_SHIFT |
GPIO0D2_UART4_SOUT << GPIO0D2_SHIFT |
GPIO0D3_UART4_SIN << GPIO0D3_SHIFT);
RK3368_GPIO0D0_MASK | RK3368_GPIO0D1_MASK |
RK3368_GPIO0D2_MASK | RK3368_GPIO0D3_MASK,
RK3368_GPIO0D0_GPIO | RK3368_GPIO0D1_GPIO |
RK3368_GPIO0D2_UART4_SOUT |
break; default: debug("uart id = %d iomux error!\n", uart_id);RK3368_GPIO0D3_UART4_SIN);