/* SPDX-License-Identifier: BSD-3-Clause */

#ifndef MT8195_H
#define MT8195_H

/*=======================================================================*/
/* Constant Definitions                                                  */
/*=======================================================================*/

#define IO_PHYS             (0x10000000)
#define IO_SIZE             (0x02000000)

#define VER_BASE            (0x08000000)

/*=======================================================================*/
/* Register Bases                                                        */
/*=======================================================================*/
#define MCUCFG_BASE          (0x0C530000)
#define TOPCKGEN_BASE        (IO_PHYS)
#define INFRACFG_AO_BASE     (IO_PHYS + 0x00001000)
#define APMIXED_BASE         (IO_PHYS + 0x0000C000)
#define INFRA_AO_BCRM_BASE   (IO_PHYS + 0x00022000)
#define AUDIO_BASE           (IO_PHYS + 0x00890000)
#define AUDIO_SRC_BASE       (IO_PHYS + 0x008a0000)
#define CAMSYS_YUVB_BASE     (IO_PHYS + 0x060af000)
#define CAMSYS_MAIN_BASE     (IO_PHYS + 0x06000000)
#define CAMSYS_MRAW_BASE     (IO_PHYS + 0x06140000)
#define CAMSYS_RAWA_BASE     (IO_PHYS + 0x0604f000)
#define CAMSYS_RAWB_BASE     (IO_PHYS + 0x0608f000)
#define CAMSYS_YUVA_BASE     (IO_PHYS + 0x0606f000)
#define CCU_MAIN_BASE        (IO_PHYS + 0x07200000)
#define IMGSYS1_DIP_NR_BASE  (IO_PHYS + 0x05130000)
#define IMGSYS1_DIP_TOP_BASE (IO_PHYS + 0x05110000)
#define IMGSYS1_WPE_BASE     (IO_PHYS + 0x05220000)
#define IMGSYS_MAIN_BASE     (IO_PHYS + 0x05000000)
#define IPESYS_BASE          (IO_PHYS + 0x05330000)
#define MFGCFG_BASE          (IO_PHYS + 0x03fbf000)
#define PERICFG_AO_BASE      (IO_PHYS + 0x01003000)
#define SCP_PAR_TOP_BASE     (IO_PHYS + 0x00720000)
#define IPNNA_BASE           (IO_PHYS + 0x00211000)
#define VDEC_CORE1_GCON_BASE (IO_PHYS + 0x0803f000)
#define VDEC_GCON_BASE       (IO_PHYS + 0x0802f000)
#define VDEC_SOC_GCON_BASE   (IO_PHYS + 0x0800f000)
#define VDOSYS0_CONFIG_BASE  (IO_PHYS + 0x0c01a000)
#define VDOSYS1_CONFIG_BASE  (IO_PHYS + 0x0c100000)
#define VENC_CORE1_GCON_BASE (IO_PHYS + 0x0b000000)
#define VENC_GCON_BASE       (IO_PHYS + 0x0a000000)
#define VPP0_REG_BASE        (IO_PHYS + 0x04000000)
#define VPPSYS1_CONFIG_BASE  (IO_PHYS + 0x04f00000)
#define WPESYS_TOP_REG_BASE  (IO_PHYS + 0x04e00000)
#define WPE_VPP0_BASE        (IO_PHYS + 0x04e02000)
#define WPE_VPP1_BASE        (IO_PHYS + 0x04e03000)

#define IOCFG_BM_BASE 		(0x11D10000)
#define IOCFG_BL_BASE 		(0x11D30000)
#define IOCFG_BR_BASE 		(0x11D40000)
#define IOCFG_LM_BASE 		(0x11E20000)
#define IOCFG_RB_BASE 		(0x11EB0000)
#define IOCFG_TL_BASE 		(0x11F40000)

/*should be removed*/
#define PERICFG_BASE        (IO_PHYS + 0x00003000)

//#define PERI_CON_BASE       (IO_PHYS + 0x00003000)

