Loading...
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Copyright (C) 2022 MediaTek Inc. All rights reserved.
 *
 * Author: Weijie Gao <weijie.gao@mediatek.com>
 */

#ifndef _MT7621_H_
#define _MT7621_H_

#define SYSCTL_BASE				0x1e000000
#define SYSCTL_SIZE				0x100
#define TIMER_BASE				0x1e000100
#define TIMER_SIZE				0x100
#define RBUS_BASE				0x1e000400
#define RBUS_SIZE				0x100
#define GPIO_BASE				0x1e000600
#define GPIO_SIZE				0x100
#define DMA_CFG_ARB_BASE			0x1e000800
#define DMA_CFG_ARB_SIZE			0x100
#define SPI_BASE				0x1e000b00
#define SPI_SIZE				0x100
#define UART1_BASE				0x1e000c00
#define UART1_SIZE				0x100
#define UART2_BASE				0x1e000d00
#define UART2_SIZE				0x100
#define UART3_BASE				0x1e000e00
#define UART3_SIZE				0x100
#define NFI_BASE				0x1e003000
#define NFI_SIZE				0x800
#define NFI_ECC_BASE				0x1e003800
#define NFI_ECC_SIZE				0x800
#define DRAMC_BASE				0x1e005000
#define DRAMC_SIZE				0x1000
#define FE_BASE					0x1e100000
#define FE_SIZE					0xe000
#define GMAC_BASE				0x1e110000
#define GMAC_SIZE				0x8000
#define SSUSB_BASE				0x1e1c0000
#define SSUSB_SIZE				0x40000

 /* GIC Base Address */
#define MIPS_GIC_BASE				0x1fbc0000

 /* CPC Base Address */
#define MIPS_CPC_BASE				0x1fbf0000

 /* Flash Memory-mapped Base Address */
#define FLASH_MMAP_BASE				0x1fc00000
#define TPL_INFO_OFFSET				0x40
#define TPL_INFO_MAGIC				0x31323637 /* Magic "7621" */

/* SRAM */
#define FE_SRAM_BASE1				0x8000
#define FE_SRAM_BASE2				0xa000

/* SYSCTL_BASE */
#define SYSCTL_CHIP_REV_ID_REG			0x0c
#define CPU_ID					0x20000
#define PKG_ID					0x10000
#define VER_ID_S				8
#define VER_ID_M				0xf00
#define ECO_ID_S				0
#define ECO_ID_M				0x0f

#define SYSCTL_SYSCFG0_REG			0x10
#define XTAL_MODE_SEL_S				6
#define XTAL_MODE_SEL_M				0x1c0
#define DRAM_TYPE				0x10
#define CHIP_MODE_S				0
#define CHIP_MODE_M				0x0f

#define BOOT_SRAM_BASE_REG			0x20

#define SYSCTL_CLKCFG0_REG			0x2c
#define CPU_CLK_SEL_S				30
#define CPU_CLK_SEL_M				0xc0000000
#define MPLL_CFG_SEL_S				23
#define MPLL_CFG_SEL_M				0x800000

#define SYSCTL_RSTCTL_REG			0x34
#define MCM_RST					0x04
#define SYS_RST					0x01

#define SYSCTL_CUR_CLK_STS_REG			0x44
#define CUR_CPU_FDIV_S				8
#define CUR_CPU_FDIV_M				0x1f00
#define CUR_CPU_FFRAC_S				0
#define CUR_CPU_FFRAC_M				0x1f

#define SYSCTL_GPIOMODE_REG			0x60
#define UART2_MODE_S				5
#define UART2_MODE_M				0x60
#define UART3_MODE_S				3
#define UART3_MODE_M				0x18
#define UART1_MODE				0x02

/* RBUS_BASE */
#define RBUS_DYN_CFG0_REG			0x0010
#define CPU_FDIV_S				8
#define CPU_FDIV_M				0x1f00
#define CPU_FFRAC_S				0
#define CPU_FFRAC_M				0x1f

/* DMA_CFG_ARB_BASE */
#define DMA_ROUTE_REG				0x000c

/* SPI_BASE */
#define SPI_SPACE_REG				0x003c
#define FS_SLAVE_SEL_S				12
#define FS_SLAVE_SEL_M				0x70000
#define FS_CLK_SEL_S				0
#define FS_CLK_SEL_M				0xfff

/* FE_BASE */
#define FE_RST_GLO_REG				0x0004
#define FE_PSE_RAM				0x04
#define FE_PSE_MEM_EN				0x02
#define FE_PSE_RESET				0x01

/* SSUSB_BASE */
#define SSUSB_MAC_CK_CTRL_REG			0x10784
#define SSUSB_MAC3_SYS_CK_GATE_MASK_TIME_S	16
#define SSUSB_MAC3_SYS_CK_GATE_MASK_TIME_M	0xff0000
#define SSUSB_MAC2_SYS_CK_GATE_MASK_TIME_S	8
#define SSUSB_MAC2_SYS_CK_GATE_MASK_TIME_M	0xff00
#define SSUSB_MAC3_SYS_CK_GATE_MODE_S		2
#define SSUSB_MAC3_SYS_CK_GATE_MODE_M		0x0c
#define SSUSB_MAC2_SYS_CK_GATE_MODE_S		0
#define SSUSB_MAC2_SYS_CK_GATE_MODE_M		0x03

