root/drivers/soc/renesas/r9a08g045-sysc.c
// SPDX-License-Identifier: GPL-2.0
/*
 * RZ/G3S System controller driver
 *
 * Copyright (C) 2024 Renesas Electronics Corp.
 */

#include <linux/bits.h>
#include <linux/device.h>
#include <linux/init.h>

#include "rz-sysc.h"

#define SYS_XSPI_MAP_STAADD_CS0         0x348
#define SYS_XSPI_MAP_ENDADD_CS0         0x34c
#define SYS_XSPI_MAP_STAADD_CS1         0x350
#define SYS_XSPI_MAP_ENDADD_CS1         0x354
#define SYS_GETH0_CFG                   0x380
#define SYS_GETH1_CFG                   0x390
#define SYS_PCIE_CFG                    0x3a0
#define SYS_PCIE_MON                    0x3a4
#define SYS_PCIE_ERR_MON                0x3ac
#define SYS_PCIE_PHY                    0x3b4
#define SYS_I2C0_CFG                    0x400
#define SYS_I2C1_CFG                    0x410
#define SYS_I2C2_CFG                    0x420
#define SYS_I2C3_CFG                    0x430
#define SYS_I3C_CFG                     0x440
#define SYS_USB_PWRRDY                  0xd70
#define SYS_PCIE_RST_RSM_B              0xd74

static const struct rz_sysc_soc_id_init_data rzg3s_sysc_soc_id_init_data __initconst = {
        .family = "RZ/G3S",
        .id = 0x85e0447,
        .devid_offset = 0xa04,
        .revision_mask = GENMASK(31, 28),
        .specific_id_mask = GENMASK(27, 0),
};

static bool rzg3s_regmap_readable_reg(struct device *dev, unsigned int reg)
{
        switch (reg) {
        case SYS_XSPI_MAP_STAADD_CS0:
        case SYS_XSPI_MAP_ENDADD_CS0:
        case SYS_XSPI_MAP_STAADD_CS1:
        case SYS_XSPI_MAP_ENDADD_CS1:
        case SYS_GETH0_CFG:
        case SYS_GETH1_CFG:
        case SYS_PCIE_CFG:
        case SYS_PCIE_MON:
        case SYS_PCIE_ERR_MON:
        case SYS_PCIE_PHY:
        case SYS_I2C0_CFG:
        case SYS_I2C1_CFG:
        case SYS_I2C2_CFG:
        case SYS_I2C3_CFG:
        case SYS_I3C_CFG:
        case SYS_USB_PWRRDY:
        case SYS_PCIE_RST_RSM_B:
                return true;
        default:
                return false;
        }
}

static bool rzg3s_regmap_writeable_reg(struct device *dev, unsigned int reg)
{
        switch (reg) {
        case SYS_XSPI_MAP_STAADD_CS0:
        case SYS_XSPI_MAP_ENDADD_CS0:
        case SYS_XSPI_MAP_STAADD_CS1:
        case SYS_XSPI_MAP_ENDADD_CS1:
        case SYS_PCIE_CFG:
        case SYS_PCIE_PHY:
        case SYS_I2C0_CFG:
        case SYS_I2C1_CFG:
        case SYS_I2C2_CFG:
        case SYS_I2C3_CFG:
        case SYS_I3C_CFG:
        case SYS_USB_PWRRDY:
        case SYS_PCIE_RST_RSM_B:
                return true;
        default:
                return false;
        }
}

const struct rz_sysc_init_data rzg3s_sysc_init_data __initconst = {
        .soc_id_init_data = &rzg3s_sysc_soc_id_init_data,
        .readable_reg = rzg3s_regmap_readable_reg,
        .writeable_reg = rzg3s_regmap_writeable_reg,
        .max_register = 0xe20,
};