提交 a124e7f2 编写于 作者: A Aapo Vienamo 提交者: Greg Kroah-Hartman

soc/tegra: pmc: Fix pad voltage configuration for Tegra186

[ Upstream commit 13136a47a061c01c91df78b37f7708dd5ce7035f ]

Implement support for the PMC_IMPL_E_33V_PWR register which replaces
PMC_PWR_DET register interface of the SoC generations preceding
Tegra186. Also add the voltage bit offsets to the tegra186_io_pads[]
table and the AO_HV pad.
Signed-off-by: NAapo Vienamo <avienamo@nvidia.com>
Acked-by: NJon Hunter <jonathanh@nvidia.com>
Signed-off-by: NThierry Reding <treding@nvidia.com>
Signed-off-by: NSasha Levin <sashal@kernel.org>
上级 90cfef19
...@@ -65,6 +65,8 @@ ...@@ -65,6 +65,8 @@
#define PWRGATE_STATUS 0x38 #define PWRGATE_STATUS 0x38
#define PMC_IMPL_E_33V_PWR 0x40
#define PMC_PWR_DET 0x48 #define PMC_PWR_DET 0x48
#define PMC_SCRATCH0_MODE_RECOVERY BIT(31) #define PMC_SCRATCH0_MODE_RECOVERY BIT(31)
...@@ -154,6 +156,7 @@ struct tegra_pmc_soc { ...@@ -154,6 +156,7 @@ struct tegra_pmc_soc {
bool has_tsense_reset; bool has_tsense_reset;
bool has_gpu_clamps; bool has_gpu_clamps;
bool needs_mbist_war; bool needs_mbist_war;
bool has_impl_33v_pwr;
const struct tegra_io_pad_soc *io_pads; const struct tegra_io_pad_soc *io_pads;
unsigned int num_io_pads; unsigned int num_io_pads;
...@@ -1067,20 +1070,31 @@ int tegra_io_pad_set_voltage(enum tegra_io_pad id, ...@@ -1067,20 +1070,31 @@ int tegra_io_pad_set_voltage(enum tegra_io_pad id,
mutex_lock(&pmc->powergates_lock); mutex_lock(&pmc->powergates_lock);
/* write-enable PMC_PWR_DET_VALUE[pad->voltage] */ if (pmc->soc->has_impl_33v_pwr) {
value = tegra_pmc_readl(PMC_PWR_DET); value = tegra_pmc_readl(PMC_IMPL_E_33V_PWR);
value |= BIT(pad->voltage);
tegra_pmc_writel(value, PMC_PWR_DET);
/* update I/O voltage */ if (voltage == TEGRA_IO_PAD_1800000UV)
value = tegra_pmc_readl(PMC_PWR_DET_VALUE); value &= ~BIT(pad->voltage);
else
value |= BIT(pad->voltage);
if (voltage == TEGRA_IO_PAD_1800000UV) tegra_pmc_writel(value, PMC_IMPL_E_33V_PWR);
value &= ~BIT(pad->voltage); } else {
else /* write-enable PMC_PWR_DET_VALUE[pad->voltage] */
value = tegra_pmc_readl(PMC_PWR_DET);
value |= BIT(pad->voltage); value |= BIT(pad->voltage);
tegra_pmc_writel(value, PMC_PWR_DET);
/* update I/O voltage */
value = tegra_pmc_readl(PMC_PWR_DET_VALUE);
tegra_pmc_writel(value, PMC_PWR_DET_VALUE); if (voltage == TEGRA_IO_PAD_1800000UV)
value &= ~BIT(pad->voltage);
else
value |= BIT(pad->voltage);
tegra_pmc_writel(value, PMC_PWR_DET_VALUE);
}
mutex_unlock(&pmc->powergates_lock); mutex_unlock(&pmc->powergates_lock);
...@@ -1102,7 +1116,10 @@ int tegra_io_pad_get_voltage(enum tegra_io_pad id) ...@@ -1102,7 +1116,10 @@ int tegra_io_pad_get_voltage(enum tegra_io_pad id)
if (pad->voltage == UINT_MAX) if (pad->voltage == UINT_MAX)
return -ENOTSUPP; return -ENOTSUPP;
value = tegra_pmc_readl(PMC_PWR_DET_VALUE); if (pmc->soc->has_impl_33v_pwr)
value = tegra_pmc_readl(PMC_IMPL_E_33V_PWR);
else
value = tegra_pmc_readl(PMC_PWR_DET_VALUE);
if ((value & BIT(pad->voltage)) == 0) if ((value & BIT(pad->voltage)) == 0)
return TEGRA_IO_PAD_1800000UV; return TEGRA_IO_PAD_1800000UV;
...@@ -1561,6 +1578,7 @@ static const struct tegra_pmc_soc tegra30_pmc_soc = { ...@@ -1561,6 +1578,7 @@ static const struct tegra_pmc_soc tegra30_pmc_soc = {
.cpu_powergates = tegra30_cpu_powergates, .cpu_powergates = tegra30_cpu_powergates,
.has_tsense_reset = true, .has_tsense_reset = true,
.has_gpu_clamps = false, .has_gpu_clamps = false,
.has_impl_33v_pwr = false,
.num_io_pads = 0, .num_io_pads = 0,
.io_pads = NULL, .io_pads = NULL,
.regs = &tegra20_pmc_regs, .regs = &tegra20_pmc_regs,
...@@ -1603,6 +1621,7 @@ static const struct tegra_pmc_soc tegra114_pmc_soc = { ...@@ -1603,6 +1621,7 @@ static const struct tegra_pmc_soc tegra114_pmc_soc = {
.cpu_powergates = tegra114_cpu_powergates, .cpu_powergates = tegra114_cpu_powergates,
.has_tsense_reset = true, .has_tsense_reset = true,
.has_gpu_clamps = false, .has_gpu_clamps = false,
.has_impl_33v_pwr = false,
.num_io_pads = 0, .num_io_pads = 0,
.io_pads = NULL, .io_pads = NULL,
.regs = &tegra20_pmc_regs, .regs = &tegra20_pmc_regs,
...@@ -1683,6 +1702,7 @@ static const struct tegra_pmc_soc tegra124_pmc_soc = { ...@@ -1683,6 +1702,7 @@ static const struct tegra_pmc_soc tegra124_pmc_soc = {
.cpu_powergates = tegra124_cpu_powergates, .cpu_powergates = tegra124_cpu_powergates,
.has_tsense_reset = true, .has_tsense_reset = true,
.has_gpu_clamps = true, .has_gpu_clamps = true,
.has_impl_33v_pwr = false,
.num_io_pads = ARRAY_SIZE(tegra124_io_pads), .num_io_pads = ARRAY_SIZE(tegra124_io_pads),
.io_pads = tegra124_io_pads, .io_pads = tegra124_io_pads,
.regs = &tegra20_pmc_regs, .regs = &tegra20_pmc_regs,
...@@ -1772,6 +1792,7 @@ static const struct tegra_pmc_soc tegra210_pmc_soc = { ...@@ -1772,6 +1792,7 @@ static const struct tegra_pmc_soc tegra210_pmc_soc = {
.cpu_powergates = tegra210_cpu_powergates, .cpu_powergates = tegra210_cpu_powergates,
.has_tsense_reset = true, .has_tsense_reset = true,
.has_gpu_clamps = true, .has_gpu_clamps = true,
.has_impl_33v_pwr = false,
.needs_mbist_war = true, .needs_mbist_war = true,
.num_io_pads = ARRAY_SIZE(tegra210_io_pads), .num_io_pads = ARRAY_SIZE(tegra210_io_pads),
.io_pads = tegra210_io_pads, .io_pads = tegra210_io_pads,
...@@ -1800,7 +1821,7 @@ static const struct tegra_io_pad_soc tegra186_io_pads[] = { ...@@ -1800,7 +1821,7 @@ static const struct tegra_io_pad_soc tegra186_io_pads[] = {
{ .id = TEGRA_IO_PAD_HDMI_DP0, .dpd = 28, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_HDMI_DP0, .dpd = 28, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_HDMI_DP1, .dpd = 29, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_HDMI_DP1, .dpd = 29, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_PEX_CNTRL, .dpd = 32, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_PEX_CNTRL, .dpd = 32, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_SDMMC2_HV, .dpd = 34, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_SDMMC2_HV, .dpd = 34, .voltage = 5 },
{ .id = TEGRA_IO_PAD_SDMMC4, .dpd = 36, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_SDMMC4, .dpd = 36, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_CAM, .dpd = 38, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_CAM, .dpd = 38, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_DSIB, .dpd = 40, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_DSIB, .dpd = 40, .voltage = UINT_MAX },
...@@ -1812,12 +1833,13 @@ static const struct tegra_io_pad_soc tegra186_io_pads[] = { ...@@ -1812,12 +1833,13 @@ static const struct tegra_io_pad_soc tegra186_io_pads[] = {
{ .id = TEGRA_IO_PAD_CSIF, .dpd = 46, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_CSIF, .dpd = 46, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_SPI, .dpd = 47, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_SPI, .dpd = 47, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_UFS, .dpd = 49, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_UFS, .dpd = 49, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_DMIC_HV, .dpd = 52, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_DMIC_HV, .dpd = 52, .voltage = 2 },
{ .id = TEGRA_IO_PAD_EDP, .dpd = 53, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_EDP, .dpd = 53, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_SDMMC1_HV, .dpd = 55, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_SDMMC1_HV, .dpd = 55, .voltage = 4 },
{ .id = TEGRA_IO_PAD_SDMMC3_HV, .dpd = 56, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_SDMMC3_HV, .dpd = 56, .voltage = 6 },
{ .id = TEGRA_IO_PAD_CONN, .dpd = 60, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_CONN, .dpd = 60, .voltage = UINT_MAX },
{ .id = TEGRA_IO_PAD_AUDIO_HV, .dpd = 61, .voltage = UINT_MAX }, { .id = TEGRA_IO_PAD_AUDIO_HV, .dpd = 61, .voltage = 1 },
{ .id = TEGRA_IO_PAD_AO_HV, .dpd = UINT_MAX, .voltage = 0 },
}; };
static const struct tegra_pmc_regs tegra186_pmc_regs = { static const struct tegra_pmc_regs tegra186_pmc_regs = {
...@@ -1870,6 +1892,7 @@ static const struct tegra_pmc_soc tegra186_pmc_soc = { ...@@ -1870,6 +1892,7 @@ static const struct tegra_pmc_soc tegra186_pmc_soc = {
.cpu_powergates = NULL, .cpu_powergates = NULL,
.has_tsense_reset = false, .has_tsense_reset = false,
.has_gpu_clamps = false, .has_gpu_clamps = false,
.has_impl_33v_pwr = true,
.num_io_pads = ARRAY_SIZE(tegra186_io_pads), .num_io_pads = ARRAY_SIZE(tegra186_io_pads),
.io_pads = tegra186_io_pads, .io_pads = tegra186_io_pads,
.regs = &tegra186_pmc_regs, .regs = &tegra186_pmc_regs,
......
...@@ -134,6 +134,7 @@ enum tegra_io_pad { ...@@ -134,6 +134,7 @@ enum tegra_io_pad {
TEGRA_IO_PAD_USB2, TEGRA_IO_PAD_USB2,
TEGRA_IO_PAD_USB3, TEGRA_IO_PAD_USB3,
TEGRA_IO_PAD_USB_BIAS, TEGRA_IO_PAD_USB_BIAS,
TEGRA_IO_PAD_AO_HV,
}; };
/* deprecated, use TEGRA_IO_PAD_{HDMI,LVDS} instead */ /* deprecated, use TEGRA_IO_PAD_{HDMI,LVDS} instead */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册