#define SSUSB_B2_ROSC_0_REG			0x10a40
#define SSUSB_RING_OSC_CNTEND_S			23
#define SSUSB_RING_OSC_CNTEND_M			0xff800000
#define SSUSB_XTAL_OSC_CNTEND_S			16
#define SSUSB_XTAL_OSC_CNTEND_M			0x7f0000
#define SSUSB_RING_BYPASS_DET			0x01

#define SSUSB_B2_ROSC_1_REG			0x10a44
#define SSUSB_RING_OSC_FRC_RECAL_S		17
#define SSUSB_RING_OSC_FRC_RECAL_M		0x60000
#define SSUSB_RING_OSC_FRC_SEL			0x01

#define SSUSB_U3PHYA_1_REG			0x10b04
#define SSUSB_PCIE_CLKDRV_AMP_S			27
#define SSUSB_PCIE_CLKDRV_AMP_M			0x38000000
#define SSUSB_SYSPLL_FBSEL_S			2
#define SSUSB_SYSPLL_FBSEL_M			0x0c
#define SSUSB_SYSPLL_PREDIV_S			0
#define SSUSB_SYSPLL_PREDIV_M			0x03

#define SSUSB_U3PHYA_2_REG			0x10b08
#define SSUSB_SYSPLL_FBDIV_S			24
#define SSUSB_SYSPLL_FBDIV_M			0x7f000000
#define SSUSB_SYSPLL_VCO_DIV_SEL		0x200000
#define SSUSB_SYSPLL_FPEN			0x2000
#define SSUSB_SYSPLL_MONCK_EN			0x1000
#define SSUSB_SYSPLL_VOD_EN			0x200

#define SSUSB_U3PHYA_3_REG			0x10b10
#define SSUSB_SYSPLL_PCW_NCPO_S			1
#define SSUSB_SYSPLL_PCW_NCPO_M			0xfffffffe

#define SSUSB_U3PHYA_9_REG			0x10b24
#define SSUSB_PLL_SSC_PRD_S			0
#define SSUSB_PLL_SSC_PRD_M			0xffff

#define SSUSB_U3PHYA_11_REG			0x10b2c
#define SSUSB_EQ_CURSEL				0x1000000
#define SSUSB_RX_DAC_MUX_S			19
#define SSUSB_RX_DAC_MUX_M			0xf80000
#define SSUSB_PCIE_SIGDET_VTH_S			5
#define SSUSB_PCIE_SIGDET_VTH_M			0x60
#define SSUSB_PCIE_SIGDET_LPF_S			3
#define SSUSB_PCIE_SIGDET_LPF_M			0x18

#define DA_SSUSB_PLL_FBKDIV_REG			0x10c1c
#define SSUSB_PLL_FBKDIV_PE2H_S			24
#define SSUSB_PLL_FBKDIV_PE2H_M			0x7f000000
#define SSUSB_PLL_FBKDIV_PE1D_S			16
#define SSUSB_PLL_FBKDIV_PE1D_M			0x7f0000
#define SSUSB_PLL_FBKDIV_PE1H_S			8
#define SSUSB_PLL_FBKDIV_PE1H_M			0x7f00
#define SSUSB_PLL_FBKDIV_U3_S			0
#define SSUSB_PLL_FBKDIV_U3_M			0x7f

#define DA_SSUSB_U3PHYA_10_REG			0x10c20
#define SSUSB_PLL_PREDIV_PE1D_S			18
#define SSUSB_PLL_PREDIV_PE1D_M			0xc0000
#define SSUSB_PLL_PREDIV_U3_S			8
#define SSUSB_PLL_PREDIV_U3_M			0x300
#define SSUSB_PLL_FBKDI_S			0
#define SSUSB_PLL_FBKDI_M			0x07

#define DA_SSUSB_PLL_PCW_NCPO_REG		0x10c24
#define SSUSB_PLL_PCW_NCPO_U3_S			0
#define SSUSB_PLL_PCW_NCPO_U3_M			0x7fffffff

#define DA_SSUSB_PLL_SSC_DELTA1_REG		0x10c38
#define SSUSB_PLL_SSC_DELTA1_PE1H_S		16
#define SSUSB_PLL_SSC_DELTA1_PE1H_M		0xffff0000
#define SSUSB_PLL_SSC_DELTA1_U3_S		0
#define SSUSB_PLL_SSC_DELTA1_U3_M		0xffff

#define DA_SSUSB_U3PHYA_21_REG			0x10c40
#define SSUSB_PLL_SSC_DELTA_U3_S		16
#define SSUSB_PLL_SSC_DELTA_U3_M		0xffff0000
#define SSUSB_PLL_SSC_DELTA1_PE2D_S		0
#define SSUSB_PLL_SSC_DELTA1_PE2D_M		0xffff

/* MT7621 specific CM values */

/* GCR_REGx_BASE */
#define GCR_REG0_BASE_VALUE			0x1c000000
#define GCR_REG1_BASE_VALUE			0x60000000
#define GCR_REG2_BASE_VALUE			0x1c000000
#define GCR_REG3_BASE_VALUE			0x1c000000

/* GCR_REGx_MASK */
#define GCR_REG0_MASK_VALUE			0x0000fc00 /* 64M Bus */
#define GCR_REG1_MASK_VALUE			0x0000f000 /* 256M PCI Mem */
#define GCR_REG2_MASK_VALUE			0x0000fc00 /* unused */
#define GCR_REG3_MASK_VALUE			0x0000fc00 /* unused */

#ifndef __ASSEMBLY__
unsigned long get_xtal_mhz(void);
#endif

#endif /* _MT7621_H_ */