Commit 502717cc authored by Preetham Ramchandra's avatar Preetham Ramchandra Committed by Tejun Heo

ata: ahci_tegra: disable devslp for Tegra124

Tegra124 does not support devslp and it should be disabled.
Signed-off-by: default avatarPreetham Chandru R <pchandru@nvidia.com>
Acked-by: default avatarThierry Reding <treding@nvidia.com>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
parent 43ee827b
...@@ -166,12 +166,14 @@ struct tegra_ahci_ops { ...@@ -166,12 +166,14 @@ struct tegra_ahci_ops {
struct tegra_ahci_soc { struct tegra_ahci_soc {
const char *const *supply_names; const char *const *supply_names;
u32 num_supplies; u32 num_supplies;
bool supports_devslp;
const struct tegra_ahci_ops *ops; const struct tegra_ahci_ops *ops;
}; };
struct tegra_ahci_priv { struct tegra_ahci_priv {
struct platform_device *pdev; struct platform_device *pdev;
void __iomem *sata_regs; void __iomem *sata_regs;
void __iomem *sata_aux_regs;
struct reset_control *sata_rst; struct reset_control *sata_rst;
struct reset_control *sata_oob_rst; struct reset_control *sata_oob_rst;
struct reset_control *sata_cold_rst; struct reset_control *sata_cold_rst;
...@@ -181,6 +183,18 @@ struct tegra_ahci_priv { ...@@ -181,6 +183,18 @@ struct tegra_ahci_priv {
const struct tegra_ahci_soc *soc; const struct tegra_ahci_soc *soc;
}; };
static void tegra_ahci_handle_quirks(struct ahci_host_priv *hpriv)
{
struct tegra_ahci_priv *tegra = hpriv->plat_data;
u32 val;
if (tegra->sata_aux_regs && !tegra->soc->supports_devslp) {
val = readl(tegra->sata_aux_regs + SATA_AUX_MISC_CNTL_1_0);
val &= ~SATA_AUX_MISC_CNTL_1_0_SDS_SUPPORT;
writel(val, tegra->sata_aux_regs + SATA_AUX_MISC_CNTL_1_0);
}
}
static int tegra124_ahci_init(struct ahci_host_priv *hpriv) static int tegra124_ahci_init(struct ahci_host_priv *hpriv)
{ {
struct tegra_ahci_priv *tegra = hpriv->plat_data; struct tegra_ahci_priv *tegra = hpriv->plat_data;
...@@ -401,6 +415,7 @@ static int tegra_ahci_controller_init(struct ahci_host_priv *hpriv) ...@@ -401,6 +415,7 @@ static int tegra_ahci_controller_init(struct ahci_host_priv *hpriv)
val &= ~SATA_CONFIGURATION_0_CLK_OVERRIDE; val &= ~SATA_CONFIGURATION_0_CLK_OVERRIDE;
writel(val, tegra->sata_regs + SATA_CONFIGURATION_0); writel(val, tegra->sata_regs + SATA_CONFIGURATION_0);
tegra_ahci_handle_quirks(hpriv);
/* Unmask SATA interrupts */ /* Unmask SATA interrupts */
...@@ -446,6 +461,7 @@ static const struct tegra_ahci_ops tegra124_ahci_ops = { ...@@ -446,6 +461,7 @@ static const struct tegra_ahci_ops tegra124_ahci_ops = {
static const struct tegra_ahci_soc tegra124_ahci_soc = { static const struct tegra_ahci_soc tegra124_ahci_soc = {
.supply_names = tegra124_supply_names, .supply_names = tegra124_supply_names,
.num_supplies = ARRAY_SIZE(tegra124_supply_names), .num_supplies = ARRAY_SIZE(tegra124_supply_names),
.supports_devslp = false,
.ops = &tegra124_ahci_ops, .ops = &tegra124_ahci_ops,
}; };
...@@ -488,6 +504,16 @@ static int tegra_ahci_probe(struct platform_device *pdev) ...@@ -488,6 +504,16 @@ static int tegra_ahci_probe(struct platform_device *pdev)
if (IS_ERR(tegra->sata_regs)) if (IS_ERR(tegra->sata_regs))
return PTR_ERR(tegra->sata_regs); return PTR_ERR(tegra->sata_regs);
/*
* AUX registers is optional.
*/
res = platform_get_resource(pdev, IORESOURCE_MEM, 2);
if (res) {
tegra->sata_aux_regs = devm_ioremap_resource(&pdev->dev, res);
if (IS_ERR(tegra->sata_aux_regs))
return PTR_ERR(tegra->sata_aux_regs);
}
tegra->sata_rst = devm_reset_control_get(&pdev->dev, "sata"); tegra->sata_rst = devm_reset_control_get(&pdev->dev, "sata");
if (IS_ERR(tegra->sata_rst)) { if (IS_ERR(tegra->sata_rst)) {
dev_err(&pdev->dev, "Failed to get sata reset\n"); dev_err(&pdev->dev, "Failed to get sata reset\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment