94 lines
2.2 KiB
C
94 lines
2.2 KiB
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,
|
|
};
|