| /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| /* |
| * Copyright (c) 2014 Zhang, Keguang <keguang.zhang@gmail.com> |
| * |
| * Loongson 1 MUX Register Definitions. |
| */ |
| |
| #ifndef __ASM_MACH_LOONGSON32_REGS_MUX_H |
| #define __ASM_MACH_LOONGSON32_REGS_MUX_H |
| |
| #define LS1X_MUX_REG(x) \ |
| ((void __iomem *)KSEG1ADDR(LS1X_MUX_BASE + (x))) |
| |
| #define LS1X_MUX_CTRL0 LS1X_MUX_REG(0x0) |
| #define LS1X_MUX_CTRL1 LS1X_MUX_REG(0x4) |
| |
| #if defined(CONFIG_LOONGSON1_LS1B) |
| /* MUX CTRL0 Register Bits */ |
| #define UART0_USE_PWM23 BIT(28) |
| #define UART0_USE_PWM01 BIT(27) |
| #define UART1_USE_LCD0_5_6_11 BIT(26) |
| #define I2C2_USE_CAN1 BIT(25) |
| #define I2C1_USE_CAN0 BIT(24) |
| #define NAND3_USE_UART5 BIT(23) |
| #define NAND3_USE_UART4 BIT(22) |
| #define NAND3_USE_UART1_DAT BIT(21) |
| #define NAND3_USE_UART1_CTS BIT(20) |
| #define NAND3_USE_PWM23 BIT(19) |
| #define NAND3_USE_PWM01 BIT(18) |
| #define NAND2_USE_UART5 BIT(17) |
| #define NAND2_USE_UART4 BIT(16) |
| #define NAND2_USE_UART1_DAT BIT(15) |
| #define NAND2_USE_UART1_CTS BIT(14) |
| #define NAND2_USE_PWM23 BIT(13) |
| #define NAND2_USE_PWM01 BIT(12) |
| #define NAND1_USE_UART5 BIT(11) |
| #define NAND1_USE_UART4 BIT(10) |
| #define NAND1_USE_UART1_DAT BIT(9) |
| #define NAND1_USE_UART1_CTS BIT(8) |
| #define NAND1_USE_PWM23 BIT(7) |
| #define NAND1_USE_PWM01 BIT(6) |
| #define GMAC1_USE_UART1 BIT(4) |
| #define GMAC1_USE_UART0 BIT(3) |
| #define LCD_USE_UART0_DAT BIT(2) |
| #define LCD_USE_UART15 BIT(1) |
| #define LCD_USE_UART0 BIT(0) |
| |
| /* MUX CTRL1 Register Bits */ |
| #define USB_RESET BIT(31) |
| #define SPI1_CS_USE_PWM01 BIT(24) |
| #define SPI1_USE_CAN BIT(23) |
| #define DISABLE_DDR_CONFSPACE BIT(20) |
| #define DDR32TO16EN BIT(16) |
| #define GMAC1_SHUT BIT(13) |
| #define GMAC0_SHUT BIT(12) |
| #define USB_SHUT BIT(11) |
| #define UART1_3_USE_CAN1 BIT(5) |
| #define UART1_2_USE_CAN0 BIT(4) |
| #define GMAC1_USE_TXCLK BIT(3) |
| #define GMAC0_USE_TXCLK BIT(2) |
| #define GMAC1_USE_PWM23 BIT(1) |
| #define GMAC0_USE_PWM01 BIT(0) |
| |
| #elif defined(CONFIG_LOONGSON1_LS1C) |
| |
| /* SHUT_CTRL Register Bits */ |
| #define UART_SPLIT GENMASK(31, 30) |
| #define OUTPUT_CLK GENMASK(29, 26) |
| #define ADC_SHUT BIT(25) |
| #define SDIO_SHUT BIT(24) |
| #define DMA2_SHUT BIT(23) |
| #define DMA1_SHUT BIT(22) |
| #define DMA0_SHUT BIT(21) |
| #define SPI1_SHUT BIT(20) |
| #define SPI0_SHUT BIT(19) |
| #define I2C2_SHUT BIT(18) |
| #define I2C1_SHUT BIT(17) |
| #define I2C0_SHUT BIT(16) |
| #define AC97_SHUT BIT(15) |
| #define I2S_SHUT BIT(14) |
| #define UART3_SHUT BIT(13) |
| #define UART2_SHUT BIT(12) |
| #define UART1_SHUT BIT(11) |
| #define UART0_SHUT BIT(10) |
| #define CAN1_SHUT BIT(9) |
| #define CAN0_SHUT BIT(8) |
| #define ECC_SHUT BIT(7) |
| #define GMAC_SHUT BIT(6) |
| #define USBHOST_SHUT BIT(5) |
| #define USBOTG_SHUT BIT(4) |
| #define SDRAM_SHUT BIT(3) |
| #define SRAM_SHUT BIT(2) |
| #define CAM_SHUT BIT(1) |
| #define LCD_SHUT BIT(0) |
| |
| #define UART_SPLIT_SHIFT 30 |
| #define OUTPUT_CLK_SHIFT 26 |
| |
| /* MISC_CTRL Register Bits */ |
| #define USBHOST_RSTN BIT(31) |
| #define PHY_INTF_SELI GENMASK(30, 28) |
| #define AC97_EN BIT(25) |
| #define SDIO_DMA_EN GENMASK(24, 23) |
| #define ADC_DMA_EN BIT(22) |
| #define SDIO_USE_SPI1 BIT(17) |
| #define SDIO_USE_SPI0 BIT(16) |
| #define SRAM_CTRL GENMASK(15, 0) |
| |
| #define PHY_INTF_SELI_SHIFT 28 |
| #define SDIO_DMA_EN_SHIFT 23 |
| #define SRAM_CTRL_SHIFT 0 |
| |
| #define LS1X_CBUS_REG(n, x) \ |
| ((void __iomem *)KSEG1ADDR(LS1X_CBUS_BASE + (n * 0x04) + (x))) |
| |
| #define LS1X_CBUS_FIRST(n) LS1X_CBUS_REG(n, 0x00) |
| #define LS1X_CBUS_SECOND(n) LS1X_CBUS_REG(n, 0x10) |
| #define LS1X_CBUS_THIRD(n) LS1X_CBUS_REG(n, 0x20) |
| #define LS1X_CBUS_FOURTHT(n) LS1X_CBUS_REG(n, 0x30) |
| #define LS1X_CBUS_FIFTHT(n) LS1X_CBUS_REG(n, 0x40) |
| |
| #endif |
| |
| #endif /* __ASM_MACH_LOONGSON32_REGS_MUX_H */ |