xref: /openbmc/linux/arch/arm/mach-mv78xx0/mv78xx0.h (revision 1ac731c529cd4d6adbce134754b51ff7d822b145)
10fdebc5eSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
24c811b99SArnd Bergmann /*
34c811b99SArnd Bergmann  * Generic definitions for Marvell MV78xx0 SoC flavors:
44c811b99SArnd Bergmann  *  MV781x0 and MV782x0.
54c811b99SArnd Bergmann  */
64c811b99SArnd Bergmann 
74c811b99SArnd Bergmann #ifndef __ASM_ARCH_MV78XX0_H
84c811b99SArnd Bergmann #define __ASM_ARCH_MV78XX0_H
94c811b99SArnd Bergmann 
104c811b99SArnd Bergmann #include "irqs.h"
114c811b99SArnd Bergmann 
124c811b99SArnd Bergmann /*
134c811b99SArnd Bergmann  * Marvell MV78xx0 address maps.
144c811b99SArnd Bergmann  *
154c811b99SArnd Bergmann  * phys
164c811b99SArnd Bergmann  * c0000000	PCIe Memory space
174c811b99SArnd Bergmann  * f0800000	PCIe #0 I/O space
184c811b99SArnd Bergmann  * f0900000	PCIe #1 I/O space
194c811b99SArnd Bergmann  * f0a00000	PCIe #2 I/O space
204c811b99SArnd Bergmann  * f0b00000	PCIe #3 I/O space
214c811b99SArnd Bergmann  * f0c00000	PCIe #4 I/O space
224c811b99SArnd Bergmann  * f0d00000	PCIe #5 I/O space
234c811b99SArnd Bergmann  * f0e00000	PCIe #6 I/O space
244c811b99SArnd Bergmann  * f0f00000	PCIe #7 I/O space
254c811b99SArnd Bergmann  * f1000000	on-chip peripheral registers
264c811b99SArnd Bergmann  *
274c811b99SArnd Bergmann  * virt		phys		size
284c811b99SArnd Bergmann  * fe400000	f102x000	16K	core-specific peripheral registers
294c811b99SArnd Bergmann  * fee00000	f0800000	64K	PCIe #0 I/O space
304c811b99SArnd Bergmann  * fee10000	f0900000	64K	PCIe #1 I/O space
314c811b99SArnd Bergmann  * fee20000	f0a00000	64K	PCIe #2 I/O space
324c811b99SArnd Bergmann  * fee30000	f0b00000	64K	PCIe #3 I/O space
334c811b99SArnd Bergmann  * fee40000	f0c00000	64K	PCIe #4 I/O space
344c811b99SArnd Bergmann  * fee50000	f0d00000	64K	PCIe #5 I/O space
354c811b99SArnd Bergmann  * fee60000	f0e00000	64K	PCIe #6 I/O space
364c811b99SArnd Bergmann  * fee70000	f0f00000	64K	PCIe #7 I/O space
373584be9eSArnd Bergmann  * fec00000	f1000000	1M	on-chip peripheral registers
384c811b99SArnd Bergmann  */
394c811b99SArnd Bergmann #define MV78XX0_CORE0_REGS_PHYS_BASE	0xf1020000
404c811b99SArnd Bergmann #define MV78XX0_CORE1_REGS_PHYS_BASE	0xf1024000
414c811b99SArnd Bergmann #define MV78XX0_CORE_REGS_VIRT_BASE	IOMEM(0xfe400000)
424c811b99SArnd Bergmann #define MV78XX0_CORE_REGS_PHYS_BASE	0xfe400000
434c811b99SArnd Bergmann #define MV78XX0_CORE_REGS_SIZE		SZ_16K
444c811b99SArnd Bergmann 
454c811b99SArnd Bergmann #define MV78XX0_PCIE_IO_PHYS_BASE(i)	(0xf0800000 + ((i) << 20))
464c811b99SArnd Bergmann #define MV78XX0_PCIE_IO_SIZE		SZ_1M
474c811b99SArnd Bergmann 
484c811b99SArnd Bergmann #define MV78XX0_REGS_PHYS_BASE		0xf1000000
493584be9eSArnd Bergmann #define MV78XX0_REGS_VIRT_BASE		IOMEM(0xfec00000)
504c811b99SArnd Bergmann #define MV78XX0_REGS_SIZE		SZ_1M
514c811b99SArnd Bergmann 
52*4b01f735SJeremy J. Peper #define MV78XX0_SRAM_PHYS_BASE          (0xf2200000)
53*4b01f735SJeremy J. Peper #define MV78XX0_SRAM_SIZE               SZ_8K
54*4b01f735SJeremy J. Peper 
554c811b99SArnd Bergmann #define MV78XX0_PCIE_MEM_PHYS_BASE	0xc0000000
564c811b99SArnd Bergmann #define MV78XX0_PCIE_MEM_SIZE		0x30000000
574c811b99SArnd Bergmann 
58*4b01f735SJeremy J. Peper #define MV78XX0_MBUS_SRAM_TARGET       0x09
59*4b01f735SJeremy J. Peper #define MV78XX0_MBUS_SRAM_ATTR         0x00
60*4b01f735SJeremy J. Peper 
614c811b99SArnd Bergmann /*
624c811b99SArnd Bergmann  * Core-specific peripheral registers.
634c811b99SArnd Bergmann  */
644c811b99SArnd Bergmann #define BRIDGE_VIRT_BASE	(MV78XX0_CORE_REGS_VIRT_BASE)
654c811b99SArnd Bergmann #define BRIDGE_PHYS_BASE	(MV78XX0_CORE_REGS_PHYS_BASE)
664c811b99SArnd Bergmann #define  BRIDGE_WINS_CPU0_BASE  (MV78XX0_CORE0_REGS_PHYS_BASE)
674c811b99SArnd Bergmann #define  BRIDGE_WINS_CPU1_BASE  (MV78XX0_CORE1_REGS_PHYS_BASE)
684c811b99SArnd Bergmann #define  BRIDGE_WINS_SZ         (0xA000)
694c811b99SArnd Bergmann 
704c811b99SArnd Bergmann /*
714c811b99SArnd Bergmann  * Register Map
724c811b99SArnd Bergmann  */
734c811b99SArnd Bergmann #define DDR_VIRT_BASE		(MV78XX0_REGS_VIRT_BASE + 0x00000)
744c811b99SArnd Bergmann #define DDR_PHYS_BASE           (MV78XX0_REGS_PHYS_BASE + 0x00000)
754c811b99SArnd Bergmann #define  DDR_WINDOW_CPU0_BASE	(DDR_PHYS_BASE + 0x1500)
764c811b99SArnd Bergmann #define  DDR_WINDOW_CPU1_BASE	(DDR_PHYS_BASE + 0x1570)
774c811b99SArnd Bergmann #define  DDR_WINDOW_CPU_SZ      (0x20)
784c811b99SArnd Bergmann 
794c811b99SArnd Bergmann #define DEV_BUS_PHYS_BASE	(MV78XX0_REGS_PHYS_BASE + 0x10000)
804c811b99SArnd Bergmann #define DEV_BUS_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x10000)
814c811b99SArnd Bergmann #define  SAMPLE_AT_RESET_LOW	(DEV_BUS_VIRT_BASE + 0x0030)
824c811b99SArnd Bergmann #define  SAMPLE_AT_RESET_HIGH	(DEV_BUS_VIRT_BASE + 0x0034)
834c811b99SArnd Bergmann #define  GPIO_VIRT_BASE		(DEV_BUS_VIRT_BASE + 0x0100)
844c811b99SArnd Bergmann #define  I2C_0_PHYS_BASE	(DEV_BUS_PHYS_BASE + 0x1000)
854c811b99SArnd Bergmann #define  I2C_1_PHYS_BASE	(DEV_BUS_PHYS_BASE + 0x1100)
864c811b99SArnd Bergmann #define  UART0_PHYS_BASE	(DEV_BUS_PHYS_BASE + 0x2000)
874c811b99SArnd Bergmann #define  UART0_VIRT_BASE	(DEV_BUS_VIRT_BASE + 0x2000)
884c811b99SArnd Bergmann #define  UART1_PHYS_BASE	(DEV_BUS_PHYS_BASE + 0x2100)
894c811b99SArnd Bergmann #define  UART1_VIRT_BASE	(DEV_BUS_VIRT_BASE + 0x2100)
904c811b99SArnd Bergmann #define  UART2_PHYS_BASE	(DEV_BUS_PHYS_BASE + 0x2200)
914c811b99SArnd Bergmann #define  UART2_VIRT_BASE	(DEV_BUS_VIRT_BASE + 0x2200)
924c811b99SArnd Bergmann #define  UART3_PHYS_BASE	(DEV_BUS_PHYS_BASE + 0x2300)
934c811b99SArnd Bergmann #define  UART3_VIRT_BASE	(DEV_BUS_VIRT_BASE + 0x2300)
944c811b99SArnd Bergmann 
954c811b99SArnd Bergmann #define GE10_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x30000)
964c811b99SArnd Bergmann #define GE11_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x34000)
974c811b99SArnd Bergmann 
984c811b99SArnd Bergmann #define PCIE00_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x40000)
994c811b99SArnd Bergmann #define PCIE01_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x44000)
1004c811b99SArnd Bergmann #define PCIE02_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x48000)
1014c811b99SArnd Bergmann #define PCIE03_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x4c000)
1024c811b99SArnd Bergmann 
1034c811b99SArnd Bergmann #define USB0_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x50000)
1044c811b99SArnd Bergmann #define USB1_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x51000)
1054c811b99SArnd Bergmann #define USB2_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x52000)
1064c811b99SArnd Bergmann 
107*4b01f735SJeremy J. Peper #define XOR_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x60900)
108*4b01f735SJeremy J. Peper 
1094c811b99SArnd Bergmann #define GE00_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x70000)
1104c811b99SArnd Bergmann #define GE01_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0x74000)
1114c811b99SArnd Bergmann 
1124c811b99SArnd Bergmann #define PCIE10_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x80000)
1134c811b99SArnd Bergmann #define PCIE11_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x84000)
1144c811b99SArnd Bergmann #define PCIE12_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x88000)
1154c811b99SArnd Bergmann #define PCIE13_VIRT_BASE	(MV78XX0_REGS_VIRT_BASE + 0x8c000)
1164c811b99SArnd Bergmann 
117*4b01f735SJeremy J. Peper #define CRYPTO_PHYS_BASE	(MV78XX0_REGS_PHYS_BASE + 0x90000)
118*4b01f735SJeremy J. Peper 
1194c811b99SArnd Bergmann #define SATA_PHYS_BASE		(MV78XX0_REGS_PHYS_BASE + 0xa0000)
1204c811b99SArnd Bergmann 
1214c811b99SArnd Bergmann /*
1224c811b99SArnd Bergmann  * Supported devices and revisions.
1234c811b99SArnd Bergmann  */
1244c811b99SArnd Bergmann #define MV78X00_Z0_DEV_ID	0x6381
1254c811b99SArnd Bergmann #define MV78X00_REV_Z0		1
1264c811b99SArnd Bergmann 
1274c811b99SArnd Bergmann #define MV78100_DEV_ID		0x7810
1284c811b99SArnd Bergmann #define MV78100_REV_A0		1
1294c811b99SArnd Bergmann #define MV78100_REV_A1		2
1304c811b99SArnd Bergmann 
1314c811b99SArnd Bergmann #define MV78200_DEV_ID		0x7820
1324c811b99SArnd Bergmann #define MV78200_REV_A0		1
1334c811b99SArnd Bergmann 
1344c811b99SArnd Bergmann #endif
135