#define GPIO_BASE           (IO_PHYS + 0x00005000)
#define SPM_BASE            (IO_PHYS + 0x00006000)
#define RGU_BASE            (IO_PHYS + 0x00007000)
#define GPT_BASE            (IO_PHYS + 0x00008000)
#define SYSTIMER_BASE       (IO_PHYS + 0x00017000)
#define TIA_BASE            (IO_PHYS + 0x0001C000)
#define PMIF_SPI_BASE       (IO_PHYS + 0x00024000)
#define PMICSPI_MST_BASE    (IO_PHYS + 0x00025000)
#define PMIF_SPMI_BASE      (IO_PHYS + 0x00027000)
#define SPMI_MST_BASE       (IO_PHYS + 0x00029000)
#define DDRPHY_BASE         (IO_PHYS + 0x00330000)
#define KPD_BASE            (IO_PHYS + 0x00010000)

#define DEM_BASE            (0x0D0A0000)

#define MCUSYS_CFGREG_BASE  (0x0C530000)
//#define CA7MCUCFG_BASE      (IO_PHYS + 0x00200100)
//#define CA15L_CONFIG_BASE   (IO_PHYS + 0x00200200)
#define SRAMROM_BASE        (IO_PHYS + 0x00214000)
#define GICD_BASE           (0x0c000000)
#define GICR_BASE           (0x0c040000)

#define AUXADC_BASE         (IO_PHYS + 0X01002000)
#define DEVINFO_BASE        (IO_PHYS + 0x01C10000)
#define UART0_BASE          (IO_PHYS + 0x01001100)
#define UART1_BASE          (IO_PHYS + 0x01001200)
#define UART2_BASE          (IO_PHYS + 0x01001300)
#define UART3_BASE          (IO_PHYS + 0x01001400)
#define SPI_BASE            (IO_PHYS + 0x010F0000)
#define NFI_BASE            (IO_PHYS + 0x0100D000) /* FIXME: not list in memory map */
#define NFIECC_BASE         (IO_PHYS + 0x0100E000) /* FIXME: not list in memory map */
#define MSDC0_TOP_BASE      (IO_PHYS + 0x01F50000)
#define MSDC1_TOP_BASE      (IO_PHYS + 0x01E10000)
#define MSDC0_BASE          (IO_PHYS + 0x01230000)
#define MSDC1_BASE          (IO_PHYS + 0x01240000)
#define MSDC2_BASE          (IO_PHYS + 0x01250000)
#define MSDC3_BASE          (IO_PHYS + 0x01260000) /* Reserved in Sylvia */
#define U3D_BASE			(IO_PHYS + 0x01200000) /* MAC: 0x1120_0000 */
#define USB_SIF_BASE		(IO_PHYS + 0x01E40000) /* PHY: 0x11E4_0000 */
#define USB1P_SIF_BASE      (IO_PHYS + 0x01C40000)
#define PCIE_BASE           (IO_PHYS + 0x093F0000)
#define PCIE_PHY_BASE       (IO_PHYS + 0x01E20000)

#define CPUXGPT_BASE        (IO_PHYS + 0x00200000)

#define SUB_INFRACFG_AO_BASE  (IO_PHYS + 0x0030E000)

/*=======================================================================*/
/* AP HW code offset                                                     */
/*=======================================================================*/
#define APHW_CODE           (VER_BASE)
#define APHW_SUBCODE        (VER_BASE + 0x04)
#define APHW_VER            (VER_BASE + 0x08)
#define APSW_VER            (VER_BASE + 0x0C)

// #define AMCONFG_BASE        (0xFFFFFFFF)

/*=======================================================================*/
/* USB register offset                                                   */
/*=======================================================================*/
#define SSUSB_DEV_BASE                      (U3D_BASE + 0x1000) /* FIXME: not list in memory map */
#define SSUSB_EPCTL_CSR_BASE                (U3D_BASE + 0x1800) /* FIXME: not list in memory map */
#define SSUSB_USB3_MAC_CSR_BASE             (U3D_BASE + 0x2400) /* FIXME: not list in memory map */
#define SSUSB_USB3_SYS_CSR_BASE             (U3D_BASE + 0x2400) /* FIXME: not list in memory map */
#define SSUSB_USB2_CSR_BASE                 (U3D_BASE + 0x3400) /* FIXME: not list in memory map */

