f587a55bc2
* [libcpu/aarch64] add smp support * [libcpu/aarch64] rt_hw_trap_irq get irq instead of iar when using gicv2 * [libcpu/aarch64] disable irq/fiq when switch thread * [libcpu/aarch64] add gtimer frq set and stack align * [libcpu/aarch64] add gicv3 support and bsp/rockchip/rk3568
117 lines
3.2 KiB
C
117 lines
3.2 KiB
C
/*
|
|
* Copyright (c) 2006-2022, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2022-3-08 GuEe-GUI the first version
|
|
*/
|
|
|
|
#ifndef __RK3568_H__
|
|
#define __RK3568_H__
|
|
|
|
/* UART */
|
|
#define UART_MMIO_BASE 0xfe650000
|
|
#define UART0_MMIO_BASE 0xfdd50000
|
|
#define UART1_MMIO_BASE (UART_MMIO_BASE + 0)
|
|
#define UART2_MMIO_BASE (UART_MMIO_BASE + 0x10000)
|
|
#define UART3_MMIO_BASE (UART_MMIO_BASE + 0x20000)
|
|
#define UART4_MMIO_BASE (UART_MMIO_BASE + 0x30000)
|
|
#define UART5_MMIO_BASE (UART_MMIO_BASE + 0x40000)
|
|
#define UART6_MMIO_BASE (UART_MMIO_BASE + 0x50000)
|
|
#define UART7_MMIO_BASE (UART_MMIO_BASE + 0x60000)
|
|
#define UART8_MMIO_BASE (UART_MMIO_BASE + 0x70000)
|
|
#define UART9_MMIO_BASE (UART_MMIO_BASE + 0x80000)
|
|
|
|
#define UART_MMIO_SIZE 0x100
|
|
|
|
#define UART_IRQ_BASE (32 + 116)
|
|
#define UART0_IRQ (UART_IRQ_BASE + 0)
|
|
#define UART1_IRQ (UART_IRQ_BASE + 1)
|
|
#define UART2_IRQ (UART_IRQ_BASE + 2)
|
|
#define UART3_IRQ (UART_IRQ_BASE + 3)
|
|
#define UART4_IRQ (UART_IRQ_BASE + 4)
|
|
#define UART5_IRQ (UART_IRQ_BASE + 5)
|
|
#define UART6_IRQ (UART_IRQ_BASE + 6)
|
|
#define UART7_IRQ (UART_IRQ_BASE + 7)
|
|
#define UART8_IRQ (UART_IRQ_BASE + 8)
|
|
#define UART9_IRQ (UART_IRQ_BASE + 9)
|
|
|
|
/* GPIO */
|
|
#define GPIO0_MMIO_BASE 0xfdd60000
|
|
#define GPIO1_MMIO_BASE 0xfe740000
|
|
#define GPIO2_MMIO_BASE 0xfe750000
|
|
#define GPIO3_MMIO_BASE 0xfe760000
|
|
#define GPIO4_MMIO_BASE 0xfe770000
|
|
|
|
#define GPIO_MMIO_SIZE 0x100
|
|
|
|
#define GPIO_IRQ_BASE (32 + 33)
|
|
#define GPIO0_IRQ (GPIO_IRQ_BASE + 0)
|
|
#define GPIO1_IRQ (GPIO_IRQ_BASE + 1)
|
|
#define GPIO2_IRQ (GPIO_IRQ_BASE + 2)
|
|
#define GPIO3_IRQ (GPIO_IRQ_BASE + 3)
|
|
#define GPIO4_IRQ (GPIO_IRQ_BASE + 4)
|
|
|
|
/* MMC */
|
|
#define MMC0_MMIO_BASE 0xfe310000 /* sdhci */
|
|
#define MMC1_MMIO_BASE 0xfe2b0000 /* sdmmc0 */
|
|
#define MMC2_MMIO_BASE 0xfe2c0000 /* sdmmc1 */
|
|
#define MMC3_MMIO_BASE 0xfe000000 /* sdmmc2 */
|
|
|
|
#define MMC0_MMIO_SIZE 0x10000
|
|
#define MMC_MMIO_SIZE 0x4000
|
|
|
|
#define MMC0_IRQ (32 + 19)
|
|
#define MMC1_IRQ (32 + 98)
|
|
#define MMC2_IRQ (32 + 99)
|
|
#define MMC3_IRQ (32 + 100)
|
|
|
|
/* Ethernet */
|
|
#define GMAC0_MMIO_BASE 0xfe2a0000
|
|
#define GMAC1_MMIO_BASE 0xfe010000
|
|
|
|
#define GMAC_MMIO_SIZE 0x10000
|
|
|
|
#define GMAC0_MAC_IRQ (32 + 27)
|
|
#define GMAC0_WAKE_IRQ (32 + 24)
|
|
#define GMAC1_MAC_IRQ (32 + 32)
|
|
#define GMAC1_WAKE_IRQ (32 + 29)
|
|
|
|
/* GIC */
|
|
#define MAX_HANDLERS 256
|
|
#define GIC_IRQ_START 0
|
|
#define ARM_GIC_NR_IRQS 256
|
|
#define ARM_GIC_MAX_NR 1
|
|
|
|
#define IRQ_ARM_IPI_KICK 0
|
|
#define IRQ_ARM_IPI_CALL 1
|
|
|
|
#define GIC_PL600_DISTRIBUTOR_PPTR 0xfd400000
|
|
#define GIC_PL600_REDISTRIBUTOR_PPTR 0xfd460000
|
|
#define GIC_PL600_CONTROLLER_PPTR RT_NULL
|
|
#define GIC_PL600_ITS_PPTR 0xfd440000
|
|
|
|
rt_inline rt_uint32_t platform_get_gic_dist_base(void)
|
|
{
|
|
return GIC_PL600_DISTRIBUTOR_PPTR;
|
|
}
|
|
|
|
rt_inline rt_uint32_t platform_get_gic_redist_base(void)
|
|
{
|
|
return GIC_PL600_REDISTRIBUTOR_PPTR;
|
|
}
|
|
|
|
rt_inline rt_uint32_t platform_get_gic_cpu_base(void)
|
|
{
|
|
return GIC_PL600_CONTROLLER_PPTR;
|
|
}
|
|
|
|
rt_inline rt_uint32_t platform_get_gic_its_base(void)
|
|
{
|
|
return GIC_PL600_ITS_PPTR;
|
|
}
|
|
|
|
#endif /* __RK3568_H__ */
|