#define SSUSB_SIFSLV_IPPC_BASE              (U3D_BASE + 0x3E00) /* FIXME: not list in memory map */

#define SSUSB_SIFSLV_SPLLC_BASE             (USB_SIF_BASE + 0x700) /* FIXME: not list in memory map */
#define SSUSB_SIFSLV_U2PHY_COM_BASE         (USB_SIF_BASE + 0x300) /* FIXME: not list in memory map */
#define SSUSB_SIFSLV_U3PHYD_BASE            (USB_SIF_BASE + 0x900) /* FIXME: not list in memory map */
#define SSUSB_SIFSLV_U2PHY_COM_SIV_B_BASE   (USB_SIF_BASE + 0x300) /* FIXME: not list in memory map */
#define SSUSB_USB30_PHYA_SIV_B2_BASE        (USB_SIF_BASE + 0xA00) /* FIXME: not list in memory map */
#define SSUSB_USB30_PHYA_SIV_B_BASE         (USB_SIF_BASE + 0xB00) /* FIXME: not list in memory map */
#define SSUSB_SIFSLV_U3PHYA_DA_BASE         (USB_SIF_BASE + 0xC00) /* FIXME: not list in memory map */


/*=======================================================================*/
/* USB download control                                                  */
/*=======================================================================*/
#define SECURITY_AO                 (0x1001A000)
#define BOOT_MISC0                  (SECURITY_AO + 0x0080)
#define MISC_LOCK_KEY               (SECURITY_AO + 0x0100)
#define RST_CON                     (SECURITY_AO + 0x0108)

#define MISC_LOCK_KEY_MAGIC    0xAD98
#define USBDL_FLAG    BOOT_MISC0


#define USBDL_BIT_EN        (0x00000001) /* 1: download bit enabled */
#define USBDL_BROM          (0x00000002) /* 0: usbdl by brom; 1: usbdl by bootloader */
#define USBDL_TIMEOUT_MASK  (0x0000FFFC) /* 14-bit timeout: 0x0000~0x3FFE: second; 0x3FFFF: no timeout */
#define USBDL_TIMEOUT_MAX   (USBDL_TIMEOUT_MASK >> 2) /* maximum timeout indicates no timeout */
#define USBDL_MAGIC         (0x444C0000) /* Brom will check this magic number */


#define SRAMROM_USBDL_TO_DIS (SRAMROM_BASE + 0x0054)
#define USBDL_TO_DIS         (0x00000001)

/*=======================================================================*/
/* NAND Control                                                          */
/*=======================================================================*/
#define NAND_PAGE_SIZE                  (2048)  // (Bytes)
#define NAND_BLOCK_BLKS                 (64)    // 64 nand pages = 128KB
#define NAND_PAGE_SHIFT                 (9)
#define NAND_LARGE_PAGE                 (11)    // large page
#define NAND_SMALL_PAGE                 (9)     // small page
#define NAND_BUS_WIDTH_8                (8)
#define NAND_BUS_WIDTH_16               (16)
#define NAND_FDM_SIZE                   (8)
#define NAND_ECC_SW                     (0)
#define NAND_ECC_HW                     (1)

#define NFI_MAX_FDM_SIZE                (8)
#define NFI_MAX_FDM_SEC_NUM             (8)
#define NFI_MAX_LOCK_CHANNEL            (16)

#define ECC_MAX_CORRECTABLE_BITS        (12)
#define ECC_MAX_PARITY_SIZE             (20)    /* in bytes */

#define ECC_ERR_LOCATION_MASK           (0x1FFF)
#define ECC_ERR_LOCATION_SHIFT          (16)

#define NAND_FFBUF_SIZE                 (2048 + 64)

/*=======================================================================*/
/* SW Reset Vector                                                       */
/*=======================================================================*/
/* setup the reset vector base address after warm reset to Aarch64 */
#define RVBADDRESS_CPU0     (MCUSYS_CFGREG_BASE + 0xC900)

/* IRQ */
#define SYS_TIMER_IRQ       (233 + 32)
#define GZ_SW_IRQ           (513 + 32)

#endif